From outputai
Provides comprehensive project context for the Output.ai framework: durable LLM workflows, Temporal orchestration, project structure, and available agents/commands.
How this skill is triggered — by the user, by Claude, or both
Slash command
/outputai:output-meta-project-contextThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
Output.ai provides infrastructure for building production-grade AI workflows: fact checkers, content generators, data extractors, research assistants, and multi-step agents. Built on Temporal, it guarantees **durable execution** - if execution fails mid-run, it resumes from the last successful step.
Output.ai provides infrastructure for building production-grade AI workflows: fact checkers, content generators, data extractors, research assistants, and multi-step agents. Built on Temporal, it guarantees durable execution - if execution fails mid-run, it resumes from the last successful step.
Separation of orchestration from I/O:
This separation enables automatic retries, resumption, and debugging.
| Component | Purpose | Key Rule |
|---|---|---|
| Workflow | Orchestrates step execution | Must be deterministic (no I/O, no Date.now(), no Math.random()) |
| Step | Handles all I/O operations | Where HTTP, LLM, DB calls happen |
| Evaluator | Quality assessment | Returns confidence-scored results for validation loops |
| Scenario | Test input data | JSON files matching workflow's inputSchema |
| Prompt | LLM templates | Liquid.js templating with YAML frontmatter config |
| Eval Test | Offline quality testing | Dataset-driven verification with verify() from @outputai/evals |
config/
├── credentials.yml.enc # Global encrypted credentials
├── credentials.key # Global decryption key (DO NOT COMMIT)
└── credentials/ # Environment-specific credentials
├── production.yml.enc
└── production.key
src/
├── shared/ # Shared code across workflows
│ ├── clients/ # API clients (e.g., jina.ts, stripe.ts)
│ └── utils/ # Utility functions (e.g., string.ts)
└── workflows/ # Workflow definitions
└── {workflow_name}/
├── workflow.ts # Orchestration logic (deterministic)
├── steps.ts # I/O operations
├── types.ts # Zod schemas (input, output, internal)
├── evaluators.ts # Quality checks (optional)
├── utils.ts # Local utilities (optional)
├── credentials.yml.enc # Workflow-specific credentials (optional)
├── prompts/ # LLM templates (optional)
│ └── [email protected]
├── scenarios/ # Test inputs (optional)
│ └── happy_path.json
└── tests/ # Offline eval tests (optional)
├── datasets/ # YAML test datasets
│ └── happy_path.yml
└── evals/ # Eval evaluators and workflow
├── evaluators.ts
└── workflow.ts
Shared directory (src/shared/):
shared/clients/ - API clients using @outputai/http for external servicesshared/utils/ - Helper functions and utilitiesAllowed imports:
../../shared/clients/*.js and ../../shared/utils/*.js./types.js, ./utils.js)Forbidden:
../other_workflow/steps.js)| Rule | Correct | Incorrect |
|---|---|---|
| Zod import | import { z } from '@outputai/core' | import { z } from 'zod' |
| HTTP client | import { httpClient } from '@outputai/http' | import axios from 'axios' |
| Credentials | import { credentials } from '@outputai/credentials' | process.env.SECRET |
| LLM calls | import { generateText, Output } from '@outputai/llm' | Direct provider SDK |
| ES imports | import { fn } from './file.js' | import { fn } from './file' |
| Workflow I/O | Call steps for any I/O | Direct fetch/http in workflow |
Determinism violations (never in workflows):
Date.now(), new Date()Math.random(), crypto.randomUUID()| Agent | Purpose |
|---|---|
workflow-planner | Designs workflow architecture, creates implementation blueprints |
workflow-debugger | Analyzes workflow execution traces, identifies issues |
workflow-quality | Reviews code quality, validates implementations |
workflow-prompt-writer | Creates and optimizes LLM prompt templates |
workflow-context-fetcher | Gathers documentation and existing patterns |
| Command | Purpose | When to Use |
|---|---|---|
/output-plan-workflow | Plan workflow architecture | ALWAYS FIRST - creates implementation blueprint |
/output-build-workflow | Build/implement workflows | After planning, or for modifications |
/output-debug-workflow | Debug workflow issues | When workflows fail or behave unexpectedly |
| Skill | Purpose |
|---|---|
output-workflow-run | Synchronous workflow execution (waits for result) |
output-workflow-start | Asynchronous workflow execution (returns ID) |
output-workflow-list | List available workflows |
output-workflow-status | Check async workflow status |
output-workflow-result | Get async workflow result |
output-workflow-reset | Rerun a workflow from after a completed step |
| Skill | Purpose |
|---|---|
output-workflow-stop | Stop running workflow |
output-workflow-trace | Trace workflow execution |
output-workflow-runs-list | List workflow run history |
output-dev-workflow-cost | Calculate cost of a workflow run |
output-services-check | Verify Output services status |
| Skill | Catches |
|---|---|
output-error-zod-import | Wrong zod import source |
output-error-nondeterminism | Date.now, Math.random in workflows |
output-error-try-catch | Missing error handling in steps |
output-error-missing-schemas | Incomplete Zod schema exports |
output-error-direct-io | I/O operations in workflow files |
output-error-http-client | Using axios instead of @outputai/http |
| Skill | Purpose |
|---|---|
output-meta-pre-flight | Pre-operation validation checks |
output-meta-post-flight | Post-operation verification |
output-meta-project-context | Load full project context (this skill) |
| Skill | Purpose |
|---|---|
output-dev-folder-structure | Project and workflow directory layout |
output-dev-workflow-function | Writing deterministic workflow files |
output-dev-step-function | Writing step functions for I/O |
output-dev-types-file | Zod schema definitions |
output-dev-evaluator-function | Quality assessment functions |
output-dev-eval-testing | Offline eval tests with @outputai/evals |
output-dev-prompt-file | LLM prompt templates with Liquid.js |
output-dev-model-selection | Pick a current LLM model via the AI Gateway listing |
output-dev-upgrade-prompt-models | Bulk-upgrade model: fields across .prompt files |
output-dev-scenario-file | Test input JSON files |
output-dev-http-client-create | Shared HTTP API client patterns |
output-dev-create-skeleton | Generate workflow skeleton |
| Skill | Purpose |
|---|---|
output-dev-credentials | Full credentials system reference (API, scopes, merging, custom providers) |
output-credentials-init | Initialize encrypted credentials files for the first time |
output-credentials-edit | View and edit credential values with show/get/edit commands |
output-credentials-env-vars | Wire credentials to env vars using the credential: convention |
# Development
npx output dev # Start dev environment
# List & inspect
npx output workflow list # List available workflows
# Execute
npx output workflow run <name> --input '{}' # Run synchronously (waits)
npx output workflow start <name> --input '{}' # Run async (returns ID)
npx output workflow status <id> # Check async status
npx output workflow result <id> # Get async result
# Debug
npx output workflow debug <id> # Debug failed workflow
npx output workflow debug <id> --json # Machine-readable output
# Rerun from a step (replays up to <stepName>, re-executes everything after)
npx output workflow reset <id> --step <stepName>
npx output workflow reset <id> --step <stepName> --reason "why"
# Eval Testing
npx output workflow test <name> # Run eval tests against datasets
npx output workflow test <name> --cached # Use cached output (fast)
npx output workflow test <name> --save # Run fresh and save results
npx output workflow dataset list <name> # List datasets for a workflow
npx output workflow dataset generate <name> --input '{}' # Generate dataset
# Credentials
npx output credentials init # Initialize encrypted credentials
npx output credentials edit # Edit credentials (decrypts, opens $EDITOR)
npx output credentials show # Show decrypted credentials
npx output credentials get <path> # Get single credential value
| Element | Convention | Example |
|---|---|---|
| Workflow folder | snake_case | fact_checker/ |
| Workflow name | snake_case | name: 'fact_checker' |
| Step functions | camelCase | fetchArticle(), analyzeContent() |
| Schema names | PascalCase | InputSchema, ArticleData |
| Prompt files | [email protected] | [email protected] |
| Scenario files | snake_case.json | happy_path.json |
import { workflow, z } from '@outputai/core';
import { fetchData, processData } from './steps.js';
export const inputSchema = z.object( { url: z.string().url() } );
export const outputSchema = z.object( { result: z.string() } );
export default workflow( {
name: 'my_workflow',
description: 'Processes data from URL',
inputSchema,
outputSchema,
fn: async input => {
const data = await fetchData( input.url );
const result = await processData( data );
return { result };
}
} );
See output-dev-workflow-function for comprehensive patterns.
import { step, z } from '@outputai/core';
import { httpClient } from '@outputai/http';
export const fetchData = step(
{ name: 'fetchData', inputSchema: z.string(), outputSchema: z.any() },
async url => {
const client = httpClient( { prefixUrl: url } );
const response = await client.get( '' );
return response.json();
}
);
See output-dev-step-function for comprehensive patterns.
Clients live in src/shared/clients/ and are shared across all workflows.
// src/shared/clients/example.ts
import { FatalError, ValidationError } from '@outputai/core';
import { httpClient } from '@outputai/http';
import { credentials } from '@outputai/credentials';
const API_KEY = credentials.require( 'example.api_key' );
const client = httpClient( {
prefixUrl: 'https://api.example.com',
headers: { Authorization: `Bearer ${API_KEY}` },
timeout: 30000,
retry: { limit: 3, statusCodes: [ 408, 429, 500, 502, 503, 504 ] }
} );
export async function fetchFromExample( query: string ): Promise<ExampleResponse> {
try {
const response = await client.get( 'endpoint', { searchParams: { q: query } } );
return response.json();
} catch ( error: unknown ) {
const err = error as { status?: number; message?: string };
if ( err.status === 401 || err.status === 403 ) {
throw new FatalError( `Auth failed: ${err.message}` );
}
throw new ValidationError( `Request failed: ${err.message}` );
}
}
Error type guidelines:
FatalError: 401, 403, 404 (won't succeed on retry)ValidationError: 429, 5xx (may succeed on retry)See output-dev-http-client-create for comprehensive patterns.
Evaluators return confidence-scored results. Three result types available:
import { evaluator, z, EvaluationBooleanResult, EvaluationNumberResult, EvaluationStringResult } from '@outputai/core';
// Boolean evaluator - pass/fail checks
export const evaluateCompleteness = evaluator( {
name: 'evaluate_completeness',
description: 'Check if content meets minimum length',
inputSchema: z.object( { content: z.string(), minLength: z.number() } ),
fn: async ( { content, minLength } ) => {
return new EvaluationBooleanResult( {
value: content.length >= minLength,
confidence: 1.0,
reasoning: `Content has ${content.length} chars (min: ${minLength})`
} );
}
} );
See output-dev-evaluator-function for comprehensive patterns.
Prompts use YAML frontmatter + Liquid.js templating. Location: src/workflows/{name}/prompts/
---
provider: anthropic
# current as of 2026-05-04 — run output-dev-model-selection for the latest
model: claude-sonnet-4-6
temperature: 0.7
maxTokens: 4096
---
<system>
You are an expert content analyzer.
{% if context %}
Additional context: {{ context }}
{% endif %}
</system>
<user>
Analyze the following content:
<content>
{{ content }}
</content>
Provide {{ numberOfPoints | default: 3 }} key insights.
</user>
Using in steps:
import { generateText, Output } from '@outputai/llm';
import { z } from '@outputai/core';
// Structured output
const { output } = await generateText( {
prompt: 'analyze@v1',
variables: { content: 'Article text...', numberOfPoints: 5 },
output: Output.object( {
schema: z.object( { insights: z.array( z.string() ) } )
} )
} );
// Text output
const { result } = await generateText( {
prompt: 'summarize@v1',
variables: { content: 'Article text...' }
} );
Provider & model selection: the SDK supports anthropic, openai, vertex, bedrock, azure, and perplexity (see sdk/llm/src/ai_model.js for the registered list). Don't pin specific model IDs in docs — they drift. To pick a current model, run output-dev-model-selection, which queries the AI Gateway model index live.
See output-dev-prompt-file for comprehensive patterns.
docker restart <project>-worker-1docker logs -f output-worker-1output-services-check skillnpx output workflow debug <id> --jsonnpx claudepluginhub growthxai/output --plugin outputaiOutlines standard folder structure conventions for Output SDK workflows. Use when creating new workflows, reorganizing files, understanding file placement, or reviewing compliance.
Creates multi-agent orchestration workflows from natural language using Socratic questioning, pattern detection for sequential/parallel/conditional flows, temp script creation, and syntax generation with visualization.
Creates bite-sized, testable implementation plans from specs or requirements, with file structure and task decomposition. Activates before coding multi-step tasks.