GitHub Action that labels your pull requests automatically. Adds size labels (XS through XXL) based on lines changed, and type labels (feature, fix, docs, refactor, test, chore) using AI analysis of the diff.
on: pull_request
jobs:
label:
runs-on: ubuntu-latest
steps:
- uses: ofershap/ai-label-pr@v1
with:
api-key: ${{ secrets.OPENAI_API_KEY }}
provider: openai
model: gpt-4o-miniSupports OpenAI and Anthropic. Size labels use simple line-count thresholds. Type labels use AI to classify the diff. Just add your API key.
Demo built with remotion-readme-kit
Labeling PRs by hand is tedious, and most teams either skip it or do it inconsistently. But labels matter: they make it easy to filter PRs by type, spot oversized changes that need extra review, and generate better changelogs. Existing PR labelers use simple rules (line count thresholds), which works for size but can't tell a feature from a refactor. This action combines rule-based size labels with AI-powered type classification. The AI reads the PR title and a sample of the diff, then picks the most fitting type. Each PR gets exactly one size label and one type label.
- Size labels: based on total lines changed (additions + deletions). Thresholds: XS (<10), S (<50), M (<200), L (<500), XL (<1000), XXL (1000+).
- Type labels: AI reads the PR title and diff (first 3000 chars), then picks one type: feature, fix, docs, refactor, test, or chore.
Existing size/type labels are removed before adding the new ones, so each PR gets exactly one of each.
| Input | Description | Default |
|---|---|---|
provider |
AI provider: openai or anthropic |
openai |
model |
Model to use | gpt-4o-mini |
api-key |
API key for the AI provider | required |
size-labels |
Apply size labels (XS/S/M/L/XL/XXL) | true |
type-labels |
Apply type labels using AI | true |
github-token |
GitHub token (defaults to GITHUB_TOKEN) | ${{ github.token }} |
| Label | Lines changed |
|---|---|
| size/XS | < 10 |
| size/S | < 50 |
| size/M | < 200 |
| size/L | < 500 |
| size/XL | < 1000 |
| size/XXL | 1000+ |
| Label | Description |
|---|---|
| type/feature | New functionality or capability |
| type/fix | Bug fix or error correction |
| type/docs | Documentation changes only |
| type/refactor | Code restructuring without behavior change |
| type/test | Adding or updating tests only |
| type/chore | Build, CI, dependencies, or maintenance |
Part of the AI DevOps suite:
- ai-commit-msg: AI-generated conventional commit messages
- ai-pr-reviewer: AI-powered PR review comments
- ai-changelog: AI-generated changelogs from merged PRs
- ai-label-pr: Auto-label PRs by size and type (this project)
npm install
npm run typecheck
npm run build
npm test
npm run lintREADME built with README Builder
MIT © 2026 Ofer Shapira
