Metadata-Version: 2.2
Name: terratalk
Version: 0.5.1
Summary: A Terraform commentator.
Home-page: https://github.com/lifeofguenter/terratalk
Author: Günter Grodotzki
Author-email: gunter@grodotzki.com
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: Click
Requires-Dist: requests
Provides-Extra: github
Requires-Dist: PyGithub; extra == "github"
Provides-Extra: gitlab
Requires-Dist: python-gitlab; extra == "gitlab"
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: provides-extra
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

# terratalk

[![build and publish](https://github.com/lifeofguenter/terratalk/actions/workflows/build-and-publish.yml/badge.svg)](https://github.com/lifeofguenter/terratalk/actions/workflows/build-and-publish.yml)
[![Coverage Status](https://coveralls.io/repos/github/lifeofguenter/terratalk/badge.svg)](https://coveralls.io/github/lifeofguenter/terratalk)
[![PyPI](https://img.shields.io/pypi/v/terratalk.svg)](https://pypi.org/project/terratalk/)
![PyPI - Downloads](https://img.shields.io/pypi/dm/terratalk)
[![License](https://img.shields.io/github/license/lifeofguenter/terratalk.svg)](LICENSE)

**_Terratalk_** is a simple tool to add an opinionated terraform plan output
into your pull-request as a comment. This allows you to have a quick feedback on
infrastructure changes without having to leave the context of your pull-request
view.

## Setup

### Prerequisite

This tool relies on either
[Bitbucket Branch Source](https://plugins.jenkins.io/cloudbees-bitbucket-branch-source/)
or [GitHub Branch Source](https://plugins.jenkins.io/github-branch-source/) to
be installed as a plugin on your Jenkins. Alternatively you can set the
environment variable `CHANGE_URL` to the URL of the pull-request which will
allow `terratalk` to construct the proper API request to your SCM.

GitLab is currently only supported from gitlab-pipelines.

### Installation

On the build agent, install `terratalk`:

```bash
$ pip install --user terratalk
```

If you are using GitHub you will additionally need to install the following:

```bash
$ pip install --user PyGithub
```

If you are using GitLab you will additionally need to install the following:

```bash
$ pip install --user python-gitlab
```

### Running

Execute in the same directory, optionally with the same `TF_DATA_DIR` as you
would normally run `terraform`. If you use
[`tfenv`](https://github.com/tfutils/tfenv) that will work as well.

```bash
$ terraform plan -out WORKSPACE.plan
$ terratalk comment -w WORKSPACE
```

### Supported providers

#### Bitbucket Server (Jenkins)

* `STASH_USER`
* `STASH_PASS`

#### Bitbucket Cloud (Jenkins)

* `BITBUCKET_USERNAME`
* `BITBUCKET_APP_PASSWORD`

#### GitHub (Jenkins)

* `GITHUB_TOKEN`

#### GitLab (pipelines)

* `GITLAB_TOKEN`

#### Gitea (actions)

* `TERRATALK_GITEA_TOKEN`

## Results

![terratalk on Bitbucket Server](https://raw.githubusercontent.com/lifeofguenter/terratalk/main/docs/images/terratalk-on-bitbucket-server.png "terratalk on Bitbucket Server")

## License

[MIT](LICENSE)
