# SDK Examples Programmatic usage of pi-coding-agent via `createAgentSession()`. ## Examples | File | Description | |------|-------------| | `01-minimal.ts` | Simplest usage with all defaults | | `02-custom-model.ts` | Select model and thinking level | | `03-custom-prompt.ts` | Replace or modify system prompt | | `04-skills.ts` | Discover, filter, or replace skills | | `05-tools.ts` | Built-in tools, custom tools | | `06-extensions.ts` | Logging, blocking, result modification | | `07-context-files.ts` | AGENTS.md context files | | `08-slash-commands.ts` | File-based slash commands | | `09-api-keys-and-oauth.ts` | API key resolution, OAuth config | | `10-settings.ts` | Override compaction, retry, terminal settings | | `11-sessions.ts` | In-memory, persistent, continue, list sessions | | `12-full-control.ts` | Replace everything, no discovery | ## Running ```bash cd packages/coding-agent npx tsx examples/sdk/01-minimal.ts ``` ## Quick Reference ```typescript import { getModel } from "@mariozechner/pi-ai"; import { AuthStorage, createAgentSession, DefaultResourceLoader, ModelRegistry, SessionManager, SettingsManager, codingTools, readOnlyTools, readTool, bashTool, editTool, writeTool, } from "@mariozechner/pi-coding-agent"; // Auth and models setup const authStorage = AuthStorage.create(); const modelRegistry = new ModelRegistry(authStorage); // Minimal const { session } = await createAgentSession({ authStorage, modelRegistry }); // Custom model const model = getModel("anthropic", "claude-opus-4-5"); const { session } = await createAgentSession({ model, thinkingLevel: "high", authStorage, modelRegistry }); // Modify prompt const loader = new DefaultResourceLoader({ systemPromptOverride: (base) => `${base}\n\nBe concise.`, }); await loader.reload(); const { session } = await createAgentSession({ resourceLoader: loader, authStorage, modelRegistry }); // Read-only const { session } = await createAgentSession({ tools: readOnlyTools, authStorage, modelRegistry }); // In-memory const { session } = await createAgentSession({ sessionManager: SessionManager.inMemory(), authStorage, modelRegistry, }); // Full control const customAuth = AuthStorage.create("/my/app/auth.json"); customAuth.setRuntimeApiKey("anthropic", process.env.MY_KEY!); const customRegistry = new ModelRegistry(customAuth); const resourceLoader = new DefaultResourceLoader({ systemPromptOverride: () => "You are helpful.", extensionFactories: [myExtension], skillsOverride: () => ({ skills: [], diagnostics: [] }), agentsFilesOverride: () => ({ agentsFiles: [] }), promptsOverride: () => ({ prompts: [], diagnostics: [] }), }); await resourceLoader.reload(); const { session } = await createAgentSession({ model, authStorage: customAuth, modelRegistry: customRegistry, resourceLoader, tools: [readTool, bashTool], customTools: [{ tool: myTool }], sessionManager: SessionManager.inMemory(), settingsManager: SettingsManager.inMemory(), }); // Run prompts session.subscribe((event) => { if (event.type === "message_update" && event.assistantMessageEvent.type === "text_delta") { process.stdout.write(event.assistantMessageEvent.delta); } }); await session.prompt("Hello"); ``` ## Options | Option | Default | Description | |--------|---------|-------------| | `authStorage` | `AuthStorage.create()` | Credential storage | | `modelRegistry` | `new ModelRegistry(authStorage)` | Model registry | | `cwd` | `process.cwd()` | Working directory | | `agentDir` | `~/.pi/agent` | Config directory | | `model` | From settings/first available | Model to use | | `thinkingLevel` | From settings/"off" | off, low, medium, high | | `tools` | `codingTools` | Built-in tools | | `customTools` | `[]` | Additional tool definitions | | `resourceLoader` | DefaultResourceLoader | Resource loader for extensions, skills, prompts, themes | | `sessionManager` | `SessionManager.create(cwd)` | Persistence | | `settingsManager` | `SettingsManager.create(cwd, agentDir)` | Settings overrides | ## Events ```typescript session.subscribe((event) => { switch (event.type) { case "message_update": if (event.assistantMessageEvent.type === "text_delta") { process.stdout.write(event.assistantMessageEvent.delta); } break; case "tool_execution_start": console.log(`Tool: ${event.toolName}`); break; case "tool_execution_end": console.log(`Result: ${event.result}`); break; case "agent_end": console.log("Done"); break; } }); ```