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

@objectstack/ai-bridge

v0.9.0

Published

**AI Context Bridge** for ObjectStack. This library provides a set of tools to bridge the gap between your metadata definitions (`Spec`) and Generative AI agents.

Readme

@objectstack/ai-bridge

AI Context Bridge for ObjectStack. This library provides a set of tools to bridge the gap between your metadata definitions (Spec) and Generative AI agents.

It translates your static schema definitions into formats that LLMs (Large Language Models) can understand, strictly adhere to, and execute against.

🌟 Capabilities

  1. Static Type Generator (Code Scaffolding)

    • Converts Object/Field definitions into strong TypeScript Interfaces (.d.ts).
    • Generates ObjectQL Query types ($select, $filter) with literal types for fields.
    • Use Case: Fed into "Coding Agents" to ensure they generate valid, compiling code.
  2. Runtime Introspection Manifest (System Prompts)

    • Generates a token-optimized, compressed JSON representation of your system.
    • Strip UI/Config noise, keeping only Business Logic (Objects, Fields, Capabilities).
    • Context-aware: Filters capabilities based on the current user's permissions.
    • Use Case: Injected into the System Prompt so the AI knows "Permission to Speak".
  3. Tool Definitions (Function Calling)

    • Outputs standard OpenAI tools (JSON Schema) for core ObjectQL operations (search, create, update).
    • Use Case: Enables "Agentic" behavior where the AI directly queries your database.

📦 Installation

pnpm add @objectstack/ai-bridge

🛠️ Usage

1. Generating TypeScript Definitions

Generate .d.ts content to paste into an LLM context or save to a file for dynamic execution.

import { generateTypeScriptDefinition } from '@objectstack/ai-bridge';

const objects = [
  {
    name: 'project',
    fields: {
       name: { type: 'text', required: true },
       status: { type: 'select', options: ['planning', 'active'] }
    }
  }
];

const tsContent = generateTypeScriptDefinition(objects);
console.log(tsContent);
// Output: 
// export interface Project { name: string; status?: 'planning' | 'active'; ... }

2. Runtime Context (Token Efficient)

Create a lightweight manifest for the AI's "Short-term Memory".

import { generateAIManifest } from '@objectstack/ai-bridge';

const manifest = generateAIManifest(objects, {
  // Optional: Filter capabilities based on real permissions
  userPermissions: {
    'project': ['read', 'create'] // User cannot delete
  }
});

// Inject this into your System Prompt
const systemPrompt = `
You are an assistant. Here is the database schema you have access to:
${JSON.stringify(manifest)}
`;

3. OpenAI Tools

Get standard Function Calling definitions to pass to the OpenAI API.

import { generateOpenAITools } from '@objectstack/ai-bridge';
import OpenAI from 'openai';

const tools = generateOpenAITools();

const response = await openai.chat.completions.create({
  model: 'gpt-4-turbo',
  messages: [...],
  tools: tools, // <-- Direct integration
  tool_choice: 'auto'
});

🏗️ Architecture

This package is designed to be isomorphic and dependency-light. It does not depend on the heavy runtime or core packages of ObjectStack, meaning it can be run in Edge functions, Lambda, or client-side environments to help construct prompts.