@aitos/transfer 1.0.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.
@@ -0,0 +1,3 @@
1
+ export * from './network';
2
+ import { Atom } from '@aitos/core';
3
+ export declare const allAtoms: Atom[];
package/dist/index.js ADDED
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.allAtoms = void 0;
18
+ __exportStar(require("./network"), exports);
19
+ const network_1 = require("./network");
20
+ exports.allAtoms = [
21
+ network_1.httpRequestAtom,
22
+ network_1.httpStreamRequestAtom,
23
+ ];
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDRDQUEwQjtBQUcxQix1Q0FHbUI7QUFFTixRQUFBLFFBQVEsR0FBVztJQUM5Qix5QkFBZTtJQUNmLCtCQUFxQjtDQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9uZXR3b3JrJztcblxuaW1wb3J0IHsgQXRvbSB9IGZyb20gJ0BhaXRvcy9jb3JlJztcbmltcG9ydCB7XG4gIGh0dHBSZXF1ZXN0QXRvbSxcbiAgaHR0cFN0cmVhbVJlcXVlc3RBdG9tLFxufSBmcm9tICcuL25ldHdvcmsnO1xuXG5leHBvcnQgY29uc3QgYWxsQXRvbXM6IEF0b21bXSA9IFtcbiAgaHR0cFJlcXVlc3RBdG9tLFxuICBodHRwU3RyZWFtUmVxdWVzdEF0b20sXG5dO1xuIl19
@@ -0,0 +1,3 @@
1
+ import { Atom } from '@aitos/core';
2
+ export declare const httpRequestAtom: Atom;
3
+ export declare const httpStreamRequestAtom: Atom;
@@ -0,0 +1,133 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.httpStreamRequestAtom = exports.httpRequestAtom = void 0;
4
+ exports.httpRequestAtom = {
5
+ name: 'httpRequest',
6
+ version: '1.0.0',
7
+ meta: {
8
+ input: [
9
+ { name: 'url', type: 'string', description: 'Request URL' },
10
+ { name: 'method', type: 'string', description: 'HTTP method (GET, POST, PUT, DELETE)' },
11
+ { name: 'body', type: 'any', description: 'Request body' },
12
+ { name: 'headers', type: 'object', description: 'Request headers' }
13
+ ],
14
+ output: { type: 'object', description: 'Response data' }
15
+ },
16
+ characteristics: { stateless: true, atomic: true, composable: true },
17
+ execute: async (input, context) => {
18
+ try {
19
+ const options = {
20
+ method: input.method,
21
+ headers: input.headers,
22
+ };
23
+ if (input.body) {
24
+ options.body = JSON.stringify(input.body);
25
+ if (!input.headers) {
26
+ options.headers = { 'Content-Type': 'application/json' };
27
+ }
28
+ }
29
+ const response = await fetch(input.url, options);
30
+ const data = await response.json();
31
+ return { success: true, data };
32
+ }
33
+ catch (error) {
34
+ return { success: false, error: `HTTP request failed: ${error}` };
35
+ }
36
+ },
37
+ };
38
+ exports.httpStreamRequestAtom = {
39
+ name: 'httpStreamRequest',
40
+ version: '1.3.0',
41
+ meta: {
42
+ input: [
43
+ { name: 'url', type: 'string', description: 'Request URL' },
44
+ { name: 'method', type: 'string', description: 'HTTP method' },
45
+ { name: 'body', type: 'any', description: 'Request body' },
46
+ { name: 'headers', type: 'object', description: 'Request headers' },
47
+ { name: 'elementId', type: 'string', description: 'Element ID for streaming display (optional)' }
48
+ ],
49
+ output: { type: 'object', description: '{ role, content, toolCalls }' }
50
+ },
51
+ characteristics: { stateless: true, atomic: true, composable: true },
52
+ execute: async (input, context) => {
53
+ try {
54
+ const options = {
55
+ method: input.method,
56
+ headers: {
57
+ 'Content-Type': 'application/json',
58
+ ...input.headers
59
+ },
60
+ body: JSON.stringify(input.body)
61
+ };
62
+ const response = await fetch(input.url, options);
63
+ if (!response.ok) {
64
+ return { success: false, error: `HTTP error: ${response.status}` };
65
+ }
66
+ const reader = response.body?.getReader();
67
+ if (!reader) {
68
+ return { success: false, error: 'Stream not available' };
69
+ }
70
+ const decoder = new TextDecoder();
71
+ let fullContent = '';
72
+ let toolCalls = [];
73
+ let streamElement = null;
74
+ if (input.elementId && typeof document !== 'undefined') {
75
+ streamElement = document.getElementById(input.elementId);
76
+ }
77
+ while (true) {
78
+ const { done, value } = await reader.read();
79
+ if (done)
80
+ break;
81
+ const chunk = decoder.decode(value, { stream: true });
82
+ const lines = chunk.split('\n');
83
+ for (const line of lines) {
84
+ if (line.startsWith('data: ')) {
85
+ const data = line.slice(6).trim();
86
+ if (data === '[DONE]')
87
+ continue;
88
+ try {
89
+ const json = JSON.parse(data);
90
+ const delta = json.choices?.[0]?.delta;
91
+ if (delta?.content) {
92
+ fullContent += delta.content;
93
+ if (streamElement) {
94
+ streamElement.textContent = fullContent;
95
+ }
96
+ }
97
+ if (delta?.tool_calls) {
98
+ for (const tc of delta.tool_calls) {
99
+ const index = tc.index;
100
+ if (!toolCalls[index]) {
101
+ toolCalls[index] = {
102
+ id: tc.id,
103
+ type: tc.type,
104
+ function: {
105
+ name: tc.function?.name || '',
106
+ arguments: ''
107
+ }
108
+ };
109
+ }
110
+ if (tc.function?.arguments) {
111
+ toolCalls[index].function.arguments += tc.function.arguments;
112
+ }
113
+ }
114
+ }
115
+ }
116
+ catch (e) {
117
+ // Ignore parse errors
118
+ }
119
+ }
120
+ }
121
+ }
122
+ const aiResponse = { role: 'assistant', content: fullContent };
123
+ if (toolCalls.length > 0) {
124
+ aiResponse.toolCalls = toolCalls;
125
+ }
126
+ return { success: true, data: aiResponse };
127
+ }
128
+ catch (error) {
129
+ return { success: false, error: `Stream request failed: ${error}` };
130
+ }
131
+ },
132
+ };
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network.js","sourceRoot":"","sources":["../network.ts"],"names":[],"mappings":";;;AAEa,QAAA,eAAe,GAAS;IACnC,IAAI,EAAE,aAAa;IACnB,OAAO,EAAE,OAAO;IAChB,IAAI,EAAE;QACJ,KAAK,EAAE;YACL,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE;YAC3D,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,sCAAsC,EAAE;YACvF,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE;YAC1D,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,iBAAiB,EAAE;SACpE;QACD,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,eAAe,EAAE;KACzD;IACD,eAAe,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE;IACpE,OAAO,EAAE,KAAK,EAAE,KAKf,EAAE,OAAgB,EAAmB,EAAE;QACtC,IAAI,CAAC;YACH,MAAM,OAAO,GAAgB;gBAC3B,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,OAAO,EAAE,KAAK,CAAC,OAAO;aACvB,CAAC;YAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;gBAC1C,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;oBACnB,OAAO,CAAC,OAAO,GAAG,EAAE,cAAc,EAAE,kBAAkB,EAAE,CAAC;gBAC3D,CAAC;YACH,CAAC;YAED,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YACjD,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACnC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QACjC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,wBAAwB,KAAK,EAAE,EAAE,CAAC;QACpE,CAAC;IACH,CAAC;CACF,CAAC;AAEW,QAAA,qBAAqB,GAAS;IACzC,IAAI,EAAE,mBAAmB;IACzB,OAAO,EAAE,OAAO;IAChB,IAAI,EAAE;QACJ,KAAK,EAAE;YACL,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE;YAC3D,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE;YAC9D,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE;YAC1D,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,iBAAiB,EAAE;YACnE,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,6CAA6C,EAAE;SAClG;QACD,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,8BAA8B,EAAE;KACxE;IACD,eAAe,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE;IACpE,OAAO,EAAE,KAAK,EAAE,KAMf,EAAE,OAAgB,EAAmB,EAAE;QACtC,IAAI,CAAC;YACH,MAAM,OAAO,GAAgB;gBAC3B,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,OAAO,EAAE;oBACP,cAAc,EAAE,kBAAkB;oBAClC,GAAG,KAAK,CAAC,OAAO;iBACjB;gBACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC;aACjC,CAAC;YAEF,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YAEjD,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;gBACjB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,eAAe,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC;YACrE,CAAC;YAED,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,CAAC;YAE1C,IAAI,CAAC,MAAM,EAAE,CAAC;gBACZ,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,sBAAsB,EAAE,CAAC;YAC3D,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;YAClC,IAAI,WAAW,GAAG,EAAE,CAAC;YACrB,IAAI,SAAS,GAAU,EAAE,CAAC;YAE1B,IAAI,aAAa,GAAuB,IAAI,CAAC;YAC7C,IAAI,KAAK,CAAC,SAAS,IAAI,OAAO,QAAQ,KAAK,WAAW,EAAE,CAAC;gBACvD,aAAa,GAAG,QAAQ,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC3D,CAAC;YAED,OAAO,IAAI,EAAE,CAAC;gBACZ,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,CAAC;gBAE5C,IAAI,IAAI;oBAAE,MAAM;gBAEhB,MAAM,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;gBAEtD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;gBAEhC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;oBACzB,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;wBAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;wBAElC,IAAI,IAAI,KAAK,QAAQ;4BAAE,SAAS;wBAEhC,IAAI,CAAC;4BACH,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;4BAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC;4BAEvC,IAAI,KAAK,EAAE,OAAO,EAAE,CAAC;gCACnB,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC;gCAE7B,IAAI,aAAa,EAAE,CAAC;oCAClB,aAAa,CAAC,WAAW,GAAG,WAAW,CAAC;gCAC1C,CAAC;4BACH,CAAC;4BAED,IAAI,KAAK,EAAE,UAAU,EAAE,CAAC;gCACtB,KAAK,MAAM,EAAE,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;oCAClC,MAAM,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC;oCACvB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;wCACtB,SAAS,CAAC,KAAK,CAAC,GAAG;4CACjB,EAAE,EAAE,EAAE,CAAC,EAAE;4CACT,IAAI,EAAE,EAAE,CAAC,IAAI;4CACb,QAAQ,EAAE;gDACR,IAAI,EAAE,EAAE,CAAC,QAAQ,EAAE,IAAI,IAAI,EAAE;gDAC7B,SAAS,EAAE,EAAE;6CACd;yCACF,CAAC;oCACJ,CAAC;oCACD,IAAI,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,CAAC;wCAC3B,SAAS,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,SAAS,IAAI,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC;oCAC/D,CAAC;gCACH,CAAC;4BACH,CAAC;wBACH,CAAC;wBAAC,OAAO,CAAC,EAAE,CAAC;4BACX,sBAAsB;wBACxB,CAAC;oBACH,CAAC;gBACH,CAAC;YACH,CAAC;YAED,MAAM,UAAU,GAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC;YAEpE,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzB,UAAU,CAAC,SAAS,GAAG,SAAS,CAAC;YACnC,CAAC;YAED,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;QAC7C,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,0BAA0B,KAAK,EAAE,EAAE,CAAC;QACtE,CAAC;IACH,CAAC;CACF,CAAC","sourcesContent":["import { Atom, Context, Result } from '@aitos/core';\n\nexport const httpRequestAtom: Atom = {\n  name: 'httpRequest',\n  version: '1.0.0',\n  meta: {\n    input: [\n      { name: 'url', type: 'string', description: 'Request URL' },\n      { name: 'method', type: 'string', description: 'HTTP method (GET, POST, PUT, DELETE)' },\n      { name: 'body', type: 'any', description: 'Request body' },\n      { name: 'headers', type: 'object', description: 'Request headers' }\n    ],\n    output: { type: 'object', description: 'Response data' }\n  },\n  characteristics: { stateless: true, atomic: true, composable: true },\n  execute: async (input: { \n    url: string; \n    method: string; \n    body?: any; \n    headers?: Record<string, string> \n  }, context: Context): Promise<Result> => {\n    try {\n      const options: RequestInit = {\n        method: input.method,\n        headers: input.headers,\n      };\n      \n      if (input.body) {\n        options.body = JSON.stringify(input.body);\n        if (!input.headers) {\n          options.headers = { 'Content-Type': 'application/json' };\n        }\n      }\n      \n      const response = await fetch(input.url, options);\n      const data = await response.json();\n      return { success: true, data };\n    } catch (error) {\n      return { success: false, error: `HTTP request failed: ${error}` };\n    }\n  },\n};\n\nexport const httpStreamRequestAtom: Atom = {\n  name: 'httpStreamRequest',\n  version: '1.3.0',\n  meta: {\n    input: [\n      { name: 'url', type: 'string', description: 'Request URL' },\n      { name: 'method', type: 'string', description: 'HTTP method' },\n      { name: 'body', type: 'any', description: 'Request body' },\n      { name: 'headers', type: 'object', description: 'Request headers' },\n      { name: 'elementId', type: 'string', description: 'Element ID for streaming display (optional)' }\n    ],\n    output: { type: 'object', description: '{ role, content, toolCalls }' }\n  },\n  characteristics: { stateless: true, atomic: true, composable: true },\n  execute: async (input: { \n    url: string; \n    method: string; \n    body?: any; \n    headers?: Record<string, string>;\n    elementId?: string;\n  }, context: Context): Promise<Result> => {\n    try {\n      const options: RequestInit = {\n        method: input.method,\n        headers: {\n          'Content-Type': 'application/json',\n          ...input.headers\n        },\n        body: JSON.stringify(input.body)\n      };\n      \n      const response = await fetch(input.url, options);\n      \n      if (!response.ok) {\n        return { success: false, error: `HTTP error: ${response.status}` };\n      }\n      \n      const reader = response.body?.getReader();\n      \n      if (!reader) {\n        return { success: false, error: 'Stream not available' };\n      }\n      \n      const decoder = new TextDecoder();\n      let fullContent = '';\n      let toolCalls: any[] = [];\n      \n      let streamElement: HTMLElement | null = null;\n      if (input.elementId && typeof document !== 'undefined') {\n        streamElement = document.getElementById(input.elementId);\n      }\n      \n      while (true) {\n        const { done, value } = await reader.read();\n        \n        if (done) break;\n        \n        const chunk = decoder.decode(value, { stream: true });\n        \n        const lines = chunk.split('\\n');\n        \n        for (const line of lines) {\n          if (line.startsWith('data: ')) {\n            const data = line.slice(6).trim();\n            \n            if (data === '[DONE]') continue;\n            \n            try {\n              const json = JSON.parse(data);\n              const delta = json.choices?.[0]?.delta;\n              \n              if (delta?.content) {\n                fullContent += delta.content;\n                \n                if (streamElement) {\n                  streamElement.textContent = fullContent;\n                }\n              }\n              \n              if (delta?.tool_calls) {\n                for (const tc of delta.tool_calls) {\n                  const index = tc.index;\n                  if (!toolCalls[index]) {\n                    toolCalls[index] = {\n                      id: tc.id,\n                      type: tc.type,\n                      function: {\n                        name: tc.function?.name || '',\n                        arguments: ''\n                      }\n                    };\n                  }\n                  if (tc.function?.arguments) {\n                    toolCalls[index].function.arguments += tc.function.arguments;\n                  }\n                }\n              }\n            } catch (e) {\n              // Ignore parse errors\n            }\n          }\n        }\n      }\n      \n      const aiResponse: any = { role: 'assistant', content: fullContent };\n      \n      if (toolCalls.length > 0) {\n        aiResponse.toolCalls = toolCalls;\n      }\n      \n      return { success: true, data: aiResponse };\n    } catch (error) {\n      return { success: false, error: `Stream request failed: ${error}` };\n    }\n  },\n};\n"]}
package/package.json ADDED
@@ -0,0 +1,31 @@
1
+ {
2
+ "name": "@aitos/transfer",
3
+ "version": "1.0.0",
4
+ "description": "AITOS Transfer Capability Package - Network and IPC transfer atoms",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "scripts": {
8
+ "build": "tsc",
9
+ "dev": "tsc --watch"
10
+ },
11
+ "keywords": [
12
+ "aitos",
13
+ "transfer",
14
+ "network",
15
+ "ipc",
16
+ "capability"
17
+ ],
18
+ "author": "AITOS Team",
19
+ "license": "MIT",
20
+ "files": [
21
+ "dist"
22
+ ],
23
+ "peerDependencies": {
24
+ "@aitos/core": "^1.0.0"
25
+ },
26
+ "devDependencies": {
27
+ "@aitos/core": "file:../../../aitos",
28
+ "@types/node": "^20.0.0",
29
+ "typescript": "^5.0.0"
30
+ }
31
+ }