Skip to main content

Python HTTP client library for Terraform Cloud/Enterprise API.

Project description

pytfc

Python HTTP client library for the Terraform Cloud and Terraform Enterprise API.

import pytfc
client = pytfc.Client(org='my-tfe-org')
client.workspaces.create(name='aws-base-vpc-dev')
client.set_ws(name='aws-base-vpc-dev')
client.workspace_variables.create(key='AWS_ACCESS_KEY_ID', value='ABCDEFGHIJKLMNOPQRST', category='env', sensitive='true')
client.workspace_variables.create(key='AWS_SECRET_ACCESS_KEY', value='ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789ABCD', category='env', sensitive='true')

Usage

A client object must be instantiated with certain parameters. The parameters can be specified as environment variables or directly as function arguments. The only parameter required at the time a client is instantiated is the API token. A hostname is also required if you are using TFE, and if a hostname is not specified it is assumed you are using TFC (app.terraform.io). Depending on what level you are working at, mainly Organization-level vs. Workspace-level, you can optionally set some of the other parameters either at the time the client is instantiated or after the fact.

Instantiating a Client

With environment variables:

os.environ['TFE_HOSTNAME']='tfe.whatever.com'
os.environ['TFE_TOKEN']='abcdefghijklmn.atlasv1.opqrstuvwxyz012345678987654321abcdefghijklmnopqrstuvwxyz01234567890'

client = pytfc.Client(org='my-existing-tfe-org')

Directly as function arguments:

client = pytfc.Client(hostname='tfe.whatever.com', token='abcdefghijklmn.atlasv1.opqrstuvwxyz012345678987654321abcdefghijklmnopqrstuvwxyz01234567890', org='my-existing-tfe-org')

Setting the Organization and Workspace when a client is instantiated:

client = pytfc.Client(org='my-existing-tfe-org', ws='my-existing-tfe-ws')

Assumes the TFE_HOSTNAME and TFE_TOKEN environment variables are set.

Setting the Organization and Workspace after a client is instantiated:

client = pytfc.Client()
client.set_org(name='my-existing-tfe-org')
client.set_ws(name='my-existing-tfe-ws')

Assumes the TFE_HOSTNAME and TFE_TOKEN environment variables are set.


See the docs for more details and examples on usage.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pytfc-0.0.11.tar.gz (24.1 kB view details)

Uploaded Source

Built Distribution

pytfc-0.0.11-py3-none-any.whl (35.0 kB view details)

Uploaded Python 3

File details

Details for the file pytfc-0.0.11.tar.gz.

File metadata

  • Download URL: pytfc-0.0.11.tar.gz
  • Upload date:
  • Size: 24.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for pytfc-0.0.11.tar.gz
Algorithm Hash digest
SHA256 f51811d3ae6f400073025f65bc9d9f506ee6c1bd4ca95a3ecbf11bf644103d2e
MD5 31c22ab4263d9c4242751fe9bb242ca4
BLAKE2b-256 04c422ee15216e9d42b81271b04cdcc8365c80f4d86f049a5a84791b057ae123

See more details on using hashes here.

File details

Details for the file pytfc-0.0.11-py3-none-any.whl.

File metadata

  • Download URL: pytfc-0.0.11-py3-none-any.whl
  • Upload date:
  • Size: 35.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for pytfc-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 df0db6c6238932a57b6abf695b0af7ef8c51ffead6f75b03b114b5ffea1c255a
MD5 3fe8676b36fa6d550e1c6c4821bceaf9
BLAKE2b-256 122538b8264515bba78fb0035c331da4ea23d6d72ae8ea670a767fc7b27e332c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page