This action runs on pull requests to count GitHub organization members and membership written in terraform files.
Required. This token needs to have read:org
scope to read organization information by octokit.
See https://docs.github.com/en/rest/reference/orgs#get-an-organization
Required. The json file from running the command terraform show --json | jq
.
Required. This organization name for which you want to count seats.
Seats that membership used.
Max seats an organization can use.
Total number of membership in the github_membership
and github_repository_collaborator
resources written in the terraform file.
Members which are in terraform do not exist in GitHub.
- Note: This action should be used with setup-terraform step. The terraform_wrapper flag in the setup-terraform step should be set to false.
on: [pull_request]
jobs:
job:
runs-on: ubuntu-latest
name: A job to show seats
steps:
- uses: actions/checkout@v2
- uses: hashicorp/setup-terraform@v2
with:
terraform_version: 1.3.9
terraform_wrapper: false
- name: Terraform init
run: terraform init
- name: Terraform plan
run: terraform plan -out plan-binary
- name: Terraform show --json
run: terraform show --json plan-binary | jq >> terraform-json.json
- name: Set up ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: 2.7
- name: Count seats and members
id: seats_members
uses: M-Yamashita01/[email protected]
env:
ACCESS_TOKEN: ${{ secrets.GITHUB_ADMIN_ACCESS_TOKEN }}
TERRAFORM_JSON_FILE_PATH: '${{ github.workspace }}/terraform-json.json'
ORGANIZATION_NAME: 'organization_name'
- name: Post comments
uses: actions/github-script@v5
with:
script: |
var output = `Current seats in organization and members in terraform files.\n
・Seats that membership used:: ${{ steps.seats_members.outputs.filled_seats }}\n
・Max seats an organization can use: ${{ steps.seats_members.outputs.max_seats }}\n
・Total number of membership in terraform files: ${{ steps.seats_members.outputs.members_in_terraform }}\n\n
`
const numberOfSeatsInShortage = ${{ steps.seats_members.outputs.members_in_terraform }} - ${{ steps.seats_members.outputs.max_seats }}
var additional_message = `There is no shortage of seats.\n`
if (numberOfSeatsInShortage > 0) {
additional_message = `There are ${numberOfSeatsInShortage} seats missing. Please add seats.\n`
}
var notify_non_existing_member_message = ``
const non_existing_members = "${{ steps.seats_members.outputs.non_existing_members }}"
if (non_existing_members.length > 0) {
notify_non_existing_member_message = `Some members in terraform files do not exist. Please check the members.\n
・Non-existing members: ${non_existing_members}.\n\n
`
}
output += additional_message
output += notify_non_existing_member_message
github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body: output
})