Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/comcast/speculative-plan-pr-reporter-resource

A concourse resource to publish the speculative terraform plan as a PR comment.
https://github.com/comcast/speculative-plan-pr-reporter-resource

cicd concourse terraform

Last synced: about 2 months ago
JSON representation

A concourse resource to publish the speculative terraform plan as a PR comment.

Awesome Lists containing this project

README

        

# concourse-terraform-plan-reporter-resource

A Concourse resource to generate a report from a speculative terraform plan.

Written in Python, it currently supports publishing the report of changes as a table to a Github Pull Request
by taking advantage of the [telia-oss/github-pr-resource](https://github.com/telia-oss/github-pr-resource)
to fetch metadata for the PR.

[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)

## Source Configuration

| Parameter | Required | Default | Description |
|-|-|-|-|
| gh_api_endpoint | No | `https://api.github.com` | The API endpoint for the Github instance to which the resource should publish the speculative plan report. |
| gh_access_token | Yes | | The Github Personal Access Token to be used for accessing the Github API endpoint. This is usually fetched from a secret store like Vault and defined in the pipeline configuration as ((github.access_token)) |
| gh_repository | Yes | | The Github repository for which the pipeline is being executed. The path should be in the format `org_name/repo_name`. |
| pr_path | Yes | | The directory path to the pull request where `get` on `github-pr-resource` fetches the repository and the pull request metadata. |

## Behavior

### `check`

N/A. The check itself doesn't do anything in this resource currently to trigger
any action.

### `put`

#### Parameters

| Parameter | Required | Default | Description |
|-|-|-|-|
| plan_json_file | Yes | | The path to the terraform plan in the JSON format, generated using `terraform show --json `. This can be the result of a task or the use of `ljfranklin/terraform-resource` |

The version emitted from out is a `base64` representation of the comment posted to Github Pull Request.
in the markdown table format, comprising of the resources that are being created, modified or removed and an expandable description of
the attributes that are changed for each resource.

### `get`

The base64 representation of the comment URL is decoded and written to a file called `comment_url.txt`
under the resource directory.

## Example

```yml
resource_types:
- name: terraform
type: registry-image
source:
repository: ljfranklin/terraform-resource

- name: terraform-plan-gh-pr-resource
type: docker-image
source:
repository: /terraform-plan-pr-reporter-resource # Registry URL and namespace where the resource image is pushed to. The image can be generated using the `Dockerfile`.

- name: pull-request
type: registry-image
source:
repository: teliaoss/github-pr-resource

resources:
- name: examples
type: git
source:
uri: https://github.com/concourse/examples.git # This has a terraform example
branch: master

- name: appcode-pull-request
type: pull-request
check_every: 12h
source:
repository: /
access_token: ((github.access_token))
v3_endpoint: https://api.github.com
v4_endpoint: https://api.github.com/graphql
base_branch: main
states: ["OPEN"]
disable_forks: false

- name: deve-env-terraform
type: terraform
source:
env_name: main
backend_type: s3
backend_config:
bucket : ((terraform.backend.bucket))
region : us-east-1
key : ((terraform.backend.key))
access_key : ((aws.access_key_id))
secret_key : ((aws.secret_access_key))
token : ((aws.session_token))

- name: terraform-gh-pr
type: terraform-plan-gh-pr-resource
source:
gh_access_token: ((github.access_token))
gh_api: https://api.github.com
pr_path: appcode-pull-request
gh_repository: /gh_repository>
jobs:

- name: terraform-plan-aws
serial: true
plan:

- get: examples
- put: deve-env-terraform
get_params:
output_planfile: true
output_statefile: true
params:
plan_only: true
env_name : deve
terraform_source: examples/terraform/staging
- get: appcode-pull-request
- put: terraform-gh-pr
params:
plan_json_file: "deve-env-terraform/plan.json"
```

## Development

Prerequisites:
* python is required - version 3.11.1 is tested; earlier versions (3.x.x) may also work
* docker is required for buidling the resource.

To use the newly built image, push it to a docker registry that's accessible to
Concourse and configure your pipeline to use it:
Make sure to [force-recheck the resource type](https://concourse-ci.org/managing-resource-types.html#fly-check-resource-type) for the new changes to reflect

### Makefile

A lot of useful make directives are provided.

- To initialize the project, run `make all`.
- To format the code base, run `make pretty`.

### Building Docker image

Make directives are provided to aide with both local testing of the resource and pushing the resource to a docker registry.
Edit the `DOCKER_IMAGE_TAG` at the top of the `makefile`.

- `make docker-build` To build the image.
- `make docker-local` To test the image locally for `out` with a sample input.
- `make docker-push` To push the image to a docker registry.

Please make sure the user is authenticated against the respective docker registry.

The build image has to be pushed to registry before using the same in concourse.

## LICENSE

This project is licensed under the terms of the Apache 2.0 open source license. Please refer to [LICENSE](./LICENSE) for the full terms.