From east
East Execution Engine (e3) - durable dataflow execution for East programs. Use when: (1) Authoring e3 packages with @elaraai/e3 (e3.input, e3.task, e3.package, e3.export), (2) Running e3 CLI commands (e3 repo create, e3 start, e3 watch, e3 get, e3 set), (3) Working with workspaces and packages, (4) Content-addressable caching and dataflow execution.
How this skill is triggered — by the user, by Claude, or both
Slash command
/east:e3The summary Claude sees in its skill listing — used to decide when to auto-load this skill
e3 is a durable dataflow execution engine for East programs with content-addressable caching.
e3 is a durable dataflow execution engine for East programs with content-addressable caching.
// src/index.ts
import { East, StringType } from '@elaraai/east';
import e3 from '@elaraai/e3';
// Define an input
const name = e3.input('name', StringType, 'World');
// Define a task
const greet = e3.task(
'greet',
[name],
East.function([StringType], StringType, ($, n) =>
East.str`Hello, ${n}!`
)
);
// Bundle and export
const pkg = e3.package('hello', '1.0.0', greet);
await e3.export(pkg, '/tmp/hello.zip');
export default pkg;
# Create repository
e3 repo create .
# Import and deploy
e3 package import . /tmp/hello.zip
e3 workspace create . dev
e3 workspace deploy . dev [email protected]
# Execute dataflow
e3 start . dev
# Get result
e3 get . dev.tasks.greet.output
Define an input dataset at .inputs.${name}.
const name = e3.input('name', StringType, 'default');
const count = e3.input('count', IntegerType);
Define a task that runs an East function.
const greet = e3.task(
'greet',
[name], // dependencies (inputs or other task outputs)
East.function([StringType], StringType, ($, n) =>
East.str`Hello, ${n}!`
)
);
// With custom runner
const pyTask = e3.task(
'py_task',
[input],
East.function([IntegerType], IntegerType, ($, x) => x.multiply(2n)),
{ runner: ['uv', 'run', 'east-py', 'run', '-p', 'east-py-std'] }
);
// Chain tasks via .output
const shout = e3.task(
'shout',
[greet.output],
East.function([StringType], StringType, ($, s) => s.toUpperCase())
);
Define a task that runs a shell command.
const process = e3.customTask(
'process',
[rawData],
StringType,
($, input_paths, output_path) =>
East.str`python script.py -i ${input_paths.get(0n)} -o ${output_path}`
);
Bundle into a package. Dependencies are collected automatically.
const pkg = e3.package('myapp', '1.0.0', finalTask);
Export package to a .zip file.
await e3.export(pkg, '/tmp/myapp.zip');
e3 repo create <repo> # Create a new repository
e3 repo status <repo> # Show repository status
e3 repo remove <repo> # Remove a repository
e3 repo gc <repo> [--dry-run] # Garbage collect unreferenced objects
e3 package import <repo> <zipPath> # Import from .zip
e3 package export <repo> <pkg> <zipPath> # Export to .zip
e3 package list <repo> # List packages
e3 package remove <repo> <pkg> # Remove package
e3 workspace create <repo> <name> # Create workspace
e3 workspace deploy <repo> <ws> <pkg[@ver]> # Deploy package
e3 workspace export <repo> <ws> <zipPath> # Export workspace
e3 workspace import <repo> <ws> <zipPath> # Import package zip into workspace
e3 workspace list <repo> # List workspaces
e3 workspace status <repo> <ws> # Show workspace status
e3 workspace remove <repo> <ws> # Remove workspace
e3 list <repo> [path] # List tree contents
e3 list <repo> <path> -r # List all dataset paths recursively
e3 list <repo> <path> -l # Immediate children with type/status/size
e3 list <repo> <path> -r -l # All datasets with type/status/size
e3 get <repo> <path> [-f east|json|beast2] # Get dataset value
e3 set <repo> <path> <file> [--type <spec>] # Set dataset from file
Path format: workspace.path.to.dataset
e3 get . dev.inputs.name
e3 get . dev.tasks.greet.output
e3 set . dev.inputs.name data.east
e3 start <repo> <ws> [--filter] [--concurrency <n>] [--force]
e3 run <repo> <pkg/task> [inputs...] -o <output>
e3 watch <repo> <ws> <source.ts> [--start] [--abort-on-change]
e3 logs <repo> <path> [--follow]
e3 convert [input] [--from <fmt>] [--to <fmt>] [-o <output>]
e3 login <server> # Log in using OAuth2 Device Flow
e3 logout <server> # Log out and clear credentials
e3 auth status # List all saved credentials
e3 auth token <server> # Print access token (for curl/debugging)
e3 auth whoami [server] # Show current identity
All commands accept HTTP URLs instead of local paths:
# Start a server
e3-api-server --repos ./repos --port 3000
# Use remote repository
e3 repo create http://localhost:3000/repos/my-repo
e3 workspace list http://localhost:3000/repos/my-repo
e3 package import http://localhost:3000/repos/my-repo ./pkg.zip
e3 watch . dev ./src/index.ts --start
Auto-compiles, deploys, and runs on file changes.
npm run build && npm run main
e3 package import . /tmp/pkg.zip
e3 workspace deploy . dev [email protected]
e3 start . dev
| Package | Description |
|---|---|
@elaraai/e3 | SDK: e3.input, e3.task, e3.package, e3.export |
@elaraai/e3-types | Shared type definitions |
@elaraai/e3-core | Core library (workspaces, execution, caching) |
@elaraai/e3-cli | CLI tool |
@elaraai/e3-api-client | HTTP client for remote servers |
@elaraai/e3-api-server | REST API server |
my-project/
├── package.json
├── tsconfig.json
├── pyproject.toml # For Python runner
├── src/
│ └── index.ts # Package definition
└── repo/ # Repository (created by e3 repo create)
├── objects/ # Content-addressable object store
├── packages/ # Package metadata
└── workspaces/ # Workspace state
Tasks are cached by content hash. Re-runs only when:
Use --force to bypass: e3 start . dev --force
npx claudepluginhub elaraai/east-plugin --plugin eastBuild agentic workflow pipelines in Python using Graflow, combining deterministic flow control with AI reasoning via Studio Agent and MCP tools.
Provides expert guidance for Vercel Workflow DevKit when building durable workflows, long-running tasks, API routes, or agents needing pause/resume, retries, step execution, or crash-safe orchestration.
Implements durable multi-step workflows on Cloudflare Workers with retries, state persistence, sleeps, event waiting, and NonRetryableError handling. Use for long-running tasks.