GitSOPS is a collection of GitHub Actions for managing secrets in Git repositories securely, leveraging SOPS for encryption. GitSOPS enables easy and secure handling of secrets in dotenv files stored in Git by providing actions to read, upsert (add/update), and delete secrets.
- Delete Secret: Removes a specified secret from an encrypted dotenv file.
- Read Secret: Reads and exports secrets from an encrypted dotenv file as environment variables.
- Upsert Secret: Adds or updates a secret in an encrypted dotenv file.
GitSOPS is designed as a GitHub Actions library to enable a secure, centralized secrets management system directly within GitHub workflows. It allows developers to manage secrets in Git repositories as part of a seamless CI/CD pipeline.
To use GitSOPS actions in your GitHub workflows, reference the actions in your .github/workflows YAML file.
For a full example of GitSOPS in action, check out gitsops-demo, a repository that demonstrates how to use GitSOPS to manage secrets as part of a platform API that adheres to GitOps principle of using git repositories as the single source of truth.
| Action | Input | Requirement | Description | 
|---|---|---|---|
| Delete | secret_name | Required | The name of the secret to delete. | 
| secret_file_path | Required | The path to the .envfile. | |
| additional_args | Optional | Additional arguments for the sopscommand, such as specifying keys for encryption/decryption. | |
| Read | secret_file_path | Required | The path to the .envfile. | 
| include_pattern | Optional | A regex pattern to filter which secrets to include (default is ".*"to include all). | |
| additional_args | Optional | Additional arguments for the sopscommand, such as specifying keys for encryption/decryption. | |
| Upsert | secret_name | Required | The name of the secret to add or update. | 
| secret_value | Required | The value of the secret. | |
| secret_file_path | Required | The path to the .envfile. | |
| additional_args | Optional | Additional arguments for the sopscommand, such as specifying keys for encryption/decryption. | 
- Automate README Generation: Automatically generate the README file with action descriptions and parameters.
- Add Release and Test Workflows: Implement workflows to automate releases and testing.
- Optimize with Pre-built Docker Images (under consideration): Use pre-built Docker images to improve performance and reduce build time on GitHub runners.
- Improve Logging: Use GitHub Actions commands to set the logging message level.
- Handle Special Charachters: Handle special charachters in user input.
GitSOPS is an independent project developed to manage secrets in Git repositories using SOPS for encryption. GitSOPS is not affiliated with, endorsed by, or associated with or the SOPS project.
GitSOPS leverages SOPS for secure encryption and decryption of secrets but is a separate toolset that integrates these capabilities into GitHub Actions for ease of use in CI/CD pipelines. For details on SOPS, please refer to the SOPS documentation.
This project is licensed under the MIT License.
I create open-source code and write articles on my website and GitHub, covering topics like automation, platform engineering, and smart home technology.
If you’d like to support my work (or treat my cat to a tuna can!), you can do so here: