Big News: Socket raises $60M Series C at a $1B valuation to secure software supply chains for AI-driven development.Announcement
Sign In

@copass/ai-sdk

Package Overview
Dependencies
Maintainers
1
Versions
28
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@copass/ai-sdk

Vercel AI SDK tool adapters for Copass — drop-in discover/interpret/search tools for LLM agents

latest
Source
npmnpm
Version
0.5.10
Version published
Maintainers
1
Created
Source

@copass/ai-sdk

Copass retrieval as Vercel AI SDK tools. The LLM picks discover (menu of relevant items), search (synthesized answer), or get_origin (map canonical_ids to source files) — you don't write the tool-calling loop. interpret is exposed for back-compat but legacy; prefer search for drill-in.

Prerequisites

Install the Copass CLI and bootstrap your account:

npm install -g @copass/cli
copass login                             # email OTP
copass setup                             # creates a sandbox, writes .olane/refs.json
copass apikey create --name my-app       # prints an olk_... key — shown once, save it
OutputUse as
olk_... key printed by copass apikey createCOPASS_API_KEY
sandbox_id in ./.olane/refs.jsonCOPASS_SANDBOX_ID
project_id in ./.olane/refs.json (optional)COPASS_PROJECT_ID

Ingest some content so retrieval has something to return:

copass ingest path/to/file.md
# or pipe stdin:  echo "some decision or note" | copass ingest -

Install

npm install @copass/ai-sdk @copass/core ai @ai-sdk/anthropic zod

Quickstart

The Copass-specific code is four lines. Everything else is vanilla Vercel AI SDK you'd write even without Copass.

import { CopassClient } from '@copass/core';
import { copassTools } from '@copass/ai-sdk';
import { generateText } from 'ai';
import { anthropic } from '@ai-sdk/anthropic';

// ── Copass (the entire integration) ──
const copass = new CopassClient({
  auth: { type: 'api-key', key: process.env.COPASS_API_KEY! },
});
const window = await copass.contextWindow.create({
  sandbox_id: process.env.COPASS_SANDBOX_ID!,
});

// ── Standard Vercel AI SDK call — only `tools:` is new ──
const { text } = await generateText({
  model: anthropic('claude-opus-4-7'),
  tools: copassTools({ client: copass, sandbox_id: window.sandboxId, window }),
  maxSteps: 5,
  prompt: 'what do we know about checkout retry behavior?',
});

console.log(text);

What Copass is actually doing:

  • new CopassClient({ auth }) — authenticated REST client.
  • contextWindow.create(...) — opens an ephemeral data source for this conversation.
  • copassTools({ ... }) — returns discover / interpret / search / get_origin tools Claude can invoke autonomously. The window argument makes each window-aware retrieval call window-aware at the server level (get_origin is a cheap windowless lookup).

Everything else — generateText, model:, maxSteps:, prompt: — is vanilla Vercel AI SDK.

Multi-turn: createWindowTracker

The quickstart above runs one turn. For a multi-turn conversation where turn 2 retrieval should know what turn 1 surfaced, wrap with createWindowTracker:

import { copassTools, createWindowTracker } from '@copass/ai-sdk';

const tracker = createWindowTracker({ window });

// Per turn:
const userMessage = '...';
await tracker.recordUserTurn(userMessage);

const { text } = await generateText({
  model,
  tools: copassTools({ client: copass, sandbox_id: window.sandboxId, window }),
  onStepFinish: tracker.onStepFinish,   // auto-mirror assistant + tool messages
  prompt: userMessage,
});

Three additions:

  • const tracker = createWindowTracker({ window }) at setup.
  • tracker.recordUserTurn(msg) before each generateText — the user's message isn't in onStepFinish (it's the input), so capture it explicitly. Idempotent; safe to call redundantly.
  • onStepFinish: tracker.onStepFinish on the generateText call — Vercel AI SDK's standard step-finish hook; the tracker mirrors each step's response.messages into the window, deduplicated.

Tool messages (role: 'tool') are skipped by default since they're usually retrieval noise. Opt in with createWindowTracker({ window, includeToolMessages: true }) if you want them tracked.

Why this, not the raw API

  • LLM chooses the retrieval shape. Claude picks discover for a menu of relevant items, search for a synthesized answer, or get_origin to map canonical_ids to the source files those entities were extracted from. interpret is also wired up for back-compat (legacy — prefer search).
  • Window-aware retrieval. Each retrieval call carries the window argument so the server knows which items have already been surfaced in this conversation. Add createWindowTracker (above) to get automatic cross-turn awareness.
  • Trimmed response shapes. Tools return only what the model needs ({header, items, next_steps} / {brief} / {answer}) — no sandbox/project echoes that waste tokens.

Tools

ToolWhen the LLM calls it
discover"What's relevant?" — ranked menu of pointers
search"Tell me about X" / "Answer this." — synthesized answer (canonical drill-in)
get_origin"Where does this live?" — maps canonical_ids from discover to source files. Cheap, no LLM. Pair with the agent's native read tool.
interpretLegacy — brief pinned to canonical_ids. Prefer search for drill-in.

Conversation metadata

When you mirror turns into a ContextWindow, set the conversation roster once at construction so it rides on every turn:

const window = await client.contextWindow.create({
  sandbox_id,
  participants: ['User', 'agent:support-bot'],
});

await window.addTurn({
  role: 'user',
  content: 'Hey, did you finish the report?',
  name: 'Alice',  // → envelope `speaker`
});

See @copass/core for the full envelope surface (speaker, participants, occurred_at, free-form source_type).

License

MIT

Keywords

copass

FAQs

Package last updated on 30 May 2026

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts