reactive-fsm 1.0.0 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +107 -0
- package/dist/adapters/anthropic.d.ts +13 -0
- package/dist/adapters/anthropic.d.ts.map +1 -0
- package/dist/adapters/anthropic.js +33 -0
- package/dist/adapters/anthropic.js.map +1 -0
- package/dist/adapters/gemini.d.ts +15 -0
- package/dist/adapters/gemini.d.ts.map +1 -0
- package/dist/adapters/gemini.js +33 -0
- package/dist/adapters/gemini.js.map +1 -0
- package/dist/adapters/langchain.d.ts +10 -0
- package/dist/adapters/langchain.d.ts.map +1 -0
- package/dist/adapters/langchain.js +20 -0
- package/dist/adapters/langchain.js.map +1 -0
- package/dist/adapters/openai.d.ts +2 -2
- package/dist/adapters/openai.d.ts.map +1 -1
- package/dist/adapters/openai.js +6 -5
- package/dist/adapters/openai.js.map +1 -1
- package/dist/adapters/vercel-ai.d.ts +2 -2
- package/dist/adapters/vercel-ai.d.ts.map +1 -1
- package/dist/adapters/vercel-ai.js +8 -7
- package/dist/adapters/vercel-ai.js.map +1 -1
- package/dist/core/machine.d.ts +3 -1
- package/dist/core/machine.d.ts.map +1 -1
- package/dist/core/machine.js.map +1 -1
- package/dist/index.d.ts +10 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -1
- package/dist/index.js.map +1 -1
- package/package.json +30 -3
package/README.md
CHANGED
|
@@ -154,6 +154,98 @@ while (true) {
|
|
|
154
154
|
}
|
|
155
155
|
```
|
|
156
156
|
|
|
157
|
+
#### Anthropic SDK
|
|
158
|
+
|
|
159
|
+
```typescript
|
|
160
|
+
import { createAnthropicAdapter } from 'reactive-fsm/adapters/anthropic'
|
|
161
|
+
import Anthropic from '@anthropic-ai/sdk'
|
|
162
|
+
|
|
163
|
+
const anthropic = new Anthropic()
|
|
164
|
+
const adapter = createAnthropicAdapter(fsm, registry, appCtx)
|
|
165
|
+
|
|
166
|
+
const messages = [{ role: 'user' as const, content: 'Quiero agendar una cita' }]
|
|
167
|
+
|
|
168
|
+
while (true) {
|
|
169
|
+
const { tools } = adapter.inject()
|
|
170
|
+
|
|
171
|
+
const response = await anthropic.messages.create({
|
|
172
|
+
model: 'claude-sonnet-4-20250514',
|
|
173
|
+
max_tokens: 1024,
|
|
174
|
+
messages,
|
|
175
|
+
tools,
|
|
176
|
+
})
|
|
177
|
+
|
|
178
|
+
const toolUses = response.content.filter(c => c.type === 'tool_use')
|
|
179
|
+
messages.push({ role: 'assistant', content: response.content })
|
|
180
|
+
|
|
181
|
+
if (toolUses.length > 0) {
|
|
182
|
+
adapter.registerToolCall()
|
|
183
|
+
if (adapter.isLooping()) break
|
|
184
|
+
|
|
185
|
+
const toolResults = toolUses.map(tc => ({
|
|
186
|
+
type: 'tool_result' as const,
|
|
187
|
+
tool_use_id: tc.id,
|
|
188
|
+
content: JSON.stringify(await executeTool(tc.name, tc.input)),
|
|
189
|
+
}))
|
|
190
|
+
messages.push({ role: 'user', content: toolResults })
|
|
191
|
+
continue
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
return response.content.find(c => c.type === 'text')?.text
|
|
195
|
+
}
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
#### LangChain
|
|
199
|
+
|
|
200
|
+
```typescript
|
|
201
|
+
import { wrapWithFSM } from 'reactive-fsm/adapters/langchain'
|
|
202
|
+
|
|
203
|
+
const wrapper = wrapWithFSM(fsm, registry, appCtx)
|
|
204
|
+
// wrapper.getTools() returns available tools for current gate
|
|
205
|
+
// wrapper.shouldStop() — check before each agent step
|
|
206
|
+
// wrapper.onToolCall() — call after each tool invocation
|
|
207
|
+
// wrapper.onStateChange('BOOKING') — refresh gate mid-flow
|
|
208
|
+
|
|
209
|
+
// Integrate with your existing LangChain executor:
|
|
210
|
+
const currentTools = Object.values(wrapper.getTools())
|
|
211
|
+
// …pass to your agent, re-fetch tools each iteration
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
#### Google Gemini
|
|
215
|
+
|
|
216
|
+
```typescript
|
|
217
|
+
import { createGeminiAdapter } from 'reactive-fsm/adapters/gemini'
|
|
218
|
+
import { GoogleGenerativeAI } from '@google/generative-ai'
|
|
219
|
+
|
|
220
|
+
const genAI = new GoogleGenerativeAI(apiKey)
|
|
221
|
+
const adapter = createGeminiAdapter(fsm, registry, appCtx)
|
|
222
|
+
const model = genAI.getGenerativeModel({
|
|
223
|
+
model: 'gemini-2.0-flash',
|
|
224
|
+
tools: adapter.inject().tools,
|
|
225
|
+
})
|
|
226
|
+
|
|
227
|
+
const chat = model.startChat()
|
|
228
|
+
|
|
229
|
+
while (true) {
|
|
230
|
+
const { tools } = adapter.inject()
|
|
231
|
+
const result = await chat.sendMessage(userMessage)
|
|
232
|
+
const calls = result.response.functionCalls()
|
|
233
|
+
|
|
234
|
+
if (calls?.length) {
|
|
235
|
+
adapter.registerToolCall()
|
|
236
|
+
if (adapter.isLooping()) break
|
|
237
|
+
|
|
238
|
+
const parts = calls.map(call => ({
|
|
239
|
+
functionResponse: { name: call.name, response: executeTool(call.name, call.args) },
|
|
240
|
+
}))
|
|
241
|
+
await chat.sendMessage(parts)
|
|
242
|
+
continue
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
return result.response.text()
|
|
246
|
+
}
|
|
247
|
+
```
|
|
248
|
+
|
|
157
249
|
---
|
|
158
250
|
|
|
159
251
|
## Real-World Patterns
|
|
@@ -290,6 +382,21 @@ shield.reset()
|
|
|
290
382
|
|
|
291
383
|
---
|
|
292
384
|
|
|
385
|
+
## Why reactive-fsm
|
|
386
|
+
|
|
387
|
+
| | reactive-fsm | LangGraph | Manual |
|
|
388
|
+
|---|---|---|---|
|
|
389
|
+
| Dependencies | **0** (core) | LangChain + several | None |
|
|
390
|
+
| Bundle size | **~7 KB** | ~5 MB | — |
|
|
391
|
+
| Setup | **3 lines** | 30+ lines | 50+ lines |
|
|
392
|
+
| Loop shield | **Built-in** | None | Manual |
|
|
393
|
+
| Tool gating | **Per-state** | Manual filter | Manual |
|
|
394
|
+
| Gate refresh | **Automatic** | None | None |
|
|
395
|
+
| Provider | **Any** | LangChain-only | Any |
|
|
396
|
+
| TypeScript | **100% typed** | Partial | Varies |
|
|
397
|
+
|
|
398
|
+
---
|
|
399
|
+
|
|
293
400
|
## Architecture
|
|
294
401
|
|
|
295
402
|
```
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { FSMPublic } from '../core/machine';
|
|
2
|
+
import { type ToolEntry } from '../core/tool-gating';
|
|
3
|
+
export interface AnthropicAdapter<TContext = any> {
|
|
4
|
+
inject(): {
|
|
5
|
+
tools: unknown[];
|
|
6
|
+
};
|
|
7
|
+
isLooping(): boolean;
|
|
8
|
+
registerToolCall(): void;
|
|
9
|
+
resetLoopShield(): void;
|
|
10
|
+
refreshGate(state: string): void;
|
|
11
|
+
}
|
|
12
|
+
export declare function createAnthropicAdapter<TContext = any>(fsm: FSMPublic, registry: ToolEntry<TContext>[], context: TContext): AnthropicAdapter<TContext>;
|
|
13
|
+
//# sourceMappingURL=anthropic.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"anthropic.d.ts","sourceRoot":"","sources":["../../src/adapters/anthropic.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAe,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAqB,KAAK,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAExE,MAAM,WAAW,gBAAgB,CAAC,QAAQ,GAAG,GAAG;IAC9C,MAAM,IAAI;QAAE,KAAK,EAAE,OAAO,EAAE,CAAA;KAAE,CAAC;IAC/B,SAAS,IAAI,OAAO,CAAC;IACrB,gBAAgB,IAAI,IAAI,CAAC;IACzB,eAAe,IAAI,IAAI,CAAC;IACxB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAClC;AAQD,wBAAgB,sBAAsB,CAAC,QAAQ,GAAG,GAAG,EACnD,GAAG,EAAE,SAAS,EACd,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC,EAAE,EAC/B,OAAO,EAAE,QAAQ,GAChB,gBAAgB,CAAC,QAAQ,CAAC,CAkC5B"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { buildToolsForGate } from '../core/tool-gating';
|
|
2
|
+
export function createAnthropicAdapter(fsm, registry, context) {
|
|
3
|
+
const _fsm = fsm;
|
|
4
|
+
return {
|
|
5
|
+
inject() {
|
|
6
|
+
const toolMap = buildToolsForGate(_fsm.currentState, context, registry);
|
|
7
|
+
const toolsArray = [];
|
|
8
|
+
for (const t of Object.values(toolMap)) {
|
|
9
|
+
const tool = t;
|
|
10
|
+
toolsArray.push({
|
|
11
|
+
name: tool.name ?? '',
|
|
12
|
+
description: tool.description ?? '',
|
|
13
|
+
input_schema: tool.parameters ?? { type: 'object', properties: {} },
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
return { tools: toolsArray };
|
|
17
|
+
},
|
|
18
|
+
isLooping() {
|
|
19
|
+
return _fsm.isLooping;
|
|
20
|
+
},
|
|
21
|
+
registerToolCall() {
|
|
22
|
+
_fsm._registerToolCall();
|
|
23
|
+
},
|
|
24
|
+
resetLoopShield() {
|
|
25
|
+
_fsm._resetLoopShield();
|
|
26
|
+
},
|
|
27
|
+
refreshGate(state) {
|
|
28
|
+
_fsm._setState(state);
|
|
29
|
+
_fsm._resetLoopShield();
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=anthropic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"anthropic.js","sourceRoot":"","sources":["../../src/adapters/anthropic.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAkB,MAAM,qBAAqB,CAAC;AAgBxE,MAAM,UAAU,sBAAsB,CACpC,GAAc,EACd,QAA+B,EAC/B,OAAiB;IAEjB,MAAM,IAAI,GAAG,GAAkB,CAAC;IAChC,OAAO;QACL,MAAM;YACJ,MAAM,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;YACxE,MAAM,UAAU,GAAoB,EAAE,CAAC;YACvC,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;gBACvC,MAAM,IAAI,GAAG,CAA4B,CAAC;gBAC1C,UAAU,CAAC,IAAI,CAAC;oBACd,IAAI,EAAG,IAAI,CAAC,IAAe,IAAI,EAAE;oBACjC,WAAW,EAAG,IAAI,CAAC,WAAsB,IAAI,EAAE;oBAC/C,YAAY,EAAG,IAAI,CAAC,UAAsC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,EAAE;iBACjG,CAAC,CAAC;YACL,CAAC;YACD,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;QAC/B,CAAC;QAED,SAAS;YACP,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;QAED,gBAAgB;YACd,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;QAED,eAAe;YACb,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;QAED,WAAW,CAAC,KAAa;YACvB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YACtB,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { FSMPublic } from '../core/machine';
|
|
2
|
+
import { type ToolEntry } from '../core/tool-gating';
|
|
3
|
+
export interface GeminiAdapter<TContext = any> {
|
|
4
|
+
inject(): {
|
|
5
|
+
tools: Array<{
|
|
6
|
+
functionDeclarations: unknown[];
|
|
7
|
+
}>;
|
|
8
|
+
};
|
|
9
|
+
isLooping(): boolean;
|
|
10
|
+
registerToolCall(): void;
|
|
11
|
+
resetLoopShield(): void;
|
|
12
|
+
refreshGate(state: string): void;
|
|
13
|
+
}
|
|
14
|
+
export declare function createGeminiAdapter<TContext = any>(fsm: FSMPublic, registry: ToolEntry<TContext>[], context: TContext): GeminiAdapter<TContext>;
|
|
15
|
+
//# sourceMappingURL=gemini.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gemini.d.ts","sourceRoot":"","sources":["../../src/adapters/gemini.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAe,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAqB,KAAK,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAExE,MAAM,WAAW,aAAa,CAAC,QAAQ,GAAG,GAAG;IAC3C,MAAM,IAAI;QAAE,KAAK,EAAE,KAAK,CAAC;YAAE,oBAAoB,EAAE,OAAO,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,CAAC;IAChE,SAAS,IAAI,OAAO,CAAC;IACrB,gBAAgB,IAAI,IAAI,CAAC;IACzB,eAAe,IAAI,IAAI,CAAC;IACxB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAClC;AAED,wBAAgB,mBAAmB,CAAC,QAAQ,GAAG,GAAG,EAChD,GAAG,EAAE,SAAS,EACd,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC,EAAE,EAC/B,OAAO,EAAE,QAAQ,GAChB,aAAa,CAAC,QAAQ,CAAC,CAkCzB"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { buildToolsForGate } from '../core/tool-gating';
|
|
2
|
+
export function createGeminiAdapter(fsm, registry, context) {
|
|
3
|
+
const _fsm = fsm;
|
|
4
|
+
return {
|
|
5
|
+
inject() {
|
|
6
|
+
const toolMap = buildToolsForGate(_fsm.currentState, context, registry);
|
|
7
|
+
const declarations = [];
|
|
8
|
+
for (const t of Object.values(toolMap)) {
|
|
9
|
+
const tool = t;
|
|
10
|
+
declarations.push({
|
|
11
|
+
name: tool.name ?? '',
|
|
12
|
+
description: tool.description ?? '',
|
|
13
|
+
parameters: tool.parameters ?? { type: 'object', properties: {} },
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
return { tools: [{ functionDeclarations: declarations }] };
|
|
17
|
+
},
|
|
18
|
+
isLooping() {
|
|
19
|
+
return _fsm.isLooping;
|
|
20
|
+
},
|
|
21
|
+
registerToolCall() {
|
|
22
|
+
_fsm._registerToolCall();
|
|
23
|
+
},
|
|
24
|
+
resetLoopShield() {
|
|
25
|
+
_fsm._resetLoopShield();
|
|
26
|
+
},
|
|
27
|
+
refreshGate(state) {
|
|
28
|
+
_fsm._setState(state);
|
|
29
|
+
_fsm._resetLoopShield();
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=gemini.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gemini.js","sourceRoot":"","sources":["../../src/adapters/gemini.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAkB,MAAM,qBAAqB,CAAC;AAUxE,MAAM,UAAU,mBAAmB,CACjC,GAAc,EACd,QAA+B,EAC/B,OAAiB;IAEjB,MAAM,IAAI,GAAG,GAAkB,CAAC;IAChC,OAAO;QACL,MAAM;YACJ,MAAM,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;YACxE,MAAM,YAAY,GAAc,EAAE,CAAC;YACnC,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;gBACvC,MAAM,IAAI,GAAG,CAA4B,CAAC;gBAC1C,YAAY,CAAC,IAAI,CAAC;oBAChB,IAAI,EAAG,IAAI,CAAC,IAAe,IAAI,EAAE;oBACjC,WAAW,EAAG,IAAI,CAAC,WAAsB,IAAI,EAAE;oBAC/C,UAAU,EAAG,IAAI,CAAC,UAAsC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,EAAE;iBAC/F,CAAC,CAAC;YACL,CAAC;YACD,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,oBAAoB,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC;QAC7D,CAAC;QAED,SAAS;YACP,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;QAED,gBAAgB;YACd,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;QAED,eAAe;YACb,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;QAED,WAAW,CAAC,KAAa;YACvB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YACtB,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { FSMPublic } from '../core/machine';
|
|
2
|
+
import { type ToolEntry } from '../core/tool-gating';
|
|
3
|
+
export interface LangChainFSMWrapper<TContext = any> {
|
|
4
|
+
getTools(): Record<string, unknown>;
|
|
5
|
+
shouldStop(): boolean;
|
|
6
|
+
onToolCall(): void;
|
|
7
|
+
onStateChange(gate: string): void;
|
|
8
|
+
}
|
|
9
|
+
export declare function wrapWithFSM<TContext = any>(fsm: FSMPublic, registry: ToolEntry<TContext>[], context: TContext): LangChainFSMWrapper<TContext>;
|
|
10
|
+
//# sourceMappingURL=langchain.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"langchain.d.ts","sourceRoot":"","sources":["../../src/adapters/langchain.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAe,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAqB,KAAK,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAExE,MAAM,WAAW,mBAAmB,CAAC,QAAQ,GAAG,GAAG;IACjD,QAAQ,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACpC,UAAU,IAAI,OAAO,CAAC;IACtB,UAAU,IAAI,IAAI,CAAC;IACnB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;CACnC;AAED,wBAAgB,WAAW,CAAC,QAAQ,GAAG,GAAG,EACxC,GAAG,EAAE,SAAS,EACd,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC,EAAE,EAC/B,OAAO,EAAE,QAAQ,GAChB,mBAAmB,CAAC,QAAQ,CAAC,CAoB/B"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { buildToolsForGate } from '../core/tool-gating';
|
|
2
|
+
export function wrapWithFSM(fsm, registry, context) {
|
|
3
|
+
const _fsm = fsm;
|
|
4
|
+
return {
|
|
5
|
+
getTools() {
|
|
6
|
+
return buildToolsForGate(_fsm.currentState, context, registry);
|
|
7
|
+
},
|
|
8
|
+
shouldStop() {
|
|
9
|
+
return _fsm.isLooping;
|
|
10
|
+
},
|
|
11
|
+
onToolCall() {
|
|
12
|
+
_fsm._registerToolCall();
|
|
13
|
+
},
|
|
14
|
+
onStateChange(gate) {
|
|
15
|
+
_fsm._setState(gate);
|
|
16
|
+
_fsm._resetLoopShield();
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=langchain.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"langchain.js","sourceRoot":"","sources":["../../src/adapters/langchain.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAkB,MAAM,qBAAqB,CAAC;AASxE,MAAM,UAAU,WAAW,CACzB,GAAc,EACd,QAA+B,EAC/B,OAAiB;IAEjB,MAAM,IAAI,GAAG,GAAkB,CAAC;IAChC,OAAO;QACL,QAAQ;YACN,OAAO,iBAAiB,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;QACjE,CAAC;QAED,UAAU;YACR,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;QAED,UAAU;YACR,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;QAED,aAAa,CAAC,IAAY;YACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YACrB,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { FSMPublic } from '../core/machine';
|
|
2
2
|
import { type ToolEntry } from '../core/tool-gating';
|
|
3
3
|
export interface OpenAIInjectResult {
|
|
4
4
|
tools: unknown[];
|
|
@@ -10,5 +10,5 @@ export interface OpenAIAdapter<TContext = any> {
|
|
|
10
10
|
resetLoopShield(): void;
|
|
11
11
|
refreshGate(state: string): void;
|
|
12
12
|
}
|
|
13
|
-
export declare function createOpenAIAdapter<TContext = any>(fsm:
|
|
13
|
+
export declare function createOpenAIAdapter<TContext = any>(fsm: FSMPublic, registry: ToolEntry<TContext>[], context: TContext): OpenAIAdapter<TContext>;
|
|
14
14
|
//# sourceMappingURL=openai.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"openai.d.ts","sourceRoot":"","sources":["../../src/adapters/openai.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"openai.d.ts","sourceRoot":"","sources":["../../src/adapters/openai.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAe,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAqB,KAAK,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAExE,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,OAAO,EAAE,CAAC;CAClB;AAED,MAAM,WAAW,aAAa,CAAC,QAAQ,GAAG,GAAG;IAC3C,MAAM,IAAI,kBAAkB,CAAC;IAC7B,SAAS,IAAI,OAAO,CAAC;IACrB,gBAAgB,IAAI,IAAI,CAAC;IACzB,eAAe,IAAI,IAAI,CAAC;IACxB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAClC;AAED,wBAAgB,mBAAmB,CAAC,QAAQ,GAAG,GAAG,EAChD,GAAG,EAAE,SAAS,EACd,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC,EAAE,EAC/B,OAAO,EAAE,QAAQ,GAChB,aAAa,CAAC,QAAQ,CAAC,CAwBzB"}
|
package/dist/adapters/openai.js
CHANGED
|
@@ -1,21 +1,22 @@
|
|
|
1
1
|
import { buildToolsForGate } from '../core/tool-gating';
|
|
2
2
|
export function createOpenAIAdapter(fsm, registry, context) {
|
|
3
|
+
const _fsm = fsm;
|
|
3
4
|
return {
|
|
4
5
|
inject() {
|
|
5
|
-
const toolMap = buildToolsForGate(
|
|
6
|
+
const toolMap = buildToolsForGate(_fsm.currentState, context, registry);
|
|
6
7
|
return { tools: Object.values(toolMap) };
|
|
7
8
|
},
|
|
8
9
|
isLooping() {
|
|
9
|
-
return
|
|
10
|
+
return _fsm.isLooping;
|
|
10
11
|
},
|
|
11
12
|
registerToolCall() {
|
|
12
|
-
|
|
13
|
+
_fsm._registerToolCall();
|
|
13
14
|
},
|
|
14
15
|
resetLoopShield() {
|
|
15
|
-
|
|
16
|
+
_fsm._resetLoopShield();
|
|
16
17
|
},
|
|
17
18
|
refreshGate(state) {
|
|
18
|
-
|
|
19
|
+
_fsm._setState(state);
|
|
19
20
|
},
|
|
20
21
|
};
|
|
21
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"openai.js","sourceRoot":"","sources":["../../src/adapters/openai.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAkB,MAAM,qBAAqB,CAAC;AAcxE,MAAM,UAAU,mBAAmB,CACjC,
|
|
1
|
+
{"version":3,"file":"openai.js","sourceRoot":"","sources":["../../src/adapters/openai.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAkB,MAAM,qBAAqB,CAAC;AAcxE,MAAM,UAAU,mBAAmB,CACjC,GAAc,EACd,QAA+B,EAC/B,OAAiB;IAEjB,MAAM,IAAI,GAAG,GAAkB,CAAC;IAChC,OAAO;QACL,MAAM;YACJ,MAAM,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;YACxE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QAC3C,CAAC;QAED,SAAS;YACP,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;QAED,gBAAgB;YACd,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;QAED,eAAe;YACb,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;QAED,WAAW,CAAC,KAAa;YACvB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { FSMPublic } from '../core/machine';
|
|
2
2
|
import { type ToolEntry } from '../core/tool-gating';
|
|
3
3
|
export interface VercelStepInfo {
|
|
4
4
|
toolCalls?: Array<{
|
|
@@ -24,5 +24,5 @@ export interface VercelAdapter<TContext = any> {
|
|
|
24
24
|
inject(): VercelInjectResult;
|
|
25
25
|
refreshGate(state: string): void;
|
|
26
26
|
}
|
|
27
|
-
export declare function createVercelAdapter<TContext = any>(fsm:
|
|
27
|
+
export declare function createVercelAdapter<TContext = any>(fsm: FSMPublic, registry: ToolEntry<TContext>[], context: TContext): VercelAdapter<TContext>;
|
|
28
28
|
//# sourceMappingURL=vercel-ai.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vercel-ai.d.ts","sourceRoot":"","sources":["../../src/adapters/vercel-ai.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"vercel-ai.d.ts","sourceRoot":"","sources":["../../src/adapters/vercel-ai.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAe,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAqB,KAAK,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAExE,MAAM,WAAW,cAAc;IAC7B,SAAS,CAAC,EAAE,KAAK,CAAC;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;IACxD,WAAW,CAAC,EAAE,KAAK,CAAC;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;CAC7D;AAED,MAAM,WAAW,uBAAuB;IACtC,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,uBAAuB,KAAK,OAAO,CAAC;QAAE,UAAU,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;CAC7G;AAED,MAAM,WAAW,aAAa,CAAC,QAAQ,GAAG,GAAG;IAC3C,MAAM,IAAI,kBAAkB,CAAC;IAC7B,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAClC;AAiBD,wBAAgB,mBAAmB,CAAC,QAAQ,GAAG,GAAG,EAChD,GAAG,EAAE,SAAS,EACd,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC,EAAE,EAC/B,OAAO,EAAE,QAAQ,GAChB,aAAa,CAAC,QAAQ,CAAC,CA6CzB"}
|
|
@@ -9,11 +9,12 @@ function syncTools(target, gate, ctx, registry) {
|
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
11
|
export function createVercelAdapter(fsm, registry, context) {
|
|
12
|
+
const _fsm = fsm;
|
|
12
13
|
const tools = {};
|
|
13
14
|
let currentGate = null;
|
|
14
15
|
return {
|
|
15
16
|
inject() {
|
|
16
|
-
currentGate =
|
|
17
|
+
currentGate = _fsm.currentState;
|
|
17
18
|
syncTools(tools, currentGate, context, registry);
|
|
18
19
|
return {
|
|
19
20
|
tools,
|
|
@@ -27,15 +28,15 @@ export function createVercelAdapter(fsm, registry, context) {
|
|
|
27
28
|
break;
|
|
28
29
|
}
|
|
29
30
|
}
|
|
30
|
-
|
|
31
|
+
_fsm._resetLoopShield();
|
|
31
32
|
for (let i = 0; i < consecutiveToolSteps; i++) {
|
|
32
|
-
|
|
33
|
+
_fsm._registerToolCall();
|
|
33
34
|
}
|
|
34
|
-
if (
|
|
35
|
+
if (_fsm.isLooping) {
|
|
35
36
|
return { toolChoice: 'none' };
|
|
36
37
|
}
|
|
37
|
-
if (
|
|
38
|
-
currentGate =
|
|
38
|
+
if (_fsm.currentState !== currentGate) {
|
|
39
|
+
currentGate = _fsm.currentState;
|
|
39
40
|
syncTools(tools, currentGate, context, registry);
|
|
40
41
|
}
|
|
41
42
|
return {};
|
|
@@ -43,7 +44,7 @@ export function createVercelAdapter(fsm, registry, context) {
|
|
|
43
44
|
};
|
|
44
45
|
},
|
|
45
46
|
refreshGate(state) {
|
|
46
|
-
|
|
47
|
+
_fsm._setState(state);
|
|
47
48
|
},
|
|
48
49
|
};
|
|
49
50
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vercel-ai.js","sourceRoot":"","sources":["../../src/adapters/vercel-ai.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAkB,MAAM,qBAAqB,CAAC;AAsBxE,SAAS,SAAS,CAChB,MAA+B,EAC/B,IAAY,EACZ,GAAY,EACZ,QAAqB;IAErB,MAAM,KAAK,GAAG,iBAAiB,CAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;IACrD,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QACtC,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;IACD,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACjD,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IACtB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,mBAAmB,CACjC,
|
|
1
|
+
{"version":3,"file":"vercel-ai.js","sourceRoot":"","sources":["../../src/adapters/vercel-ai.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAkB,MAAM,qBAAqB,CAAC;AAsBxE,SAAS,SAAS,CAChB,MAA+B,EAC/B,IAAY,EACZ,GAAY,EACZ,QAAqB;IAErB,MAAM,KAAK,GAAG,iBAAiB,CAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;IACrD,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QACtC,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;IACD,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACjD,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IACtB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,mBAAmB,CACjC,GAAc,EACd,QAA+B,EAC/B,OAAiB;IAEjB,MAAM,IAAI,GAAG,GAAkB,CAAC;IAChC,MAAM,KAAK,GAA4B,EAAE,CAAC;IAC1C,IAAI,WAAW,GAAkB,IAAI,CAAC;IAEtC,OAAO;QACL,MAAM;YACJ,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC;YAChC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;YAEjD,OAAO;gBACL,KAAK;gBACL,WAAW,EAAE,KAAK,EAAE,EAAE,KAAK,EAA2B,EAAE,EAAE;oBACxD,IAAI,oBAAoB,GAAG,CAAC,CAAC;oBAC7B,KAAK,IAAI,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;wBAC3C,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC;4BAC1C,oBAAoB,EAAE,CAAC;wBACzB,CAAC;6BAAM,CAAC;4BACN,MAAM;wBACR,CAAC;oBACH,CAAC;oBAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,oBAAoB,EAAE,CAAC,EAAE,EAAE,CAAC;wBAC9C,IAAI,CAAC,iBAAiB,EAAE,CAAC;oBAC3B,CAAC;oBAED,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;wBACnB,OAAO,EAAE,UAAU,EAAE,MAAe,EAAE,CAAC;oBACzC,CAAC;oBAED,IAAI,IAAI,CAAC,YAAY,KAAK,WAAW,EAAE,CAAC;wBACtC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC;wBAChC,SAAS,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;oBACnD,CAAC;oBAED,OAAO,EAAE,CAAC;gBACZ,CAAC;aACF,CAAC;QACJ,CAAC;QAED,WAAW,CAAC,KAAa;YACvB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC;KACF,CAAC;AACJ,CAAC"}
|
package/dist/core/machine.d.ts
CHANGED
|
@@ -5,11 +5,13 @@ export interface FSMConfig {
|
|
|
5
5
|
tools: Record<string, string[]>;
|
|
6
6
|
loopShield?: LoopShieldConfig;
|
|
7
7
|
}
|
|
8
|
-
export interface
|
|
8
|
+
export interface FSMPublic {
|
|
9
9
|
readonly currentState: string;
|
|
10
10
|
readonly allowedTools: string[];
|
|
11
11
|
readonly isLooping: boolean;
|
|
12
12
|
transitionTo(state: string): void;
|
|
13
|
+
}
|
|
14
|
+
export interface FSMInstance extends FSMPublic {
|
|
13
15
|
_registerToolCall(): void;
|
|
14
16
|
_resetLoopShield(): void;
|
|
15
17
|
_setState(state: string): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"machine.d.ts","sourceRoot":"","sources":["../../src/core/machine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAExE,MAAM,WAAW,SAAS;IACxB,YAAY,EAAE,MAAM,CAAC;IACrB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;IAChC,UAAU,CAAC,EAAE,gBAAgB,CAAC;CAC/B;AAED,MAAM,WAAW,
|
|
1
|
+
{"version":3,"file":"machine.d.ts","sourceRoot":"","sources":["../../src/core/machine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAExE,MAAM,WAAW,SAAS;IACxB,YAAY,EAAE,MAAM,CAAC;IACrB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;IAChC,UAAU,CAAC,EAAE,gBAAgB,CAAC;CAC/B;AAED,MAAM,WAAW,SAAS;IACxB,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,YAAY,EAAE,MAAM,EAAE,CAAC;IAChC,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC;IAC5B,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CACnC;AAED,MAAM,WAAW,WAAY,SAAQ,SAAS;IAC5C,iBAAiB,IAAI,IAAI,CAAC;IAC1B,gBAAgB,IAAI,IAAI,CAAC;IACzB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAChC;AAED,wBAAgB,SAAS,CAAC,MAAM,EAAE,SAAS,GAAG,WAAW,CAoDxD"}
|
package/dist/core/machine.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"machine.js","sourceRoot":"","sources":["../../src/core/machine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAyB,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"machine.js","sourceRoot":"","sources":["../../src/core/machine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAyB,MAAM,eAAe,CAAC;AAsBxE,MAAM,UAAU,SAAS,CAAC,MAAiB;IACzC,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAE3C,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;QAC1C,MAAM,IAAI,KAAK,CAAC,kBAAkB,MAAM,CAAC,YAAY,6BAA6B,CAAC,CAAC;IACtF,CAAC;IAED,IAAI,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC;IAExC,MAAM,MAAM,GAAG,gBAAgB,CAC7B,MAAM,CAAC,UAAU,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC,EAAE,CAChE,CAAC;IAEF,SAAS,eAAe;QACtB,OAAO,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC3C,CAAC;IAED,OAAO;QACL,IAAI,YAAY;YACd,OAAO,aAAa,CAAC;QACvB,CAAC;QAED,IAAI,YAAY;YACd,OAAO,eAAe,EAAE,CAAC;QAC3B,CAAC;QAED,IAAI,SAAS;YACX,OAAO,MAAM,CAAC,SAAS,EAAE,CAAC;QAC5B,CAAC;QAED,YAAY,CAAC,KAAa;YACxB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC5B,MAAM,IAAI,KAAK,CAAC,kBAAkB,KAAK,oBAAoB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACzF,CAAC;YACD,aAAa,GAAG,KAAK,CAAC;QACxB,CAAC;QAED,iBAAiB;YACf,MAAM,CAAC,gBAAgB,EAAE,CAAC;QAC5B,CAAC;QAED,gBAAgB;YACd,MAAM,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC;QAED,SAAS,CAAC,KAAa;YACrB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC5B,MAAM,IAAI,KAAK,CAAC,kBAAkB,KAAK,oBAAoB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACzF,CAAC;YACD,aAAa,GAAG,KAAK,CAAC;QACxB,CAAC;KACF,CAAC;AACJ,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { createFSM as _createFSM } from './core/machine';
|
|
2
|
+
import type { FSMConfig, FSMPublic } from './core/machine';
|
|
3
|
+
export { _createFSM as createFSM };
|
|
4
|
+
export type { FSMConfig, FSMPublic };
|
|
3
5
|
export { buildToolsForGate } from './core/tool-gating';
|
|
4
6
|
export type { ToolEntry } from './core/tool-gating';
|
|
5
7
|
export { createLoopShield } from './core/loop-shield';
|
|
@@ -8,4 +10,10 @@ export { createVercelAdapter } from './adapters/vercel-ai';
|
|
|
8
10
|
export type { VercelAdapter, VercelInjectResult, VercelStepInfo, VercelPrepareStepParams, } from './adapters/vercel-ai';
|
|
9
11
|
export { createOpenAIAdapter } from './adapters/openai';
|
|
10
12
|
export type { OpenAIAdapter, OpenAIInjectResult, } from './adapters/openai';
|
|
13
|
+
export { createAnthropicAdapter } from './adapters/anthropic';
|
|
14
|
+
export type { AnthropicAdapter } from './adapters/anthropic';
|
|
15
|
+
export { wrapWithFSM } from './adapters/langchain';
|
|
16
|
+
export type { LangChainFSMWrapper } from './adapters/langchain';
|
|
17
|
+
export { createGeminiAdapter } from './adapters/gemini';
|
|
18
|
+
export type { GeminiAdapter } from './adapters/gemini';
|
|
11
19
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3D,OAAO,EAAE,UAAU,IAAI,SAAS,EAAE,CAAC;AACnC,YAAY,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC;AAErC,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,YAAY,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,YAAY,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAE/E,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,YAAY,EACV,aAAa,EACb,kBAAkB,EAClB,cAAc,EACd,uBAAuB,GACxB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,YAAY,EACV,aAAa,EACb,kBAAkB,GACnB,MAAM,mBAAmB,CAAC;AAE3B,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAC9D,YAAY,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAE7D,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,YAAY,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAEhE,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,YAAY,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,10 @@
|
|
|
1
|
-
|
|
1
|
+
import { createFSM as _createFSM } from './core/machine';
|
|
2
|
+
export { _createFSM as createFSM };
|
|
2
3
|
export { buildToolsForGate } from './core/tool-gating';
|
|
3
4
|
export { createLoopShield } from './core/loop-shield';
|
|
4
5
|
export { createVercelAdapter } from './adapters/vercel-ai';
|
|
5
6
|
export { createOpenAIAdapter } from './adapters/openai';
|
|
7
|
+
export { createAnthropicAdapter } from './adapters/anthropic';
|
|
8
|
+
export { wrapWithFSM } from './adapters/langchain';
|
|
9
|
+
export { createGeminiAdapter } from './adapters/gemini';
|
|
6
10
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGzD,OAAO,EAAE,UAAU,IAAI,SAAS,EAAE,CAAC;AAGnC,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAGvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAGtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAQ3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAMxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAG9D,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "reactive-fsm",
|
|
3
|
-
"version": "1.
|
|
4
|
-
"description": "Reactive Finite State Machine for AI agent orchestration — zero dependencies core, conditional tool gating, loop shield, adapters for Vercel AI SDK and
|
|
3
|
+
"version": "1.1.0",
|
|
4
|
+
"description": "Reactive Finite State Machine for AI agent orchestration — zero dependencies core, conditional tool gating, loop shield, adapters for Vercel AI SDK, OpenAI, Anthropic, LangChain, and Google Gemini",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
7
7
|
"types": "dist/index.d.ts",
|
|
@@ -17,6 +17,18 @@
|
|
|
17
17
|
"./adapters/openai": {
|
|
18
18
|
"types": "./dist/adapters/openai.d.ts",
|
|
19
19
|
"import": "./dist/adapters/openai.js"
|
|
20
|
+
},
|
|
21
|
+
"./adapters/anthropic": {
|
|
22
|
+
"types": "./dist/adapters/anthropic.d.ts",
|
|
23
|
+
"import": "./dist/adapters/anthropic.js"
|
|
24
|
+
},
|
|
25
|
+
"./adapters/langchain": {
|
|
26
|
+
"types": "./dist/adapters/langchain.d.ts",
|
|
27
|
+
"import": "./dist/adapters/langchain.js"
|
|
28
|
+
},
|
|
29
|
+
"./adapters/gemini": {
|
|
30
|
+
"types": "./dist/adapters/gemini.d.ts",
|
|
31
|
+
"import": "./dist/adapters/gemini.js"
|
|
20
32
|
}
|
|
21
33
|
},
|
|
22
34
|
"files": [
|
|
@@ -30,6 +42,9 @@
|
|
|
30
42
|
"ai-agents",
|
|
31
43
|
"vercel-ai-sdk",
|
|
32
44
|
"openai",
|
|
45
|
+
"anthropic",
|
|
46
|
+
"langchain",
|
|
47
|
+
"gemini",
|
|
33
48
|
"tool-gating"
|
|
34
49
|
],
|
|
35
50
|
"author": "Alejandro Alvarado <roddcode.dev@gmail.com>",
|
|
@@ -52,7 +67,10 @@
|
|
|
52
67
|
},
|
|
53
68
|
"peerDependencies": {
|
|
54
69
|
"ai": "^4.0.0",
|
|
55
|
-
"openai": "^4.0.0"
|
|
70
|
+
"openai": "^4.0.0",
|
|
71
|
+
"@anthropic-ai/sdk": "^0.30.0",
|
|
72
|
+
"langchain": "^0.3.0",
|
|
73
|
+
"@google/generative-ai": "^0.21.0"
|
|
56
74
|
},
|
|
57
75
|
"peerDependenciesMeta": {
|
|
58
76
|
"ai": {
|
|
@@ -60,6 +78,15 @@
|
|
|
60
78
|
},
|
|
61
79
|
"openai": {
|
|
62
80
|
"optional": true
|
|
81
|
+
},
|
|
82
|
+
"@anthropic-ai/sdk": {
|
|
83
|
+
"optional": true
|
|
84
|
+
},
|
|
85
|
+
"langchain": {
|
|
86
|
+
"optional": true
|
|
87
|
+
},
|
|
88
|
+
"@google/generative-ai": {
|
|
89
|
+
"optional": true
|
|
63
90
|
}
|
|
64
91
|
},
|
|
65
92
|
"scripts": {
|