Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/actionsdesk/github-actions-allow-list-as-code-action
Automate GitHub Actions allow list for GitHub Enterprise Cloud accounts
https://github.com/actionsdesk/github-actions-allow-list-as-code-action
automation github-actions github-enterprise-cloud policy-as-code
Last synced: about 2 months ago
JSON representation
Automate GitHub Actions allow list for GitHub Enterprise Cloud accounts
- Host: GitHub
- URL: https://github.com/actionsdesk/github-actions-allow-list-as-code-action
- Owner: ActionsDesk
- License: mit
- Created: 2021-05-27T07:07:46.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-01T14:23:51.000Z (3 months ago)
- Last Synced: 2024-10-13T23:21:13.518Z (3 months ago)
- Topics: automation, github-actions, github-enterprise-cloud, policy-as-code
- Language: JavaScript
- Homepage:
- Size: 2.81 MB
- Stars: 14
- Watchers: 4
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: readme.md
- Contributing: .github/contributing.md
- License: license
- Code of conduct: .github/code_of_conduct.md
- Codeowners: .github/codeowners
- Security: .github/security.md
Awesome Lists containing this project
README
# github-actions-allow-list-as-code-action
> Automate GitHub Actions allow list for GitHub Enterprise accounts
[![test](https://github.com/ActionsDesk/github-actions-allow-list-as-code-action/actions/workflows/test.yml/badge.svg)](https://github.com/ActionsDesk/github-actions-allow-list-as-code-action/actions/workflows/test.yml) [![CodeQL](https://github.com/ActionsDesk/github-actions-allow-list-as-code-action/actions/workflows/github-code-scanning/codeql/badge.svg)](https://github.com/ActionsDesk/github-actions-allow-list-as-code-action/actions/workflows/github-code-scanning/codeql) [![styled with prettier](https://img.shields.io/badge/styled_with-prettier-ff69b4.svg)](https://github.com/prettier/prettier)
## Usage
```yml
name: Deploy GitHub Actions allow liston:
push:
branches: [main]
paths: [github-actions-allow-list.yml]jobs:
deploy:
runs-on: ubuntu-latestpermissions: read-all
steps:
- name: Checkout
uses: actions/[email protected]- name: Setup node
uses: actions/[email protected]
with:
node-version: 14.x- name: Deploy GitHub Actions allow list
uses: ActionsDesk/[email protected]
with:
token: ${{ secrets.ENTERPRISE_ADMIN_TOKEN }}
enterprise: 'your-enterprise'
# same as defined under `on.pull_requests.paths`
allow_list_path: github-actions-allow-list.yml
# gh_api_url: 'https://github.example.com/api/v3' # Only required for GitHub Enterprise Server
```### Action Inputs
| Name | Description | Default | Required |
| :---------------- | :--------------------------------------------------------------------------------------------------------------- | :------------------------------ | :------- |
| `token` | GitHub Personal Access Token ([PAT]) with `admin:enterprise` or `admin:org` scope | | `true` |
| `organization` | GitHub organization slug | | `false` |
| `enterprise` | GitHub Enterprise account slug | | `false` |
| `allow_list_path` | Path to the GitHub Actions allow list YML within the repository | `github-actions-allow-list.yml` | `false` |
| `gh_api_url` | GitHub Enterprise Servier - URL to the GitHub API endpoint.
Example: `https://github.example.com/api/v3.` | `https://api.github.com` | `false` |ℹ️ Notes for providing `enterprise` or `organization`:
- Either provide `enterprise` to update the [GitHub Enterprise Cloud's actions allow list](https://docs.github.com/en/github/setting-up-and-managing-your-enterprise/setting-policies-for-organizations-in-your-enterprise-account/enforcing-github-actions-policies-in-your-enterprise-account#allowing-specific-actions-to-run), or `organization` to update a single [organization's allow list](https://docs.github.com/en/organizations/managing-organization-settings/disabling-or-limiting-github-actions-for-your-organization#allowing-specific-actions-to-run).
- Providing both will result in the action run failing with `Please provide only one of: enterprise, organization`.
- If providing `organization`, but the allow list is handled via [GitHub Enterprise Cloud's actions allow list](https://docs.github.com/en/github/setting-up-and-managing-your-enterprise/setting-policies-for-organizations-in-your-enterprise-account/enforcing-github-actions-policies-in-your-enterprise-account#allowing-specific-actions-to-run), the action run will fail with `Selected actions are already set at the enterprise level`.## Allow List file
Example content for Allow List file containing `actions:` key and list with two allowed actions.
```yml
actions:
- actionsdesk/[email protected]
- hashicorp/[email protected]
```## License
- [MIT License](./license)
[pat]: https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token 'Personal Access Token'