Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/crazy-max/ghaction-github-labeler
GitHub Action to manage labels on GitHub
https://github.com/crazy-max/ghaction-github-labeler
actions github-actions github-labels
Last synced: 7 days ago
JSON representation
GitHub Action to manage labels on GitHub
- Host: GitHub
- URL: https://github.com/crazy-max/ghaction-github-labeler
- Owner: crazy-max
- License: mit
- Created: 2019-10-18T15:07:04.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-11-18T22:53:49.000Z (2 months ago)
- Last Synced: 2025-01-04T03:31:54.685Z (15 days ago)
- Topics: actions, github-actions, github-labels
- Language: TypeScript
- Homepage: https://github.com/marketplace/actions/github-labeler
- Size: 13.8 MB
- Stars: 145
- Watchers: 5
- Forks: 17
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Codeowners: .github/CODEOWNERS
- Support: .github/SUPPORT.md
Awesome Lists containing this project
- awesome-actions - Manage Labels on GitHub (create/rename/update/delete) as Code
- fucking-awesome-actions - Manage Labels on GitHub (create/rename/update/delete) as Code
- awesome-workflows - Manage Labels on GitHub (create/rename/update/delete) as Code
- jimsghstars - crazy-max/ghaction-github-labeler - GitHub Action to manage labels on GitHub (TypeScript)
README
[![GitHub release](https://img.shields.io/github/release/crazy-max/ghaction-github-labeler.svg?style=flat-square)](https://github.com/crazy-max/ghaction-github-labeler/releases/latest)
[![GitHub marketplace](https://img.shields.io/badge/marketplace-github--labeler-blue?logo=github&style=flat-square)](https://github.com/marketplace/actions/github-labeler)
[![Test workflow](https://img.shields.io/github/actions/workflow/status/crazy-max/ghaction-github-labeler/test.yml?branch=master&label=test&logo=github&style=flat-square)](https://github.com/crazy-max/ghaction-github-labeler/actions?workflow=test)
[![Codecov](https://img.shields.io/codecov/c/github/crazy-max/ghaction-github-labeler?logo=codecov&style=flat-square)](https://codecov.io/gh/crazy-max/ghaction-github-labeler)
[![Become a sponsor](https://img.shields.io/badge/sponsor-crazy--max-181717.svg?logo=github&style=flat-square)](https://github.com/sponsors/crazy-max)
[![Paypal Donate](https://img.shields.io/badge/donate-paypal-00457c.svg?logo=paypal&style=flat-square)](https://www.paypal.me/crazyws)## About
GitHub Action to manage labels on GitHub (create/rename/update/delete) as code.
![GitHub Labeler](.github/ghaction-github-labeler.png)
___
* [Usage](#usage)
* [YAML configuration](#yaml-configuration)
* [Workflow](#workflow)
* [Customizing](#customizing)
* [inputs](#inputs)
* [Contributing](#contributing)
* [License](#license)## Usage
### YAML configuration
In the repository where you want to perform this action, create the YAML file
`.github/labels.yml` (you can also set a [custom filename](#customizing)) that
looks like:```yaml
- name: "bug"
color: "#d73a4a"
description: "Something isn't working"
- name: "documentation"
color: "#0075ca"
description: "Improvements or additions to documentation"
- name: "duplicate"
color: "#cfd8d7"
description: "This issue or pull request already exists"
- name: "enhancement"
color: "#a22eef"
- name: "wontfix_it"
color: "#000000"
description: "This will not be worked on"
from_name: "wontfix"
```* `name`, `color` and `description` are the main [GitHub label fields](https://developer.github.com/v3/issues/labels/#parameters)
* `description` can be omit if your want to keep the current one
* `from_name` allow to rename a label from one currently available on your repository### Workflow
```yaml
name: githubon:
push:
branches:
- 'main'
paths:
- '.github/labels.yml'
- '.github/workflows/labels.yml'
pull_request:
paths:
- '.github/labels.yml'
- '.github/workflows/labels.yml'jobs:
labeler:
runs-on: ubuntu-latest
permissions:
contents: read
issues: write
steps:
-
name: Checkout
uses: actions/checkout@v4
-
name: Run Labeler
uses: crazy-max/ghaction-github-labeler@v5
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
yaml-file: .github/labels.yml
dry-run: ${{ github.event_name == 'pull_request' }}
exclude: |
help*
*issue
```With this workflow, the YAML configuration above on a [fresh repository](samples/original.yml),
this will:* Skip `bug` (because same `color` and `description`)
* Skip `documentation` (because same `color` and `description`)
* Update `duplicate` (`color` is different)
* Update `enhancement` (`color` is different, keep current `description`)
* Leave `good first issue` alone (because it matches an `exclude` pattern)
* Leave `help wanted` alone (because it matches an `exclude` pattern)
* Delete `invalid`
* Delete `question`
* Rename `wontfix` to `wontfix_it` and set `color` and `description`## Customizing
### inputs
Following inputs can be used as `step.with` keys
| Name | Type | Description |
|----------------|--------|-------------------------------------------------------------------------------------|
| `yaml-file` | String | Path to YAML file containing labels definitions. (default `.github/labels.yml`) |
| `skip-delete` | Bool | If enabled, labels will not be deleted if not found in YAML file. (default `false`) |
| `dry-run` | Bool | If enabled, changes will not be applied. (default `false`) |
| `exclude` | List | Newline delimited list of labels pattern(s)/matcher to exclude |## Contributing
Want to contribute? Awesome! The most basic way to show your support is to star
the project, or to raise issues. You can also support this project by [**becoming a sponsor on GitHub**](https://github.com/sponsors/crazy-max)
or by making a [PayPal donation](https://www.paypal.me/crazyws) to ensure this
journey continues indefinitely!Thanks again for your support, it is much appreciated! :pray:
## License
MIT. See `LICENSE` for more details.