Skip to main content

AceTeam workflow nodes for local execution

Project description

aceteam-nodes

PyPI version License: MIT Python 3.12+

AceTeam workflow nodes for local CLI execution. Run AceTeam workflows on your own machine with any LLM provider.

Install

pip install aceteam-nodes

Quick Start

# Run a workflow
python -m aceteam_nodes.cli run examples/hello-llm.json --input '{"prompt":"Explain AI in one sentence"}'

# List available nodes
python -m aceteam_nodes.cli list-nodes

# Validate a workflow file
python -m aceteam_nodes.cli validate examples/hello-llm.json

Configuration

Create ~/.ace/config.yaml to configure API keys and defaults:

default_model: gpt-4o-mini

Set your API key via environment variable:

export OPENAI_API_KEY=sk-...
# or
export ANTHROPIC_API_KEY=sk-ant-...

How It Works

Workflow JSON ──> AceTeamWorkflow (load + validate)
                       │
                       ▼
              workflow-engine (DAG execution)
                       │
                       ▼
              AceTeamNode.run() per node
                  │         │
                  ▼         ▼
              litellm    httpx/jinja2
            (100+ LLMs)  (API calls)
  1. A workflow JSON file defines nodes and their connections as a directed acyclic graph
  2. AceTeamWorkflow validates the file and resolves node references
  3. The aceteam-workflow-engine executes nodes in topological order
  4. Each node type implements run() — LLM nodes call litellm, API nodes use httpx, etc.
  5. Results flow through the graph until all outputs are produced

Available Nodes

Node Description
LLM AI text generation via litellm (100+ providers)
APICall HTTP requests with Jinja templating
TextInput Static text source
DataTransform Data transformation
CSVReader CSV data source
If / IfElse Conditional branching
ForEach Loop iteration
Equal, NotEqual, GreaterThan, LessThan, And, Or, Not Comparison/logic operators

Development

# Setup
uv sync --extra dev

# Test
uv run pytest

# Lint & format
uv run ruff check && uv run ruff format

# Type check
uv run pyright

# Build
uv build

Related

  • Ace CLI — TypeScript CLI that wraps this package for a streamlined user experience
  • Workflow Engine — The DAG execution engine used under the hood

License

MIT

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

aceteam_nodes-0.2.0.tar.gz (127.5 kB view details)

Uploaded Source

Built Distribution

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

aceteam_nodes-0.2.0-py3-none-any.whl (20.9 kB view details)

Uploaded Python 3

File details

Details for the file aceteam_nodes-0.2.0.tar.gz.

File metadata

  • Download URL: aceteam_nodes-0.2.0.tar.gz
  • Upload date:
  • Size: 127.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for aceteam_nodes-0.2.0.tar.gz
Algorithm Hash digest
SHA256 39408001764bc0948ad793b5740e76052cbf96f0262d7c1bb1e3bb9d1ce59eeb
MD5 c868ec82b4c7b5506b6736281f6a2e28
BLAKE2b-256 44b76a1d8736d7d96f3d1092fb66921fdea42950187af2372b22ca0116b7d0f4

See more details on using hashes here.

File details

Details for the file aceteam_nodes-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: aceteam_nodes-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 20.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for aceteam_nodes-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1d7475d95f4374ac028ad0a639fd890b1da178e1c7216fc2c5138b9d4ea126ef
MD5 ccf48be30fe652cca39f0d074e190d76
BLAKE2b-256 3f396178a7100cb2888bfe0924b31f57fc92bb1c39fb66a0e9937b93fb723993

See more details on using hashes here.

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