Changelog
All notable changes to @jamaalbuilds/ai-toolkit
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
[0.3.2] - 2026-03-28
Changed
- Refactored 10 functions across 9 files — all public functions now under 50 lines
- Added expect.assertions to rate limit test (stream-fallback)
[0.3.1] - 2026-03-28
Fixed
- README: 9 additional code example fixes (agents
await, workflowawait, config return type, auth params, storage/api options, data/health shapes) - LLMS.md: 6 wrong signatures (
getUserId,requireApiKey, cache methods,initToolkit,parseConfig,createCache) - CHANGELOG: removed overclaimed fix, corrected JSDoc count
- CONTRIBUTING.md: added
yarn verifycommand - 11 silent-pass try/catch tests now use
expect.assertions()(ai, knowledge, workflow) - 3 weak
toBeDefined()assertions replaced with behavioral checks (agents, config, stream-fallback) - JSDoc
@exampleadded to 10+ exports missing documentation (ai, config, auth, cache, data, database, health, mcp, storage, testing) - Input validation added to
createLLM,getProviderConfig, auth middleware, cache client,createHealthCheck - Error messages improved across api, storage, security modules
- MCP server builder: comprehensive JSDoc and validation on
defineTool,defineResource,readResource
Added
- 14 new tests: ai rate-limit (3), stream abort signal, mcp error paths (2), mcp content variants (3), config schema validation (4), mcp tool handler error
- knowledge
createKnowledgefactory with input validation builtInSplitinternal utility JSDoc
[0.3.0] - 2026-03-28
Fixed
- README: 4 code examples that wouldn't compile (chain
await, knowledge params, testing mock API, monitor trace) - README: MCP section used nonexistent standalone
defineTool/defineResourceimports - README: Security section had wrong method signatures (
createGuardrailsparams, sync.check(),createRateLimiterargs) - LLMS.md: 7 wrong function signatures (MCP, Security, Knowledge)
- CLAUDE.md: module table missing
data/observability, listed nonexistentrealtimewithout annotation - Root barrel missing v5 mock exports (
mockAI,mockChain,mockAgents,mockKnowledge,mockMonitor,mockWorkflow) - Root barrel missing monitor exports (
exportMetrics,getTraces,getTrace,onTrace) and types - 12 silent-pass database tests now use
expect.assertions()
Added
- api module: 23 tests (was zero coverage) — HTTP methods, retry, error wrapping, rate limit detection
- health module: 3 new edge case tests
- workflow/serve: happy-path test
@exampleJSDoc on 10 previously undocumented exports- README: 25+ previously undocumented exports now documented (monitor, security, database, auth, chain, workflow)
[0.2.0] - 2026-03-28
Added
- monitor:
getTraces(),getTrace(),onTrace(),exportMetrics()— self-contained observability without Langfuse - In-memory trace store with configurable max (default 1000, FIFO eviction)
- 7 cross-module integration tests (AI+Security, Knowledge+DB, RAG, Workflow, Agents, Monitor, MCP)
- 34 security penetration tests (PII bypass, SQL injection, guardrail bypass, rate limiter abuse)
- JSDoc
@exampleon all 92+ exported types across 9 modules - SELF_HOSTED.md — Ollama, Langfuse, Postgres, Redis self-hosted deployment guide
- README expanded with per-module sections for all 17 modules
- CONTRIBUTING.md, SECURITY.md, LICENSE
- biome.json with explicit lint rules
- CodeQL security scanning in CI
- Coverage thresholds (60% lines/functions)
- Bundle size tracking in CI
- License audit in CI
- Renovate dependency management
- PR template with quality checklist
Fixed
- SQL injection prevention in
vectorSearchRaw(validateIdentifier) - Agent message reducer accumulates instead of overwrites
- Stream rate limit checked before model loading
- Trace IDs use
crypto.randomUUID(no cold start collisions) - All
require()converted toimport()for ESM consistency mockLLMthrowsLLMErrorinstead of rawError- Rate limiter validates cache parameter
- All error messages include
yarn addnotnpm install
Changed
createAIfactory refactored (140 lines to 25 lines)tokensTodayrenamed totokensInWindow(accurate naming)defaultDriveruses provider param (neontoneon-http)aiStepaccepts configurable pricing- Extracted
builtInSplitto sharedinternal/utility
[0.1.0] - 2026-03-28
Added
Core Modules (v5)
- ai module: Vercel AI SDK wrapper with
createAI,generate,stream,structured, provider fallback, and cost tracking - chain module: LangChain.js composition with
prompt,parse,createChain,rag,createSplitter,createLanguageSplitter - agents module: LangGraph.js multi-agent orchestration with
createAgent,createGraph,route, state reducers, HITL - knowledge module: Document ingestion pipeline with
parseDocument,chunk,ingest,search,createKnowledge - database module: Drizzle ORM + pgvector with
createDatabase,vectorSearch,migrate, SQL injection prevention - monitor module: Langfuse observability with
createMonitor,trace,evaluate,getCostReport,createLogger - workflow module: Inngest durable jobs with
createWorkflow,defineJob,humanInTheLoop,aiStep,serve - security module: PII detection, sanitization, guardrails, audit logging, rate limiting
Existing Modules (carried from v4, updated)
- config module: Zod schema validation with
initToolkit,parseConfig - errors module: Typed error hierarchy —
ToolkitError,LLMError,ValidationError,AuthError, and more - mcp module: MCP server builder with
McpServerBuilder,McpTestHarness, Zod tool schemas - auth module: API key validation with timing-safe comparison, RBAC, multi-tenant context
- cache module: Redis + in-memory adapters with TTL,
createCache - storage module: Vercel Blob wrapper with file validation, upload, delete, list
- health module: Self-diagnostics with
createHealthCheck - api module: HTTP client with retry logic
- testing module: Mock factories for all v5 modules
Infrastructure
- 8 Architecture Decision Records (ADR-001 through ADR-008)
- CI pipeline: GitHub Actions with typecheck, lint, test, coverage, build, bundle size, license audit
- CodeQL security scanning on PRs
- Nightly scheduled test + build
- Semantic verification checks (5 automated pattern checks)
- Biome linter with explicit rules
- Husky pre-commit and pre-push hooks
- Renovate dependency monitoring
- PR template with quality checklist
- CONTRIBUTING.md, SECURITY.md, LICENSE (MIT)
- LLMS.md for AI-assisted development context