@aitos/core 1.0.0 → 1.0.1

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.
@@ -0,0 +1,408 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TelemetryStore = exports.AtomRegistryImpl = exports.Store = exports.AitosRuntime = void 0;
4
+ class Store {
5
+ constructor() {
6
+ this.data = new Map();
7
+ }
8
+ get(key) {
9
+ return this.data.get(key);
10
+ }
11
+ set(key, value) {
12
+ this.data.set(key, value);
13
+ }
14
+ has(key) {
15
+ return this.data.has(key);
16
+ }
17
+ delete(key) {
18
+ this.data.delete(key);
19
+ }
20
+ clear() {
21
+ this.data.clear();
22
+ }
23
+ }
24
+ exports.Store = Store;
25
+ class TelemetryStore {
26
+ constructor() {
27
+ this.atoms = new Map();
28
+ }
29
+ record(atom, graphName, duration, success) {
30
+ let entry = this.atoms.get(atom);
31
+ if (!entry) {
32
+ entry = { count: 0, totalDuration: 0, maxDuration: 0, errorCount: 0, lastCalled: 0, graphs: new Set() };
33
+ this.atoms.set(atom, entry);
34
+ }
35
+ entry.count++;
36
+ entry.totalDuration += duration;
37
+ if (duration > entry.maxDuration)
38
+ entry.maxDuration = duration;
39
+ if (!success)
40
+ entry.errorCount++;
41
+ entry.lastCalled = Date.now();
42
+ entry.graphs.add(graphName);
43
+ }
44
+ getStats() {
45
+ const result = [];
46
+ for (const [atom, data] of this.atoms) {
47
+ result.push({
48
+ atom,
49
+ count: data.count,
50
+ avgDuration: data.count > 0 ? Math.round(data.totalDuration / data.count) : 0,
51
+ maxDuration: data.maxDuration,
52
+ errorCount: data.errorCount,
53
+ errorRate: data.count > 0 ? Math.round((data.errorCount / data.count) * 10000) / 100 : 0,
54
+ lastCalled: data.lastCalled,
55
+ graphs: Array.from(data.graphs),
56
+ });
57
+ }
58
+ result.sort((a, b) => b.count - a.count);
59
+ return result;
60
+ }
61
+ reset() {
62
+ this.atoms.clear();
63
+ }
64
+ }
65
+ exports.TelemetryStore = TelemetryStore;
66
+ class AtomRegistryImpl {
67
+ constructor() {
68
+ this.atoms = new Map();
69
+ }
70
+ register(atom) {
71
+ const key = `${atom.name}@${atom.version}`;
72
+ this.atoms.set(key, atom);
73
+ this.atoms.set(atom.name, atom);
74
+ }
75
+ get(name) {
76
+ return this.atoms.get(name);
77
+ }
78
+ has(name) {
79
+ return this.atoms.has(name);
80
+ }
81
+ list() {
82
+ const result = [];
83
+ const seen = new Set();
84
+ for (const [key, atom] of this.atoms.entries()) {
85
+ if (!seen.has(atom.name)) {
86
+ seen.add(atom.name);
87
+ result.push(atom.name);
88
+ }
89
+ }
90
+ return result;
91
+ }
92
+ }
93
+ exports.AtomRegistryImpl = AtomRegistryImpl;
94
+ class AitosRuntime {
95
+ constructor() {
96
+ this.atoms = new Map();
97
+ this.telemetryStore = new TelemetryStore();
98
+ this.telemetryHistory = [];
99
+ }
100
+ register(atom) {
101
+ const key = `${atom.name}@${atom.version}`;
102
+ this.atoms.set(key, atom);
103
+ this.atoms.set(atom.name, atom);
104
+ }
105
+ validateGraph(graph) {
106
+ const errors = [];
107
+ this.validateGraphNodes(graph.nodes, graph.order, errors);
108
+ return { valid: errors.length === 0, errors: errors.map(e => JSON.stringify(e)) };
109
+ }
110
+ validateGraphNodes(nodes, order, errors, path = '', parentExecuted) {
111
+ const executed = parentExecuted ? new Set(parentExecuted) : new Set();
112
+ for (const nodeId of order) {
113
+ const node = nodes[nodeId];
114
+ if (!node) {
115
+ errors.push({
116
+ node: path,
117
+ code: 'NODE_NOT_FOUND',
118
+ param: '',
119
+ ref: nodeId,
120
+ message: `Node "${nodeId}" not found in nodes`
121
+ });
122
+ continue;
123
+ }
124
+ const nodePath = path ? `${path}.${nodeId}` : nodeId;
125
+ if (!node.atom) {
126
+ errors.push({ node: nodePath, code: 'MISSING_ATOM', param: '', ref: '', message: 'Missing atom field' });
127
+ continue;
128
+ }
129
+ if (typeof node.atom !== 'string') {
130
+ errors.push({ node: nodePath, code: 'INVALID_ATOM_TYPE', param: '', ref: '', message: 'Atom must be a string' });
131
+ continue;
132
+ }
133
+ if (!this.atoms.has(node.atom)) {
134
+ errors.push({ node: nodePath, code: 'ATOM_NOT_FOUND', param: '', ref: '', message: `Atom "${node.atom}" not registered` });
135
+ }
136
+ this.validateGraphReferences(node, executed, errors, nodePath, nodes);
137
+ if (node.nodes && typeof node.nodes === 'object' && 'order' in node.nodes) {
138
+ const subGraph = node.nodes;
139
+ if (subGraph.nodes && subGraph.order) {
140
+ this.validateGraphNodes(subGraph.nodes, subGraph.order, errors, `${nodePath}.nodes`, executed);
141
+ }
142
+ }
143
+ if (node.then && typeof node.then === 'object' && 'order' in node.then) {
144
+ const subGraph = node.then;
145
+ if (subGraph.nodes && subGraph.order) {
146
+ this.validateGraphNodes(subGraph.nodes, subGraph.order, errors, `${nodePath}.then`, executed);
147
+ }
148
+ }
149
+ if (node.else && typeof node.else === 'object' && 'order' in node.else) {
150
+ const subGraph = node.else;
151
+ if (subGraph.nodes && subGraph.order) {
152
+ this.validateGraphNodes(subGraph.nodes, subGraph.order, errors, `${nodePath}.else`, executed);
153
+ }
154
+ }
155
+ executed.add(nodeId);
156
+ }
157
+ }
158
+ validateGraphReferences(node, executed, errors, nodePath, nodes) {
159
+ for (const [key, value] of Object.entries(node)) {
160
+ if (['atom', 'nodes', 'then', 'else'].includes(key))
161
+ continue;
162
+ if (typeof value === 'string') {
163
+ const matches = value.matchAll(/\{\{(\w+)(?:\.(.+?))?\}\}/g);
164
+ for (const match of matches) {
165
+ const refId = match[1];
166
+ if (!executed.has(refId) && !nodes[refId]) {
167
+ const suggestions = this.generateGraphSuggestions(executed, nodes);
168
+ errors.push({
169
+ node: nodePath,
170
+ code: 'INVALID_REFERENCE',
171
+ param: key,
172
+ ref: refId,
173
+ message: `Invalid reference {{${refId}}}: node not found or not yet executed`,
174
+ suggestions
175
+ });
176
+ }
177
+ }
178
+ }
179
+ }
180
+ }
181
+ generateGraphSuggestions(executed, nodes) {
182
+ const suggestions = [];
183
+ for (const nodeId of executed) {
184
+ if (suggestions.length >= 5)
185
+ break;
186
+ const node = nodes[nodeId];
187
+ if (node) {
188
+ const atom = this.atoms.get(node.atom);
189
+ suggestions.push({
190
+ id: nodeId,
191
+ type: atom?.meta.output.type || 'unknown',
192
+ source: node.atom
193
+ });
194
+ }
195
+ }
196
+ return suggestions;
197
+ }
198
+ async executeGraph(graph, context, outerScope, graphName) {
199
+ const results = outerScope ? { ...outerScope } : {};
200
+ const gName = graphName || 'unknown';
201
+ const previousScope = context.currentScope;
202
+ context.currentScope = results;
203
+ context.runtime = this;
204
+ for (const nodeId of graph.order) {
205
+ const node = graph.nodes[nodeId];
206
+ const input = this.resolveGraphInput(node, results, context);
207
+ const startTime = performance.now();
208
+ const result = await context.execute(node.atom, input);
209
+ const duration = Math.round(performance.now() - startTime);
210
+ this.telemetryStore.record(node.atom, gName, duration, result.success);
211
+ if (!result.success) {
212
+ context.currentScope = previousScope;
213
+ throw new Error(JSON.stringify({ node: nodeId, atom: node.atom, error: result.error }));
214
+ }
215
+ results[nodeId] = result.data;
216
+ }
217
+ context.currentScope = previousScope;
218
+ return results;
219
+ }
220
+ onSnapshot(callback) {
221
+ this.snapshotCallback = callback;
222
+ }
223
+ flushTelemetry() {
224
+ const stats = this.telemetryStore.getStats();
225
+ const snapshot = { timestamp: Date.now(), stats };
226
+ this.telemetryHistory.push(snapshot);
227
+ if (this.telemetryHistory.length > 100) {
228
+ this.telemetryHistory.shift();
229
+ }
230
+ this.snapshotCallback?.(snapshot);
231
+ return snapshot;
232
+ }
233
+ getTelemetryHistory() {
234
+ return this.telemetryHistory;
235
+ }
236
+ restoreTelemetryHistory(history) {
237
+ this.telemetryHistory = history.slice(-100);
238
+ }
239
+ resolveGraphInput(node, results, context) {
240
+ const resolved = {};
241
+ const SUBGRAPH_KEYS = new Set(['nodes', 'then', 'else']);
242
+ for (const [key, value] of Object.entries(node)) {
243
+ if (key === 'atom')
244
+ continue;
245
+ if (SUBGRAPH_KEYS.has(key)) {
246
+ resolved[key] = value;
247
+ }
248
+ else {
249
+ resolved[key] = this.resolveGraphValue(value, results, context);
250
+ }
251
+ }
252
+ return resolved;
253
+ }
254
+ resolveGraphValue(value, results, context) {
255
+ if (typeof value === 'string') {
256
+ const ESCAPE_PLACEHOLDER = '\x00ESCAPED_BRACE\x00';
257
+ let processedValue = value.replace(/\\{{/g, ESCAPE_PLACEHOLDER);
258
+ const match = processedValue.match(/^\{\{(\w+)(?:\.(.+?))?\}\}$/);
259
+ if (match) {
260
+ const nodeId = match[1];
261
+ const field = match[2];
262
+ let resolvedValue;
263
+ if (nodeId in results) {
264
+ resolvedValue = results[nodeId];
265
+ }
266
+ else if (context.store.has(nodeId)) {
267
+ resolvedValue = context.store.get(nodeId);
268
+ }
269
+ else {
270
+ throw new Error(JSON.stringify({
271
+ code: 'REFERENCE_NOT_FOUND',
272
+ ref: nodeId,
273
+ message: `Reference {{${nodeId}}} not found in current scope or store`,
274
+ availableInScope: Object.keys(results),
275
+ availableInStore: context.store.has(nodeId) ? [nodeId] : [],
276
+ hint: 'Check if the reference is a node output or a store value.',
277
+ fix: `Ensure the node "${nodeId}" is executed before this reference, or use { "atom": "set", "key": "${nodeId}", "value": ... } to store the value.`
278
+ }));
279
+ }
280
+ if (field) {
281
+ return this.getFieldValue(resolvedValue, field);
282
+ }
283
+ return resolvedValue;
284
+ }
285
+ const result = processedValue.replace(/\{\{(\w+)(?:\.(.+?))?\}\}/g, (_, nodeId, field) => {
286
+ let resolvedValue;
287
+ if (nodeId in results) {
288
+ resolvedValue = results[nodeId];
289
+ }
290
+ else if (context.store.has(nodeId)) {
291
+ resolvedValue = context.store.get(nodeId);
292
+ }
293
+ else {
294
+ throw new Error(JSON.stringify({
295
+ code: 'REFERENCE_NOT_FOUND',
296
+ ref: nodeId,
297
+ message: `Reference {{${nodeId}}} not found in current scope or store`,
298
+ availableInScope: Object.keys(results),
299
+ availableInStore: context.store.has(nodeId) ? [nodeId] : [],
300
+ hint: 'Check if the reference is a node output or a store value.',
301
+ fix: `Ensure the node "${nodeId}" is executed before this reference, or use { "atom": "set", "key": "${nodeId}", "value": ... } to store the value.`
302
+ }));
303
+ }
304
+ if (field) {
305
+ return this.getFieldValue(resolvedValue, field);
306
+ }
307
+ return resolvedValue;
308
+ });
309
+ return result.replace(new RegExp(ESCAPE_PLACEHOLDER, 'g'), '{{');
310
+ }
311
+ if (Array.isArray(value)) {
312
+ return value.map(item => this.resolveGraphValue(item, results, context));
313
+ }
314
+ if (typeof value === 'object' && value !== null) {
315
+ const resolved = {};
316
+ for (const [k, v] of Object.entries(value)) {
317
+ resolved[k] = this.resolveGraphValue(v, results, context);
318
+ }
319
+ return resolved;
320
+ }
321
+ return value;
322
+ }
323
+ getFieldValue(obj, field) {
324
+ const parts = field.split('.');
325
+ let current = obj;
326
+ for (const part of parts) {
327
+ if (current === undefined || current === null)
328
+ return undefined;
329
+ current = current[part];
330
+ }
331
+ return current;
332
+ }
333
+ listAtoms() {
334
+ const result = [];
335
+ const seen = new Set();
336
+ for (const [key, atom] of this.atoms.entries()) {
337
+ if (!seen.has(atom.name)) {
338
+ seen.add(atom.name);
339
+ result.push(atom);
340
+ }
341
+ }
342
+ return result;
343
+ }
344
+ getSkillSet() {
345
+ const atoms = this.listAtoms();
346
+ const registry = {
347
+ aitos: {
348
+ version: '1.0.0',
349
+ type: 'graph-instruction-set',
350
+ },
351
+ graph: {
352
+ format: {
353
+ nodes: 'Record<nodeId, GraphNode>',
354
+ order: 'string[] (execution order)'
355
+ },
356
+ example: {
357
+ nodes: {
358
+ getY: { atom: 'get', key: 'fruitY' },
359
+ addFive: { atom: 'add', a: '{{getY}}', b: 5 },
360
+ saveY: { atom: 'set', key: 'fruitY', value: '{{addFive}}' }
361
+ },
362
+ order: ['getY', 'addFive', 'saveY']
363
+ }
364
+ },
365
+ node: {
366
+ format: { atom: 'string', '...params': 'per atom.input' },
367
+ example: { atom: 'add', a: '{{otherNodeId}}', b: 1 }
368
+ },
369
+ ref: {
370
+ format: '{{nodeId}} or {{nodeId.field}}',
371
+ rules: [
372
+ 'Use nodeId to reference another node result',
373
+ 'nodeId must be defined in nodes and appear earlier in order',
374
+ 'Use {{nodeId.field}} to access nested properties',
375
+ 'References are resolved before execution'
376
+ ]
377
+ },
378
+ atoms: atoms.map(a => ({
379
+ name: a.name,
380
+ version: a.version,
381
+ input: a.meta.input,
382
+ output: a.meta.output,
383
+ })),
384
+ validation: {
385
+ description: 'Validation checks node references and atom existence',
386
+ errorFormat: {
387
+ node: 'Node path',
388
+ code: 'Error code',
389
+ param: 'Parameter name',
390
+ ref: 'Invalid reference',
391
+ message: 'Error description',
392
+ suggestions: [
393
+ { id: 'Suggested nodeId', type: 'Output type', source: 'Atom name' }
394
+ ]
395
+ }
396
+ }
397
+ };
398
+ return JSON.stringify(registry);
399
+ }
400
+ getTelemetryStats() {
401
+ return this.telemetryStore.getStats();
402
+ }
403
+ resetTelemetry() {
404
+ this.telemetryStore.reset();
405
+ }
406
+ }
407
+ exports.AitosRuntime = AitosRuntime;
408
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../src/runtime.ts"],"names":[],"mappings":"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","sourcesContent":["import { Atom, Context, Result, Graph, GraphNode, Scope, AtomRegistry, GraphValidationError, GraphSuggestion, Runtime, TelemetryStats, TelemetrySnapshot } from './types';\n\nclass Store {\n  private data: Map<string, any> = new Map();\n\n  get(key: string): any {\n    return this.data.get(key);\n  }\n\n  set(key: string, value: any): void {\n    this.data.set(key, value);\n  }\n\n  has(key: string): boolean {\n    return this.data.has(key);\n  }\n\n  delete(key: string): void {\n    this.data.delete(key);\n  }\n\n  clear(): void {\n    this.data.clear();\n  }\n}\n\nclass TelemetryStore {\n  private atoms: Map<string, {\n    count: number;\n    totalDuration: number;\n    maxDuration: number;\n    errorCount: number;\n    lastCalled: number;\n    graphs: Set<string>;\n  }> = new Map();\n\n  record(atom: string, graphName: string, duration: number, success: boolean): void {\n    let entry = this.atoms.get(atom);\n    if (!entry) {\n      entry = { count: 0, totalDuration: 0, maxDuration: 0, errorCount: 0, lastCalled: 0, graphs: new Set() };\n      this.atoms.set(atom, entry);\n    }\n    entry.count++;\n    entry.totalDuration += duration;\n    if (duration > entry.maxDuration) entry.maxDuration = duration;\n    if (!success) entry.errorCount++;\n    entry.lastCalled = Date.now();\n    entry.graphs.add(graphName);\n  }\n\n  getStats(): TelemetryStats[] {\n    const result: TelemetryStats[] = [];\n    for (const [atom, data] of this.atoms) {\n      result.push({\n        atom,\n        count: data.count,\n        avgDuration: data.count > 0 ? Math.round(data.totalDuration / data.count) : 0,\n        maxDuration: data.maxDuration,\n        errorCount: data.errorCount,\n        errorRate: data.count > 0 ? Math.round((data.errorCount / data.count) * 10000) / 100 : 0,\n        lastCalled: data.lastCalled,\n        graphs: Array.from(data.graphs),\n      });\n    }\n    result.sort((a, b) => b.count - a.count);\n    return result;\n  }\n\n  reset(): void {\n    this.atoms.clear();\n  }\n}\n\nclass AtomRegistryImpl implements AtomRegistry {\n  private atoms: Map<string, Atom> = new Map();\n\n  register(atom: Atom): void {\n    const key = `${atom.name}@${atom.version}`;\n    this.atoms.set(key, atom);\n    this.atoms.set(atom.name, atom);\n  }\n\n  get(name: string): Atom | undefined {\n    return this.atoms.get(name);\n  }\n\n  has(name: string): boolean {\n    return this.atoms.has(name);\n  }\n\n  list(): string[] {\n    const result: string[] = [];\n    const seen = new Set<string>();\n    \n    for (const [key, atom] of this.atoms.entries()) {\n      if (!seen.has(atom.name)) {\n        seen.add(atom.name);\n        result.push(atom.name);\n      }\n    }\n    \n    return result;\n  }\n}\n\nexport class AitosRuntime implements Runtime {\n  private atoms: Map<string, Atom> = new Map();\n  private telemetryStore: TelemetryStore = new TelemetryStore();\n  private telemetryHistory: TelemetrySnapshot[] = [];\n  private snapshotCallback?: (snapshot: TelemetrySnapshot) => void;\n\n  register(atom: Atom): void {\n    const key = `${atom.name}@${atom.version}`;\n    this.atoms.set(key, atom);\n    this.atoms.set(atom.name, atom);\n  }\n\n  validateGraph(graph: Graph): { valid: boolean; errors: string[] } {\n    const errors: GraphValidationError[] = [];\n    this.validateGraphNodes(graph.nodes, graph.order, errors);\n    return { valid: errors.length === 0, errors: errors.map(e => JSON.stringify(e)) };\n  }\n\n  private validateGraphNodes(nodes: Record<string, GraphNode>, order: string[], errors: GraphValidationError[], path: string = '', parentExecuted?: Set<string>): void {\n    const executed = parentExecuted ? new Set(parentExecuted) : new Set<string>();\n\n    for (const nodeId of order) {\n      const node = nodes[nodeId];\n      if (!node) {\n        errors.push({\n          node: path,\n          code: 'NODE_NOT_FOUND',\n          param: '',\n          ref: nodeId,\n          message: `Node \"${nodeId}\" not found in nodes`\n        });\n        continue;\n      }\n\n      const nodePath = path ? `${path}.${nodeId}` : nodeId;\n\n      if (!node.atom) {\n        errors.push({ node: nodePath, code: 'MISSING_ATOM', param: '', ref: '', message: 'Missing atom field' });\n        continue;\n      }\n\n      if (typeof node.atom !== 'string') {\n        errors.push({ node: nodePath, code: 'INVALID_ATOM_TYPE', param: '', ref: '', message: 'Atom must be a string' });\n        continue;\n      }\n\n      if (!this.atoms.has(node.atom)) {\n        errors.push({ node: nodePath, code: 'ATOM_NOT_FOUND', param: '', ref: '', message: `Atom \"${node.atom}\" not registered` });\n      }\n\n      this.validateGraphReferences(node, executed, errors, nodePath, nodes);\n\n      if (node.nodes && typeof node.nodes === 'object' && 'order' in node.nodes) {\n        const subGraph = node.nodes as Graph;\n        if (subGraph.nodes && subGraph.order) {\n          this.validateGraphNodes(subGraph.nodes, subGraph.order, errors, `${nodePath}.nodes`, executed);\n        }\n      }\n      if (node.then && typeof node.then === 'object' && 'order' in node.then) {\n        const subGraph = node.then as Graph;\n        if (subGraph.nodes && subGraph.order) {\n          this.validateGraphNodes(subGraph.nodes, subGraph.order, errors, `${nodePath}.then`, executed);\n        }\n      }\n      if (node.else && typeof node.else === 'object' && 'order' in node.else) {\n        const subGraph = node.else as Graph;\n        if (subGraph.nodes && subGraph.order) {\n          this.validateGraphNodes(subGraph.nodes, subGraph.order, errors, `${nodePath}.else`, executed);\n        }\n      }\n\n      executed.add(nodeId);\n    }\n  }\n\n  private validateGraphReferences(node: GraphNode, executed: Set<string>, errors: GraphValidationError[], nodePath: string, nodes: Record<string, GraphNode>): void {\n    for (const [key, value] of Object.entries(node)) {\n      if (['atom', 'nodes', 'then', 'else'].includes(key)) continue;\n\n      if (typeof value === 'string') {\n        const matches = value.matchAll(/\\{\\{(\\w+)(?:\\.(.+?))?\\}\\}/g);\n        for (const match of matches) {\n          const refId = match[1];\n          if (!executed.has(refId) && !nodes[refId]) {\n            const suggestions = this.generateGraphSuggestions(executed, nodes);\n            errors.push({\n              node: nodePath,\n              code: 'INVALID_REFERENCE',\n              param: key,\n              ref: refId,\n              message: `Invalid reference {{${refId}}}: node not found or not yet executed`,\n              suggestions\n            });\n          }\n        }\n      }\n    }\n  }\n\n  private generateGraphSuggestions(executed: Set<string>, nodes: Record<string, GraphNode>): GraphSuggestion[] {\n    const suggestions: GraphSuggestion[] = [];\n\n    for (const nodeId of executed) {\n      if (suggestions.length >= 5) break;\n      const node = nodes[nodeId];\n      if (node) {\n        const atom = this.atoms.get(node.atom);\n        suggestions.push({\n          id: nodeId,\n          type: atom?.meta.output.type || 'unknown',\n          source: node.atom\n        });\n      }\n    }\n\n    return suggestions;\n  }\n\n  async executeGraph(graph: Graph, context: Context, outerScope?: Record<string, any>, graphName?: string): Promise<Record<string, any>> {\n    const results: Record<string, any> = outerScope ? { ...outerScope } : {};\n    const gName = graphName || 'unknown';\n    \n    const previousScope = context.currentScope;\n    context.currentScope = results;\n    context.runtime = this;\n\n    for (const nodeId of graph.order) {\n      const node = graph.nodes[nodeId];\n      const input = this.resolveGraphInput(node, results, context);\n      const startTime = performance.now();\n      const result = await context.execute(node.atom, input);\n      const duration = Math.round(performance.now() - startTime);\n\n      this.telemetryStore.record(node.atom, gName, duration, result.success);\n\n      if (!result.success) {\n        context.currentScope = previousScope;\n        throw new Error(JSON.stringify({ node: nodeId, atom: node.atom, error: result.error }));\n      }\n\n      results[nodeId] = result.data;\n    }\n\n    context.currentScope = previousScope;\n\n    return results;\n  }\n\n  onSnapshot(callback: (snapshot: TelemetrySnapshot) => void): void {\n    this.snapshotCallback = callback;\n  }\n\n  flushTelemetry(): TelemetrySnapshot {\n    const stats = this.telemetryStore.getStats();\n    const snapshot: TelemetrySnapshot = { timestamp: Date.now(), stats };\n    this.telemetryHistory.push(snapshot);\n    if (this.telemetryHistory.length > 100) {\n      this.telemetryHistory.shift();\n    }\n    this.snapshotCallback?.(snapshot);\n    return snapshot;\n  }\n\n  getTelemetryHistory(): TelemetrySnapshot[] {\n    return this.telemetryHistory;\n  }\n\n  restoreTelemetryHistory(history: TelemetrySnapshot[]): void {\n    this.telemetryHistory = history.slice(-100);\n  }\n\n  private resolveGraphInput(node: GraphNode, results: Record<string, any>, context: Context): any {\n    const resolved: any = {};\n    const SUBGRAPH_KEYS = new Set(['nodes', 'then', 'else']);\n\n    for (const [key, value] of Object.entries(node)) {\n      if (key === 'atom') continue;\n      if (SUBGRAPH_KEYS.has(key)) {\n        resolved[key] = value;\n      } else {\n        resolved[key] = this.resolveGraphValue(value, results, context);\n      }\n    }\n\n    return resolved;\n  }\n\n  private resolveGraphValue(value: any, results: Record<string, any>, context: Context): any {\n    if (typeof value === 'string') {\n      const ESCAPE_PLACEHOLDER = '\\x00ESCAPED_BRACE\\x00';\n      let processedValue = value.replace(/\\\\{{/g, ESCAPE_PLACEHOLDER);\n\n      const match = processedValue.match(/^\\{\\{(\\w+)(?:\\.(.+?))?\\}\\}$/);\n      if (match) {\n        const nodeId = match[1];\n        const field = match[2];\n\n        let resolvedValue: any;\n        \n        if (nodeId in results) {\n          resolvedValue = results[nodeId];\n        } else if (context.store.has(nodeId)) {\n          resolvedValue = context.store.get(nodeId);\n        } else {\n          throw new Error(JSON.stringify({\n            code: 'REFERENCE_NOT_FOUND',\n            ref: nodeId,\n            message: `Reference {{${nodeId}}} not found in current scope or store`,\n            availableInScope: Object.keys(results),\n            availableInStore: context.store.has(nodeId) ? [nodeId] : [],\n            hint: 'Check if the reference is a node output or a store value.',\n            fix: `Ensure the node \"${nodeId}\" is executed before this reference, or use { \"atom\": \"set\", \"key\": \"${nodeId}\", \"value\": ... } to store the value.`\n          }));\n        }\n\n        if (field) {\n          return this.getFieldValue(resolvedValue, field);\n        }\n        return resolvedValue;\n      }\n\n      const result = processedValue.replace(/\\{\\{(\\w+)(?:\\.(.+?))?\\}\\}/g, (_, nodeId, field) => {\n        let resolvedValue: any;\n        \n        if (nodeId in results) {\n          resolvedValue = results[nodeId];\n        } else if (context.store.has(nodeId)) {\n          resolvedValue = context.store.get(nodeId);\n        } else {\n          throw new Error(JSON.stringify({\n            code: 'REFERENCE_NOT_FOUND',\n            ref: nodeId,\n            message: `Reference {{${nodeId}}} not found in current scope or store`,\n            availableInScope: Object.keys(results),\n            availableInStore: context.store.has(nodeId) ? [nodeId] : [],\n            hint: 'Check if the reference is a node output or a store value.',\n            fix: `Ensure the node \"${nodeId}\" is executed before this reference, or use { \"atom\": \"set\", \"key\": \"${nodeId}\", \"value\": ... } to store the value.`\n          }));\n        }\n        if (field) {\n          return this.getFieldValue(resolvedValue, field);\n        }\n        return resolvedValue;\n      });\n\n      return result.replace(new RegExp(ESCAPE_PLACEHOLDER, 'g'), '{{');\n    }\n\n    if (Array.isArray(value)) {\n      return value.map(item => this.resolveGraphValue(item, results, context));\n    }\n\n    if (typeof value === 'object' && value !== null) {\n      const resolved: any = {};\n      for (const [k, v] of Object.entries(value)) {\n        resolved[k] = this.resolveGraphValue(v, results, context);\n      }\n      return resolved;\n    }\n\n    return value;\n  }\n\n  private getFieldValue(obj: any, field: string): any {\n    const parts = field.split('.');\n    let current = obj;\n\n    for (const part of parts) {\n      if (current === undefined || current === null) return undefined;\n      current = current[part];\n    }\n\n    return current;\n  }\n\n  listAtoms(): Atom[] {\n    const result: Atom[] = [];\n    const seen = new Set<string>();\n\n    for (const [key, atom] of this.atoms.entries()) {\n      if (!seen.has(atom.name)) {\n        seen.add(atom.name);\n        result.push(atom);\n      }\n    }\n\n    return result;\n  }\n\n  getSkillSet(): string {\n    const atoms = this.listAtoms();\n\n    const registry = {\n      aitos: {\n        version: '1.0.0',\n        type: 'graph-instruction-set',\n      },\n      graph: {\n        format: {\n          nodes: 'Record<nodeId, GraphNode>',\n          order: 'string[] (execution order)'\n        },\n        example: {\n          nodes: {\n            getY: { atom: 'get', key: 'fruitY' },\n            addFive: { atom: 'add', a: '{{getY}}', b: 5 },\n            saveY: { atom: 'set', key: 'fruitY', value: '{{addFive}}' }\n          },\n          order: ['getY', 'addFive', 'saveY']\n        }\n      },\n      node: {\n        format: { atom: 'string', '...params': 'per atom.input' },\n        example: { atom: 'add', a: '{{otherNodeId}}', b: 1 }\n      },\n      ref: {\n        format: '{{nodeId}} or {{nodeId.field}}',\n        rules: [\n          'Use nodeId to reference another node result',\n          'nodeId must be defined in nodes and appear earlier in order',\n          'Use {{nodeId.field}} to access nested properties',\n          'References are resolved before execution'\n        ]\n      },\n      atoms: atoms.map(a => ({\n        name: a.name,\n        version: a.version,\n        input: a.meta.input,\n        output: a.meta.output,\n      })),\n      validation: {\n        description: 'Validation checks node references and atom existence',\n        errorFormat: {\n          node: 'Node path',\n          code: 'Error code',\n          param: 'Parameter name',\n          ref: 'Invalid reference',\n          message: 'Error description',\n          suggestions: [\n            { id: 'Suggested nodeId', type: 'Output type', source: 'Atom name' }\n          ]\n        }\n      }\n    };\n\n    return JSON.stringify(registry);\n  }\n\n  getTelemetryStats(): TelemetryStats[] {\n    return this.telemetryStore.getStats();\n  }\n\n  resetTelemetry(): void {\n    this.telemetryStore.reset();\n  }\n}\n\nexport { Store, AtomRegistryImpl, TelemetryStore };\nexport type { Atom, Context, Result, Graph, GraphNode, Scope, AtomRegistry, GraphValidationError, GraphSuggestion, Runtime, TelemetryStats, TelemetrySnapshot };\n"]}
@@ -0,0 +1,123 @@
1
+ export interface Atom {
2
+ name: string;
3
+ version: string;
4
+ meta: {
5
+ input: Array<{
6
+ name: string;
7
+ type: string;
8
+ description?: string;
9
+ }>;
10
+ output: {
11
+ type: string;
12
+ description?: string;
13
+ };
14
+ };
15
+ characteristics: {
16
+ stateless: boolean;
17
+ atomic: boolean;
18
+ composable: boolean;
19
+ };
20
+ execute: (input: any, context: Context) => Promise<Result>;
21
+ }
22
+ export interface Result {
23
+ success: boolean;
24
+ data?: any;
25
+ error?: string;
26
+ }
27
+ export interface GraphNode {
28
+ atom: string;
29
+ nodes?: Graph;
30
+ then?: Graph;
31
+ else?: Graph;
32
+ [key: string]: any;
33
+ }
34
+ export type GraphMode = 'kernel' | 'user';
35
+ export interface GraphInterface {
36
+ input: Array<{
37
+ name: string;
38
+ type: string;
39
+ description?: string;
40
+ }>;
41
+ output: {
42
+ type: string;
43
+ description?: string;
44
+ };
45
+ }
46
+ export interface Graph {
47
+ mode?: GraphMode;
48
+ _meta?: {
49
+ description?: string;
50
+ type?: string;
51
+ category?: string;
52
+ author?: string;
53
+ };
54
+ interface?: GraphInterface;
55
+ order: string[];
56
+ nodes: Record<string, GraphNode>;
57
+ }
58
+ export interface Scope {
59
+ [key: string]: any;
60
+ }
61
+ export interface Context {
62
+ store: {
63
+ get: (key: string) => any;
64
+ set: (key: string, value: any) => void;
65
+ has: (key: string) => boolean;
66
+ delete: (key: string) => void;
67
+ clear: () => void;
68
+ keys: () => IterableIterator<string>;
69
+ };
70
+ currentScope: Scope;
71
+ execute: (atomName: string, input: any) => Promise<Result>;
72
+ executeGraph?: (graph: Graph, scope?: Scope, graphName?: string) => Promise<Record<string, any>>;
73
+ runtime?: Runtime;
74
+ }
75
+ export interface AtomRegistry {
76
+ register: (atom: Atom) => void;
77
+ get: (name: string) => Atom | undefined;
78
+ has: (name: string) => boolean;
79
+ list: () => string[];
80
+ }
81
+ export interface GraphValidationError {
82
+ node: string;
83
+ code: string;
84
+ param: string;
85
+ ref: string;
86
+ message: string;
87
+ suggestions?: GraphSuggestion[];
88
+ }
89
+ export interface GraphSuggestion {
90
+ id: string;
91
+ type: string;
92
+ source: string;
93
+ }
94
+ export interface TelemetrySnapshot {
95
+ timestamp: number;
96
+ stats: TelemetryStats[];
97
+ }
98
+ export interface Runtime {
99
+ register(atom: Atom): void;
100
+ validateGraph(graph: Graph): {
101
+ valid: boolean;
102
+ errors: string[];
103
+ };
104
+ executeGraph(graph: Graph, context: Context, outerScope?: Record<string, any>, graphName?: string): Promise<Record<string, any>>;
105
+ listAtoms(): Atom[];
106
+ getSkillSet(): string;
107
+ getTelemetryStats(): TelemetryStats[];
108
+ resetTelemetry(): void;
109
+ onSnapshot(callback: (snapshot: TelemetrySnapshot) => void): void;
110
+ flushTelemetry(): TelemetrySnapshot;
111
+ getTelemetryHistory(): TelemetrySnapshot[];
112
+ restoreTelemetryHistory(history: TelemetrySnapshot[]): void;
113
+ }
114
+ export interface TelemetryStats {
115
+ atom: string;
116
+ count: number;
117
+ avgDuration: number;
118
+ maxDuration: number;
119
+ errorCount: number;
120
+ errorRate: number;
121
+ lastCalled: number;
122
+ graphs: string[];
123
+ }
package/dist/types.js ADDED
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQXRvbSB7XG4gIG5hbWU6IHN0cmluZztcbiAgdmVyc2lvbjogc3RyaW5nO1xuICBtZXRhOiB7XG4gICAgaW5wdXQ6IEFycmF5PHsgbmFtZTogc3RyaW5nOyB0eXBlOiBzdHJpbmc7IGRlc2NyaXB0aW9uPzogc3RyaW5nIH0+O1xuICAgIG91dHB1dDogeyB0eXBlOiBzdHJpbmc7IGRlc2NyaXB0aW9uPzogc3RyaW5nIH07XG4gIH07XG4gIGNoYXJhY3RlcmlzdGljczoge1xuICAgIHN0YXRlbGVzczogYm9vbGVhbjtcbiAgICBhdG9taWM6IGJvb2xlYW47XG4gICAgY29tcG9zYWJsZTogYm9vbGVhbjtcbiAgfTtcbiAgZXhlY3V0ZTogKGlucHV0OiBhbnksIGNvbnRleHQ6IENvbnRleHQpID0+IFByb21pc2U8UmVzdWx0Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSZXN1bHQge1xuICBzdWNjZXNzOiBib29sZWFuO1xuICBkYXRhPzogYW55O1xuICBlcnJvcj86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBHcmFwaE5vZGUge1xuICBhdG9tOiBzdHJpbmc7XG4gIG5vZGVzPzogR3JhcGg7XG4gIHRoZW4/OiBHcmFwaDtcbiAgZWxzZT86IEdyYXBoO1xuICBba2V5OiBzdHJpbmddOiBhbnk7XG59XG5cbmV4cG9ydCB0eXBlIEdyYXBoTW9kZSA9ICdrZXJuZWwnIHwgJ3VzZXInO1xuXG5leHBvcnQgaW50ZXJmYWNlIEdyYXBoSW50ZXJmYWNlIHtcbiAgaW5wdXQ6IEFycmF5PHsgbmFtZTogc3RyaW5nOyB0eXBlOiBzdHJpbmc7IGRlc2NyaXB0aW9uPzogc3RyaW5nIH0+O1xuICBvdXRwdXQ6IHsgdHlwZTogc3RyaW5nOyBkZXNjcmlwdGlvbj86IHN0cmluZyB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdyYXBoIHtcbiAgbW9kZT86IEdyYXBoTW9kZTtcbiAgX21ldGE/OiB7IGRlc2NyaXB0aW9uPzogc3RyaW5nOyB0eXBlPzogc3RyaW5nOyBjYXRlZ29yeT86IHN0cmluZzsgYXV0aG9yPzogc3RyaW5nIH07XG4gIGludGVyZmFjZT86IEdyYXBoSW50ZXJmYWNlO1xuICBvcmRlcjogc3RyaW5nW107XG4gIG5vZGVzOiBSZWNvcmQ8c3RyaW5nLCBHcmFwaE5vZGU+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjb3BlIHtcbiAgW2tleTogc3RyaW5nXTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRleHQge1xuICBzdG9yZToge1xuICAgIGdldDogKGtleTogc3RyaW5nKSA9PiBhbnk7XG4gICAgc2V0OiAoa2V5OiBzdHJpbmcsIHZhbHVlOiBhbnkpID0+IHZvaWQ7XG4gICAgaGFzOiAoa2V5OiBzdHJpbmcpID0+IGJvb2xlYW47XG4gICAgZGVsZXRlOiAoa2V5OiBzdHJpbmcpID0+IHZvaWQ7XG4gICAgY2xlYXI6ICgpID0+IHZvaWQ7XG4gICAga2V5czogKCkgPT4gSXRlcmFibGVJdGVyYXRvcjxzdHJpbmc+O1xuICB9O1xuICBjdXJyZW50U2NvcGU6IFNjb3BlO1xuICBleGVjdXRlOiAoYXRvbU5hbWU6IHN0cmluZywgaW5wdXQ6IGFueSkgPT4gUHJvbWlzZTxSZXN1bHQ+O1xuICBleGVjdXRlR3JhcGg/OiAoZ3JhcGg6IEdyYXBoLCBzY29wZT86IFNjb3BlLCBncmFwaE5hbWU/OiBzdHJpbmcpID0+IFByb21pc2U8UmVjb3JkPHN0cmluZywgYW55Pj47XG4gIHJ1bnRpbWU/OiBSdW50aW1lO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEF0b21SZWdpc3RyeSB7XG4gIHJlZ2lzdGVyOiAoYXRvbTogQXRvbSkgPT4gdm9pZDtcbiAgZ2V0OiAobmFtZTogc3RyaW5nKSA9PiBBdG9tIHwgdW5kZWZpbmVkO1xuICBoYXM6IChuYW1lOiBzdHJpbmcpID0+IGJvb2xlYW47XG4gIGxpc3Q6ICgpID0+IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdyYXBoVmFsaWRhdGlvbkVycm9yIHtcbiAgbm9kZTogc3RyaW5nO1xuICBjb2RlOiBzdHJpbmc7XG4gIHBhcmFtOiBzdHJpbmc7XG4gIHJlZjogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIHN1Z2dlc3Rpb25zPzogR3JhcGhTdWdnZXN0aW9uW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgR3JhcGhTdWdnZXN0aW9uIHtcbiAgaWQ6IHN0cmluZztcbiAgdHlwZTogc3RyaW5nO1xuICBzb3VyY2U6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUZWxlbWV0cnlTbmFwc2hvdCB7XG4gIHRpbWVzdGFtcDogbnVtYmVyO1xuICBzdGF0czogVGVsZW1ldHJ5U3RhdHNbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSdW50aW1lIHtcbiAgcmVnaXN0ZXIoYXRvbTogQXRvbSk6IHZvaWQ7XG4gIHZhbGlkYXRlR3JhcGgoZ3JhcGg6IEdyYXBoKTogeyB2YWxpZDogYm9vbGVhbjsgZXJyb3JzOiBzdHJpbmdbXSB9O1xuICBleGVjdXRlR3JhcGgoZ3JhcGg6IEdyYXBoLCBjb250ZXh0OiBDb250ZXh0LCBvdXRlclNjb3BlPzogUmVjb3JkPHN0cmluZywgYW55PiwgZ3JhcGhOYW1lPzogc3RyaW5nKTogUHJvbWlzZTxSZWNvcmQ8c3RyaW5nLCBhbnk+PjtcbiAgbGlzdEF0b21zKCk6IEF0b21bXTtcbiAgZ2V0U2tpbGxTZXQoKTogc3RyaW5nO1xuICBnZXRUZWxlbWV0cnlTdGF0cygpOiBUZWxlbWV0cnlTdGF0c1tdO1xuICByZXNldFRlbGVtZXRyeSgpOiB2b2lkO1xuICBvblNuYXBzaG90KGNhbGxiYWNrOiAoc25hcHNob3Q6IFRlbGVtZXRyeVNuYXBzaG90KSA9PiB2b2lkKTogdm9pZDtcbiAgZmx1c2hUZWxlbWV0cnkoKTogVGVsZW1ldHJ5U25hcHNob3Q7XG4gIGdldFRlbGVtZXRyeUhpc3RvcnkoKTogVGVsZW1ldHJ5U25hcHNob3RbXTtcbiAgcmVzdG9yZVRlbGVtZXRyeUhpc3RvcnkoaGlzdG9yeTogVGVsZW1ldHJ5U25hcHNob3RbXSk6IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGVsZW1ldHJ5U3RhdHMge1xuICBhdG9tOiBzdHJpbmc7XG4gIGNvdW50OiBudW1iZXI7XG4gIGF2Z0R1cmF0aW9uOiBudW1iZXI7XG4gIG1heER1cmF0aW9uOiBudW1iZXI7XG4gIGVycm9yQ291bnQ6IG51bWJlcjtcbiAgZXJyb3JSYXRlOiBudW1iZXI7XG4gIGxhc3RDYWxsZWQ6IG51bWJlcjtcbiAgZ3JhcGhzOiBzdHJpbmdbXTtcbn1cbiJdfQ==
package/package.json CHANGED
@@ -1,13 +1,27 @@
1
1
  {
2
2
  "name": "@aitos/core",
3
- "version": "1.0.0",
4
- "description": "AI-Native Application Framework - Build apps with atomic composition and graph execution",
5
- "main": "index.js",
3
+ "version": "1.0.1",
4
+ "description": "AITOS Core Package - AI-friendly atomic architecture based on capability dimensions",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
6
7
  "scripts": {
7
- "test": "echo \"Error: no test specified\" && exit 1"
8
+ "build": "tsc",
9
+ "dev": "tsc --watch"
8
10
  },
9
- "keywords": ["ai", "framework", "atomic", "graph-execution", "cross-platform"],
10
- "author": "",
11
+ "keywords": [
12
+ "aitos",
13
+ "atomic",
14
+ "architecture",
15
+ "ai-friendly",
16
+ "capability-based"
17
+ ],
18
+ "author": "AITOS Team",
11
19
  "license": "MIT",
12
- "type": "commonjs"
20
+ "files": [
21
+ "dist"
22
+ ],
23
+ "devDependencies": {
24
+ "@types/node": "^20.0.0",
25
+ "typescript": "^5.9.3"
26
+ }
13
27
  }