Skip to main content

CLI tool for executing automated workflows across Imbi projects with AI-powered transformations and GitHub PR integration.

Project description

Imbi Automations CLI

Tests Docker Build PyPI Version Docker Hub GHCR

CLI tool for executing automated workflows across Imbi projects with AI-powered transformations and GitHub PR integration.

Overview

Imbi Automations is a comprehensive CLI framework that enables bulk automation across software project repositories with deep integration to the Imbi project management system. The tool supports multiple workflow types with advanced filtering, conditional execution, and AI-powered transformations.

Key Features

  • GitHub Integration: GitHub API integration with comprehensive repository operations
  • Workflow Engine: Action-based processing with conditional execution
  • AI Integration: Claude Code SDK for intelligent transformations
  • Batch Processing: Concurrent processing with resumption capabilities
  • Template System: Jinja2-based file generation with full project context
  • Advanced Filtering: Target specific project subsets with multiple criteria

Action Types

  • Callable Actions: Direct method calls on client instances
  • Claude Code: Comprehensive AI-powered code transformations
  • Docker Operations: Container-based file extraction and manipulation
  • Git Operations: Version control operations and branch management
  • File Actions: Copy, move, delete, and regex replacement operations
  • Shell Commands: Execute arbitrary commands with template variables
  • Utility Actions: Helper operations for common workflow tasks
  • Template System: Generate files from Jinja2 templates

Documentation

Documentation is available at https://aweber-imbi.github.io/imbi-automations/.

Quick Start

# Run workflows
imbi-automations config.toml workflows/workflow-name --all-projects

# Resume from a specific project
imbi-automations config.toml workflows/workflow-name --all-projects --start-from-project my-project-slug

# Run using Docker:

```bash
docker run --rm \
  -v $(pwd)/config.toml:/config/config.toml:ro \
  -v $(pwd)/workflows:/workflows:ro \
  -v ~/.ssh:/root/.ssh:ro \
  -v imbi-cache:/cache \
  aweber/imbi-automations:latest /config/config.toml /workflows/my-workflow --all-projects

Installation

From PyPI

pip install imbi-automations

Docker Installation

Pre-built multi-architecture images are automatically published to both Docker Hub and GitHub Container Registry on every release:

# Pull from Docker Hub (recommended)
docker pull aweber/imbi-automations:latest

# Or pull from GitHub Container Registry
docker pull ghcr.io/aweber-imbi/imbi-automations:latest

# Or use a specific version
docker pull aweber/imbi-automations:1.0.0
docker pull ghcr.io/aweber-imbi/imbi-automations:1.0.0

# Run with docker-compose (recommended)
docker-compose run --rm aweber/imbi-automations /config/config.toml /workflows/my-workflow --all-projects

# Or run directly with docker (Docker Hub)
docker run --rm \
  -v $(pwd)/config.toml:/config/config.toml:ro \
  -v $(pwd)/workflows:/workflows:ro \
  -v ~/.ssh:/root/.ssh:ro \
  -v imbi-cache:/cache \
  aweber/imbi-automations:latest /config/config.toml /workflows/my-workflow --all-projects

# Or run with GHCR
docker run --rm \
  -v $(pwd)/config.toml:/config/config.toml:ro \
  -v $(pwd)/workflows:/workflows:ro \
  -v ~/.ssh:/root/.ssh:ro \
  -v imbi-cache:/cache \
  ghcr.io/aweber-imbi/imbi-automations:latest /config/config.toml /workflows/my-workflow --all-projects

Build from source:

docker build -t imbi-automations:latest .

Docker Volume Mounts:

  • /config/config.toml - Configuration file (read-only recommended)
  • /workflows - Workflows directory (read-only recommended)
  • /cache - Metadata cache directory (persistent)
  • /workspace - Temporary working directory for repo clones
  • /root/.ssh - SSH keys for git operations (read-only)
  • /root/.gnupg - GPG keys for commit signing (optional, read-only)

Important Notes:

  • Claude Code in containers may have limitations with interactive features
  • Ensure SSH keys have proper permissions (0600) when mounting
  • API keys should be in config.toml for security
  • Use named volumes for cache to improve performance across runs

Development Setup

git clone https://github.com/AWeber-Imbi/imbi-automations.git
cd imbi-automations
pip install -e .[dev]
pre-commit install

Project details


Download files

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

Source Distribution

imbi_automations-1.0.0a8.tar.gz (222.4 kB view details)

Uploaded Source

Built Distribution

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

imbi_automations-1.0.0a8-py3-none-any.whl (105.9 kB view details)

Uploaded Python 3

File details

Details for the file imbi_automations-1.0.0a8.tar.gz.

File metadata

  • Download URL: imbi_automations-1.0.0a8.tar.gz
  • Upload date:
  • Size: 222.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for imbi_automations-1.0.0a8.tar.gz
Algorithm Hash digest
SHA256 2136fa6e0abaa978505c72b9b3378af9ad841e756e9825be5fc233f87ee3ed9d
MD5 caba0b78e2a0e2f3ccc21c915823d4f8
BLAKE2b-256 581a56c020991f176adb5a8e998eae9f25ae3500df2721d56141cbf658df7f3c

See more details on using hashes here.

Provenance

The following attestation bundles were made for imbi_automations-1.0.0a8.tar.gz:

Publisher: publish.yml on AWeber-Imbi/imbi-automations

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

File details

Details for the file imbi_automations-1.0.0a8-py3-none-any.whl.

File metadata

File hashes

Hashes for imbi_automations-1.0.0a8-py3-none-any.whl
Algorithm Hash digest
SHA256 a7bbc833ff2299b695b8bc117115ff5b3d6e089cdac60c56925f335f5a24d2f9
MD5 d9eec4384fb13b9b4ebf46983cd3bdf6
BLAKE2b-256 9f9d5dfd8058cbe4f36f04806638f016e72a2e1abfdfb41e4210e99e837c2cfc

See more details on using hashes here.

Provenance

The following attestation bundles were made for imbi_automations-1.0.0a8-py3-none-any.whl:

Publisher: publish.yml on AWeber-Imbi/imbi-automations

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