Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/unplatform-io/pulumi-commercetools
A Commercetools Pulumi resource package, bridges to the commercetools Terraform provider
https://github.com/unplatform-io/pulumi-commercetools
Last synced: 13 days ago
JSON representation
A Commercetools Pulumi resource package, bridges to the commercetools Terraform provider
- Host: GitHub
- URL: https://github.com/unplatform-io/pulumi-commercetools
- Owner: unplatform-io
- License: apache-2.0
- Created: 2020-12-17T12:20:47.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2024-03-21T08:28:43.000Z (10 months ago)
- Last Synced: 2025-01-01T19:14:26.452Z (25 days ago)
- Language: Python
- Homepage:
- Size: 759 KB
- Stars: 4
- Watchers: 2
- Forks: 3
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE-OF-CONDUCT.md
Awesome Lists containing this project
- awesome-pulumi - `unplatform-io/pulumi-commercetools` - CommerceTools resource provider for Pulumi (Providers / Miscellaneous)
README
[![Actions Status](https://github.com/unplatform-io/pulumi-commercetools/workflows/release/badge.svg)](https://github.com/unplatform-io/pulumi-commercetools/actions)
[![NPM version](https://badge.fury.io/js/%40unplatform%2Fcommercetools.svg)](https://www.npmjs.com/package/@unplatform/commercetools)
[![Python version](https://badge.fury.io/py/pulumi-commercetools.svg)](https://pypi.org/project/pulumi-commercetools)
[![NuGet version](https://badge.fury.io/nu/pulumi.commercetools.svg)](https://badge.fury.io/nu/pulumi.commercetools)
[![PkgGoDev](https://pkg.go.dev/badge/github.com/unplatform-io/pulumi-commercetools/sdk/v2/go)](https://pkg.go.dev/github.com/unplatform-io/pulumi-commercetools/sdk/v2/go)# CommerceTools provider
The CommerceTools resource provider for Pulumi lets you provision [CommerceTools](https://commercetools.com/) resources.This provider is a [bridge](https://github.com/pulumi/pulumi-terraform-bridge) to the excellent [CommerceTools Terraform Provider](https://github.com/labd/terraform-provider-commercetools) from the Labd folks.
To use this package, please [install the Pulumi CLI first](https://pulumi.io/).
## Installing
The plugin itself needs to be installed by running:
pulumi plugin install --server https://github.com/unplatform-io/pulumi-commercetools/releases/download/v0.0.0 resource commercetools v0.0.0
Where v0.0.0 is the desired version.
This SDK is available in many languages in the standard packaging formats.
### Node.js (Java/TypeScript)
To use from JavaScript or TypeScript in Node.js, install using either `npm`:
$ npm install @unplatform/commercetools
or `yarn`:
$ yarn add @unplatform/commercetools
### Python
To use from Python, install using `pip`:
$ pip install pulumi_commercetools
### Go
To use from Go, use `go get` to grab the latest version of the library
$ go get github.com/unplatform-io/pulumi-commercetools/sdk/v2/go/...
### .NET
To use from .NET, install using `dotnet add package`:
$ dotnet add package Pulumi.CommerceTools
## Configuration
The following configuration points are available for the `commercetools` provider:
- `commercetools:apiUrl` - the url of the commercetools api (e.g. `https://api.europe-west1.gcp.commercetools.com`)
- `commercetools:tokenUrl` - the url used to authenticate (e.g. `https://auth.europe-west1.gcp.commercetools.com`)
- `commercetools:scopes` - the authentication scopes needed
- `commercetools:clientId` - the client id used to authenticate
- `commercetools:clientSecret` - the client secret used to authenticate
- `commercetools:projectKey` - the key of the commerce tools project## Reference
For detailed reference documentation, please visit [the docs of the commerce tools terraform provider][1].
[1]: https://commercetools-terraform-provider.readthedocs.io/en/latest/
## Upgrading the pulumi plugin
To upgrade the plugin to a never version of the upstream terraform client the following steps should be taken:
- Update the submodule: `git submodule update --remote --merge`
- Validate if the patches in `upstream_patches/` are still valid e.g.
- They might reference the wrong line of code
- They might be unneeded
- Validate if there are new mappings / changed mappings in `provider/resources.go`
- You can check if there are new items by reading the console output of `make tfgen`
- If upstream has stopped using terraform SDK and now fully uses terraform plugin framework:
- Remove the muxer in `provider/resources.go`, `provider/cmd/pulumi-*-commercetools/main.go` and the `provider/shim/shim.go`
- Validate the current implementation with the documentation on [How to Bridge a Provider](https://github.com/pulumi/pulumi-terraform-bridge/blob/master/pf/README.md)
- Rebuild the SDK's using `make build_sdks`
- Validate the functionality using the sample project, make sure to fill in valid credentials in `Pulumi.commercetools-test.yml`