Back to Goose

@aaif/goose-sdk

ui/sdk/README.md

1.33.12.8 KB
Original Source

@aaif/goose-sdk

TypeScript client library for the Goose Agent Client Protocol (ACP).

This package provides:

  • TypeScript types and Zod validators for Goose ACP extension methods
  • A client for communicating with the Goose ACP server

Installation

bash
npm install @aaif/goose-sdk

The native goose binaries are distributed as optional dependencies and will be automatically installed for your platform.

Development

Prerequisites

  • Node.js 18+
  • Rust toolchain
  • (Optional) Cross-compilation toolchains for building all platforms

Building

bash
# Build everything (schema + TypeScript)
npm run build

# Build just the schema (requires Rust)
npm run build:schema

# Build just the TypeScript
npm run build:ts

# Build native binary for current platform
npm run build:native

# Build native binaries for all platforms
npm run build:native:all

To use this package locally in another project (e.g., @aaif/goose):

bash
# In ui/sdk
npm run build
npm link

# In ui/text (or another project)
npm link @aaif/goose-sdk

Schema Generation

The TypeScript types are generated from Rust schemas defined in crates/goose. The build process:

  1. Builds the generate-acp-schema Rust binary
  2. Runs it to generate acp-schema.json and acp-meta.json
  3. Uses @hey-api/openapi-ts to generate TypeScript types and Zod validators
  4. Generates a typed client in src/generated/client.gen.ts

To regenerate schemas after changing Rust types:

bash
npm run build:schema

Native Binary Packages

Platform-specific npm packages for the goose binary are located in ui/goose-binary/:

PackagePlatform
@aaif/goose-binary-darwin-arm64macOS Apple Silicon
@aaif/goose-binary-darwin-x64macOS Intel
@aaif/goose-binary-linux-arm64Linux ARM64
@aaif/goose-binary-linux-x64Linux x64
@aaif/goose-binary-win32-x64Windows x64

These are published separately from @aaif/goose-sdk.

Building Native Binaries

bash
# Build for current platform
npm run build:native

# Build for all platforms (requires cross-compilation toolchains)
npm run build:native:all

# Build for specific platform(s)
npx tsx scripts/build-native.ts darwin-arm64 linux-x64

Publishing

Publishing is handled by GitHub Actions. See .github/workflows/publish-npm.yml.

For manual publishing:

bash
# From repository root
./ui/scripts/publish.sh --real

This will:

  1. Build and publish @aaif/goose-sdk
  2. Publish all native binary packages
  3. Publish @aaif/goose (which depends on the above)

Usage

typescript
import { GooseClient } from "@aaif/goose-sdk";

const client = new GooseClient({
  // ... configuration
});

// Use the client
const result = await client.someMethod({ ... });

See the main documentation for more details.