npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

swapcoffee-ai-sdk-tools

v0.1.0

Published

Vercel AI SDK toolset for swap.coffee APIs and SDK utilities

Readme

@swap-coffee/ai-tools

Production-ready Vercel AI SDK (v6+) tools for swap.coffee.

This package provides:

  • Full tool coverage for swap.coffee backend OpenAPI (https://backend.swap.coffee/openapi)
  • Full tool coverage for tokens OpenAPI (https://tokens.swap.coffee/api/v3/openapi.yaml)
  • Grouped tool access by OpenAPI tags (for controlled agent capabilities)
  • Individual tool access by tool name
  • SDK utility tools on top of @swap-coffee/sdk

Installation

npm install @swap-coffee/ai-tools ai @swap-coffee/sdk zod

Quick Start

import { generateText } from 'ai';
import { openai } from '@ai-sdk/openai';
import { createSwapCoffeeTools } from '@swap-coffee/ai-tools';

const tools = createSwapCoffeeTools({
  client: {
    backend: {
      apiKey: process.env.SWAP_COFFEE_API_KEY,
    },
    tokens: {
      apiKey: process.env.SWAP_COFFEE_API_KEY,
    },
  },
  // Optional filtering:
  // includeServices: ['backend'],
  // includeTags: ['Routing'],
  // includeToolNames: ['backend_buildRoute'],
});

const result = await generateText({
  model: openai(process.env.AI_MODEL!),
  prompt: 'Find available TON staking pools and explain top options.',
  tools,
});

console.log(result.text);

Tool Selection Modes

1) Use tools one-by-one

const tools = createSwapCoffeeTools({
  client,
  includeToolNames: ['backend_buildRoute', 'backend_buildTransactionsV2'],
});

2) Use tool groups by domain

import { createSwapCoffeeToolGroups } from '@swap-coffee/ai-tools';

const groups = createSwapCoffeeToolGroups({ client });

const routingTools = {
  ...(groups['backend:Routing'] ?? {}),
  ...(groups['sdk:utilities'] ?? {}),
};

3) Inspect all available tools

import { getSwapCoffeeToolCatalog } from '@swap-coffee/ai-tools';

const catalog = getSwapCoffeeToolCatalog();
console.log(catalog.length);
console.log(catalog.slice(0, 10));

Included SDK Utility Tools

  • sdk_wait_for_route_results: wraps waitForRouteResults from @swap-coffee/sdk

Examples

See examples/single-tool.ts, examples/grouped-tools.ts, and examples/catalog.ts.

Development

npm run generate
npm run typecheck
npm run build
npm test

Notes