Skip to main content

Ultralytics Actions for GitHub automation and PR management.

Project description

Ultralytics logo

🚀 Ultralytics Actions

Welcome to Ultralytics Actions - a collection of GitHub Actions for automating code quality, PR management, and CI/CD workflows across Ultralytics projects.

GitHub Actions Marketplace

Actions CI Ultralytics Actions Scan PRs codecov

Ultralytics Discord Ultralytics Forums Ultralytics Reddit

📦 Repository Contents

This repository provides three main components:

  1. Ultralytics Actions - Main GitHub Action for AI-powered code formatting, PR summaries, and auto-labeling
  2. Standalone Actions - Reusable composite actions for common CI/CD tasks
  3. Python Package - ultralytics-actions package for programmatic use

Ultralytics Actions (Main Action)

AI-powered formatting, labeling, and PR summaries for Python, Swift, and Markdown files.

📄 Features

  • Python Code: Formatted using Ruff, an extremely fast Python linter and formatter
  • Python Docstrings: Google-style formatting enforced with Ultralytics Python docstring formatter (optional)
  • JavaScript/TypeScript: Formatted with Biome, an extremely fast formatter for JS, TS, JSX, TSX, and JSON (optional, auto-detected via biome.json)
  • Markdown Files: Styled with Prettier to ensure consistent documentation appearance
  • Swift Code: Formatted with swift-format (requires macos-latest runner)
  • Spell Check: Common misspellings caught using codespell
  • Broken Links Check: Broken links identified using Lychee
  • PR Summary: Concise Pull Request summaries generated using AI
  • PR Review: AI-powered code reviews identify critical bugs, security issues, and quality concerns with suggested fixes
  • Auto-labeling: Applies relevant labels to issues, PRs, and discussions via AI

🤖 Supported AI Providers

Choose between OpenAI or Anthropic for AI-powered features:

Provider Default Model API Key
OpenAI gpt-5.4 openai_api_key
Anthropic claude-sonnet-4-6 anthropic_api_key

The model is auto-detected based on which API key you provide. Override with the model input, for example gpt-5.5, or use review_model to override PR review only.

🛠️ How It Works

Triggers on GitHub events to streamline workflows:

  • Pull Requests: Ensures formatting standards, generates summaries, provides AI reviews, and applies labels
  • Issues: Automatically applies relevant labels using AI
  • Discussions: Automatically applies relevant labels using AI

🔧 Setup

Create .github/workflows/ultralytics-actions.yml:

# Ultralytics 🚀 AGPL-3.0 License - https://ultralytics.com/license

# Ultralytics Actions https://github.com/ultralytics/actions
# This workflow formats code and documentation in PRs to Ultralytics standards

name: Ultralytics Actions

on:
  issues:
    types: [opened]
  discussion:
    types: [created]
  pull_request:
    branches: [main]
    types: [opened, closed, synchronize, review_requested]

permissions:
  contents: write # Modify code in PRs
  pull-requests: write # Add comments and labels to PRs
  issues: write # Add comments and labels to issues
  discussions: write # Add labels to discussions

jobs:
  actions:
    runs-on: ubuntu-latest
    steps:
      - name: Run Ultralytics Actions
        uses: ultralytics/actions@main
        with:
          token: ${{ secrets.GITHUB_TOKEN }} # Auto-generated token
          labels: true # Auto-label issues/PRs using AI
          python: true # Format Python with Ruff
          python_docstrings: true # Format Python docstrings (default: true)
          biome: true # Format JS/TS with Biome (auto-detected via biome.json)
          prettier: true # Format YAML, JSON, Markdown, CSS
          swift: false # Format Swift (requires macos-latest)
          dart: false # Format Dart/Flutter
          spelling: true # Check spelling with codespell
          links: true # Check broken links with Lychee
          summary: true # Generate AI-powered PR summaries
          # AI API keys - provide OpenAI OR Anthropic (model auto-detected from key)
          openai_api_key: ${{ secrets.OPENAI_API_KEY }}
          # anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }}
          # model: gpt-5.5  # Optional: override default model
          # review_model: claude-opus-4-7  # Optional: override PR review model
          brave_api_key: ${{ secrets.BRAVE_API_KEY }} # Used for broken link resolution

Standalone Actions

Reusable composite actions for common CI/CD tasks. Each can be used independently in your workflows.

1. Retry Action

Retry failed commands with exponential backoff and jitter.

- uses: ultralytics/actions/retry@main
  with:
    run: npm install
    retries: 3
    timeout_minutes: 5

📖 Full Documentation →

2. Cleanup Disk Action

Free up disk space on GitHub runners by removing unnecessary packages and files.

- uses: ultralytics/actions/cleanup-disk@main

📖 Full Documentation →

3. Scan PRs Action

List open PRs across an organization and auto-merge eligible GitHub Actions update PRs.

- uses: ultralytics/actions/scan-prs@main
  with:
    token: ${{ secrets.GITHUB_TOKEN }}
    org: ultralytics # Optional: defaults to ultralytics
    visibility: private,internal # Optional: public, private, internal, all, or comma-separated

📖 Full Documentation →

Python Package

Install ultralytics-actions for programmatic access to action utilities.

PyPI - Version Ultralytics Downloads PyPI - Python Version

pip install ultralytics-actions

Available Modules:

  • actions.review_pr - AI-powered PR review
  • actions.summarize_pr - Generate PR summaries
  • actions.scan_prs - Scan and manage organization PRs
  • actions.first_interaction - Welcome message for new contributors
  • And more in actions/ directory

💡 Contribute

Ultralytics thrives on community collaboration, and we deeply value your contributions! Please see our Contributing Guide for details on how you can get involved. We also encourage you to share your feedback through our Survey. A huge thank you 🙏 to all our contributors!

Ultralytics open-source contributors

📄 License

Ultralytics offers two licensing options:

  • AGPL-3.0 License: An OSI-approved open-source license ideal for students, researchers, and enthusiasts who value open collaboration. See the LICENSE file for details.
  • Enterprise License: Designed for commercial use, this license allows integrating Ultralytics software and AI models into commercial products without AGPL-3.0's open-source requirements. For enterprise solutions, contact Ultralytics Licensing.

📫 Contact

For bug reports or feature suggestions related to Ultralytics Actions, please submit an issue via GitHub Issues. Join our Discord community for discussions and support!


Ultralytics GitHub space Ultralytics LinkedIn space Ultralytics Twitter space Ultralytics YouTube space Ultralytics TikTok space Ultralytics BiliBili space Ultralytics Discord

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ultralytics_actions-0.2.15.tar.gz (87.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ultralytics_actions-0.2.15-py3-none-any.whl (80.8 kB view details)

Uploaded Python 3

File details

Details for the file ultralytics_actions-0.2.15.tar.gz.

File metadata

  • Download URL: ultralytics_actions-0.2.15.tar.gz
  • Upload date:
  • Size: 87.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ultralytics_actions-0.2.15.tar.gz
Algorithm Hash digest
SHA256 780bf6754fde720b9e14d23daf33a03e3b198596c79974b15229726bab8df8de
MD5 f26267090ea41100b082a076a227d036
BLAKE2b-256 7f1ff5167bc74c508f27eedf3889fc8f29153a1588bedee023ee12aa6196d5f8

See more details on using hashes here.

Provenance

The following attestation bundles were made for ultralytics_actions-0.2.15.tar.gz:

Publisher: publish.yml on ultralytics/actions

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ultralytics_actions-0.2.15-py3-none-any.whl.

File metadata

File hashes

Hashes for ultralytics_actions-0.2.15-py3-none-any.whl
Algorithm Hash digest
SHA256 88ee4d8bd341039b6f2df560152f330cb51a1b292deb553798c771a7e7ae766b
MD5 f95d6c7fc31468963aebc7a829eae3ff
BLAKE2b-256 1f79cbe03199fe935dc2c238f6d01b04a2cff496dfa1c3c7010612031b031c33

See more details on using hashes here.

Provenance

The following attestation bundles were made for ultralytics_actions-0.2.15-py3-none-any.whl:

Publisher: publish.yml on ultralytics/actions

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page