Skip to main content

A small client library for the Terraform Enterprise REST API.

Project description

Pyterprise

This is an object oriented client API for Terraform Enterprise written in Python. The methods included in this library generally map 1 to 1 in terms of function naming conventions to terraform enterprise documentation, so please review the available methods if you are uncertain on this library's usage.

Happy Terraforming!

Installation:

This module can be installed via pip, this library is compatible with python3.7. Install it with pip for python3.

pip3 install --user pyterprise

Usage:

Note: Some examples are covered here, but more are covered in the examples directory for more basic use-cases of this api.

First import the module and authenticate using the init method, you can retrieve a token from the terraform enterprise UI.

import pyterprise

tfe_token = 'TOKENHERE'
client = pyterprise.Client()

# Supply your token as a parameter and the url for the terraform enterprise server.
# If you are not self hosting, use the one provided by hashicorp.
client.init(token=tfe_token, url='https://example-host.com')

After instantiating your client you need to set an organization to access workspaces and more. From the client base-level you can also create/destroy/list organizations:

# Set the organization
org = client.set_organization(id='my-organization')

# Base level Methods:
#organizations = client.list_organizations()
#client.destroy_organization(name='my-safe-to-delete-org')
#client.create_organization(name='test', email='test@test.com')

This organization object org has access to workspaces, ssh keys and other methods (Check source code/examples for more):

# Creating a workspace with VCS example:
vcs_options = {
    "identifier": "my-github-org/my-repo",
    "oauth-token-id": "ot-xxxxxxxxxxx",
    "branch": "master",
    "default-branch": False
}
org.create_workspace(name='test-delete-me2',
                     vcs_repo=vcs_options,
                     auto_apply=False,
                     queue_all_runs=False,
                     working_directory='/',
                     trigger_prefixes=['/'])

# Or Delete a workspace at the organization level by name.
org.delete_workspace(name='my-safe-to-delete-test-workspace')

You can access workspace objects through your organization client object, which gives you access to runs, plans, statefiles, ssh-key additions and variables.

# Get a single workspace client object, 
# you can also list or search all workspace objects using the corresponding methods.
workspace = org.get_workspace('test-workspace')

# Get a list of all workspace objects in an organization.
for workspace in org.list_workspaces():
    print(workspace)

# Print some workspace attributes. Additionally you can access all attributes 
# as a dictionary by printing  the 'workspace' object at top level.                     
print(workspace.name, workspace.id, workspace.created_at)

# Run Workspace, you can destroy by changing the destroy flag.
workspace.run(destroy_flag=False)

# Plan and Apply in workspace with log output
workspace.plan_apply(destroy_flag=False)

# Update workspace, arguments identical to create function. Omit arguments to not alter.
workspace.update(auto_apply=True)

# Create a variable in a workspace
workspace.create_variable(key='foo', value='bar', sensitive=False, category='env')

# Print all variables for a workspace. 
# Variables objects also have functions for updating and deleting.
for variable in workspace.list_variables():
    print(variable)


# Apply latest unconfirmed plan in workspace. You can additionally print all attributes by print object at top level.
# or use other runs methods i.e. cancel, discard and get plan output etc.
for run in workspace.list_runs(page=1, page_size=20):
    if run.status == 'planned':
        run.apply(comment='Running latest plan.')

Please consult module contents, examples or terraform enterprise api documentation for more api client usage. This API does not currently cover administrative functions and teams, help is wanted for expanding functionality. Thank you.

API Coverage/Helper Methods

Workspaces
  • Method Coverage Complete.
Runs
  • Method Coverage Complete
Plans
  • Method Coverage Complete
Organization
  • Method Coverage Complete
SSH-Keys
  • Method Coverage Complete
Variables
  • Method Coverage Complete

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

pyterprise-0.0.15.tar.gz (10.7 kB view details)

Uploaded Source

Built Distribution

pyterprise-0.0.15-py3-none-any.whl (11.9 kB view details)

Uploaded Python 3

File details

Details for the file pyterprise-0.0.15.tar.gz.

File metadata

  • Download URL: pyterprise-0.0.15.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.40.2 CPython/3.7.3

File hashes

Hashes for pyterprise-0.0.15.tar.gz
Algorithm Hash digest
SHA256 cc789a8920a12cc5f4970f57dc50aacec1c8246da099b55c9e3dbed3d5760fc7
MD5 b20f8a052733ccc4487acfb649a6f943
BLAKE2b-256 42442d2930d7c99b1c7418449ab49fbcf9e18adb232681de800280dcab4c7da6

See more details on using hashes here.

File details

Details for the file pyterprise-0.0.15-py3-none-any.whl.

File metadata

  • Download URL: pyterprise-0.0.15-py3-none-any.whl
  • Upload date:
  • Size: 11.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.40.2 CPython/3.7.3

File hashes

Hashes for pyterprise-0.0.15-py3-none-any.whl
Algorithm Hash digest
SHA256 51dad547c177e57b86f12b18b48f0ec295c1d03065f8fff31e8a909f4cf56a66
MD5 9f0af175b996c5897cc78d71afc2ba84
BLAKE2b-256 c346997a54e165f7f31e69f7069031acbb590273f7a2a9ed105cb2eea5d7b539

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