Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/int128/argocd-commenter
Notify ArgoCD Application status via Pull Request comment or GitHub Deployment API
https://github.com/int128/argocd-commenter
argocd golang kubebuilder kubernetes
Last synced: 3 days ago
JSON representation
Notify ArgoCD Application status via Pull Request comment or GitHub Deployment API
- Host: GitHub
- URL: https://github.com/int128/argocd-commenter
- Owner: int128
- License: apache-2.0
- Created: 2020-12-12T04:44:42.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-10-30T02:13:21.000Z (3 months ago)
- Last Synced: 2024-10-30T04:58:34.892Z (3 months ago)
- Topics: argocd, golang, kubebuilder, kubernetes
- Language: Go
- Homepage:
- Size: 1.67 MB
- Stars: 133
- Watchers: 3
- Forks: 16
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-argo - argocd-commenter
README
# argocd-commenter [![docker](https://github.com/int128/argocd-commenter/actions/workflows/docker.yaml/badge.svg)](https://github.com/int128/argocd-commenter/actions/workflows/docker.yaml)
This is a Kubernetes Controller to notify a change of Argo CD Application status.
## Example: Pull Request notification
In the [GitOps](https://www.weave.works/technologies/gitops/) way, you merge a pull request to deploy a change to Kubernetes cluster.
argocd-commenter allows you to receive a notification comment after merging.When an Application is syncing, synced or healthy, argocd-commenter will create a comment.
When the sync was failed, argocd-commenter will create a comment.
See the examples in [e2e-test fixtures](https://github.com/int128/argocd-commenter-e2e-test/pulls?q=is%3Apr+is%3Aclosed).
### Sequence diagram
Here is the sequence diagram of the deployment flow.
```mermaid
sequenceDiagram
actor UserUser ->>+ GitHub Repository: git push
GitHub Repository -->>- User: pushedloop Argo CD reconciler
Argo CD Application ->>+ GitHub Repository: git checkout
GitHub Repository -->>- Argo CD Application: manifest
note over Argo CD Application: Out of Sync
Argo CD Application ->>+ Kubernetes Deployment: kubectl apply
note over Argo CD Application: Syncing
Kubernetes Deployment -->>- Argo CD Application: applied
note over Argo CD Application: Synced
endloop Kubernetes reconciler
Kubernetes Deployment ->>+ Kubernetes Pod: create
note over Argo CD Application: Progressing
Kubernetes Pod -->>- Kubernetes Deployment: ready
note over Argo CD Application: Healthy
end
```## Example: GitHub Deployment notification
In a complex deployment flow, you can receive a notification using GitHub [Deployments](https://docs.github.com/en/rest/reference/deployments) API.
For example, when you deploy a preview environment for a pull request, you can receive the deployment statuses.To receive a deployment status, set the following annotation to the Argo CD Application:
```yaml
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
annotations:
argocd-commenter.int128.github.io/deployment-url: https://api.github.com/repos/OWNER/REPO/deployments/ID
```Here is an example of workflow to deploy a preview environment:
```yaml
jobs:
deploy:
steps:
# Create a deployment
- uses: int128/deployment-action@v1
id: deployment# Generate the manifests for a preview environment
- uses: actions/checkout@v2
with:
repository: your/manifests-repository
path: manifests-repository
token: # PAT or GitHub App token is required to write
- run: |
cp -a manifests "manifests-repository/pr-${{ github.event.pull_request.number }}"
cd "manifests-repository/pr-${{ github.event.pull_request.number }}"
sed -e 's|DEPLOYMENT_URL|${{ steps.deployment.outputs.url }}|g' applications/*.yaml# Push the manifests for a preview environment
- run: |
git add .
git commit -m 'Deploy pr-${{ github.event.pull_request.number }}'
git push manifests-repository main
```When the Application status is changed, argocd-commenter will create a deployment status.
![image](https://user-images.githubusercontent.com/321266/139166278-e74f6d1b-c722-430f-850c-2f7135e251d6.png)
See the [e2e test](https://github.com/int128/argocd-commenter/blob/main/.github/workflows/docker.yaml) for details.
### Sequence diagram
Here is the sequence diagram of the deployment flow.
```mermaid
sequenceDiagram
actor UserUser ->>+ Application Repository: git push
Application Repository -->>- User: pushedApplication Repository ->>+ GitHub Actions: start
GitHub Actions ->>+ GitHub Deployment: create
GitHub Deployment -->>- GitHub Actions: created
note over GitHub Deployment: Pending
GitHub Actions ->>+ Manifest Repository: git push
Manifest Repository -->>- GitHub Actions: pushed
GitHub Actions -->>- Application Repository: successloop Argo CD reconciler
Argo CD Application ->>+ Manifest Repository: git checkout
Manifest Repository -->>- Argo CD Application: manifest
note over Argo CD Application: Out of Sync
note over GitHub Deployment: Queued
Argo CD Application ->>+ Kubernetes Deployment: kubectl apply
note over Argo CD Application: Syncing
Kubernetes Deployment -->>- Argo CD Application: applied
note over Argo CD Application: Synced
note over GitHub Deployment: In progress
endloop Kubernetes reconciler
Kubernetes Deployment ->>+ Kubernetes Pod: create
note over Argo CD Application: Progressing
Kubernetes Pod -->>- Kubernetes Deployment: ready
note over Argo CD Application: Healthy
note over GitHub Deployment: Active
end
```## Getting Started
### Prerequisite
Argo CD is running in your Kubernetes cluster.
### Setup
To deploy the manifest:
```shell
kubectl apply -f https://github.com/int128/argocd-commenter/releases/download/v1.8.0/argocd-commenter.yaml
```You need to create either Personal Access Token or GitHub App.
- Personal Access Token
- Belong to a user
- Share the rate limit in a user
- GitHub App
- Belong to a user or organization
- Have each rate limit for an installation#### Option 1: Using a Personal Access Token
1. Open https://github.com/settings/tokens
1. Generate a new token
1. Create a secret as follows:
```shell
kubectl -n argocd-commenter-system create secret generic controller-manager \
--from-literal="GITHUB_TOKEN=$YOUR_PERSONAL_ACCESS_TOKEN"
```#### Option 2: Using a GitHub App
1. Create your GitHub App from either link:
- For a user: https://github.com/settings/apps/new?name=argocd-commenter&url=https://github.com/int128/argocd-commenter&webhook_active=false&contents=read&pull_requests=write
- For an organization: https://github.com/organizations/:org/settings/apps/new?name=argocd-commenter&url=https://github.com/int128/argocd-commenter&webhook_active=false&contents=read&pull_requests=write (replace `:org` with your organization)
1. Get the **App ID** from the setting page
1. [Download a private key of the GitHub App](https://docs.github.com/en/developers/apps/authenticating-with-github-apps)
1. [Set a custom badge for the GitHub App](https://docs.github.com/en/developers/apps/creating-a-custom-badge-for-your-github-app)
- Logo of Argo CD is available in [CNCF Branding](https://cncf-branding.netlify.app/projects/argo/)
1. [Install your GitHub App on your repository or organization](https://docs.github.com/en/developers/apps/installing-github-apps)
1. Get the **Installation ID** from the URL, like `https://github.com/settings/installations/ID`
1. Create a secret as follows:
```shell
kubectl -n argocd-commenter-system create secret generic controller-manager \
--from-literal="GITHUB_APP_ID=$YOUR_GITHUB_APP_ID" \
--from-literal="GITHUB_APP_INSTALLATION_ID=$YOUR_GITHUB_APP_INSTALLATION_ID" \
--from-file="GITHUB_APP_PRIVATE_KEY=/path/to/private-key.pem"
```### Verify setup
Make sure the controller is running.
```shell
kubectl -n argocd-commenter-system rollout status deployment argocd-commenter-controller-manager
```## Configuration
### GitHub Enterprise Server
Set the environment variable `GITHUB_ENTERPRISE_URL`.
```shell
kubectl -n argocd-commenter-system create secret generic controller-manager \
--from-literal="GITHUB_TOKEN=$YOUR_PERSONAL_ACCESS_TOKEN" \
--from-literal="GITHUB_ENTERPRISE_URL=$YOUR_GITHUB_ENTERPRISE_URL"
```## Contribution
This is an open source software. Feel free to contribute to it.