@cloudbase/ai 2.8.20-beta.0 → 2.8.22-beta.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.
Files changed (106) hide show
  1. package/dist/cjs/AI.d.ts +27 -0
  2. package/dist/cjs/AI.js +154 -0
  3. package/dist/cjs/index.d.ts +13 -38
  4. package/dist/cjs/index.js +9 -73
  5. package/dist/cjs/models/Ark/index.d.ts +4 -18
  6. package/dist/cjs/models/Ark/index.js +45 -82
  7. package/dist/cjs/models/Ark/type.d.ts +52 -19
  8. package/dist/cjs/models/Ark/type.js +1 -1
  9. package/dist/cjs/models/DashScope/index.d.ts +4 -18
  10. package/dist/cjs/models/DashScope/index.js +45 -82
  11. package/dist/cjs/models/DashScope/type.d.ts +55 -24
  12. package/dist/cjs/models/DashScope/type.js +1 -1
  13. package/dist/cjs/models/HunYuan/index.d.ts +4 -19
  14. package/dist/cjs/models/HunYuan/index.js +47 -107
  15. package/dist/cjs/models/HunYuan/type.d.ts +68 -48
  16. package/dist/cjs/models/HunYuan/type.js +1 -1
  17. package/dist/cjs/models/HunYuan/util.d.ts +4 -0
  18. package/dist/cjs/models/HunYuan/util.js +58 -0
  19. package/dist/cjs/models/HunYuanBeta/index.d.ts +4 -19
  20. package/dist/cjs/models/HunYuanBeta/index.js +42 -110
  21. package/dist/cjs/models/Moonshot/index.d.ts +4 -18
  22. package/dist/cjs/models/Moonshot/index.js +45 -82
  23. package/dist/cjs/models/Moonshot/type.d.ts +63 -9
  24. package/dist/cjs/models/Moonshot/type.js +1 -1
  25. package/dist/cjs/models/Yi/index.d.ts +4 -18
  26. package/dist/cjs/models/Yi/index.js +48 -82
  27. package/dist/cjs/models/Yi/type.d.ts +41 -15
  28. package/dist/cjs/models/Yi/type.js +1 -1
  29. package/dist/cjs/models/ZhiPu/index.d.ts +4 -18
  30. package/dist/cjs/models/ZhiPu/index.js +59 -87
  31. package/dist/cjs/models/ZhiPu/type.d.ts +19 -19
  32. package/dist/cjs/models/ZhiPu/type.js +1 -1
  33. package/dist/cjs/models/index.d.ts +16 -15
  34. package/dist/cjs/models/index.js +26 -23
  35. package/dist/cjs/models/model.d.ts +38 -0
  36. package/dist/cjs/models/model.js +481 -0
  37. package/dist/cjs/type.d.ts +76 -15
  38. package/dist/cjs/type.js +6 -12
  39. package/dist/cjs/utils.d.ts +9 -1
  40. package/dist/cjs/utils.js +46 -2
  41. package/dist/esm/AI.d.ts +27 -0
  42. package/dist/esm/AI.js +128 -0
  43. package/dist/esm/index.d.ts +13 -38
  44. package/dist/esm/index.js +4 -70
  45. package/dist/esm/models/Ark/index.d.ts +4 -18
  46. package/dist/esm/models/Ark/index.js +45 -82
  47. package/dist/esm/models/Ark/type.d.ts +52 -19
  48. package/dist/esm/models/Ark/type.js +1 -1
  49. package/dist/esm/models/DashScope/index.d.ts +4 -18
  50. package/dist/esm/models/DashScope/index.js +45 -82
  51. package/dist/esm/models/DashScope/type.d.ts +55 -24
  52. package/dist/esm/models/DashScope/type.js +1 -1
  53. package/dist/esm/models/HunYuan/index.d.ts +4 -19
  54. package/dist/esm/models/HunYuan/index.js +47 -107
  55. package/dist/esm/models/HunYuan/type.d.ts +68 -48
  56. package/dist/esm/models/HunYuan/type.js +1 -1
  57. package/dist/esm/models/HunYuan/util.d.ts +4 -0
  58. package/dist/esm/models/HunYuan/util.js +53 -0
  59. package/dist/esm/models/HunYuanBeta/index.d.ts +4 -19
  60. package/dist/esm/models/HunYuanBeta/index.js +42 -110
  61. package/dist/esm/models/Moonshot/index.d.ts +4 -18
  62. package/dist/esm/models/Moonshot/index.js +45 -82
  63. package/dist/esm/models/Moonshot/type.d.ts +63 -9
  64. package/dist/esm/models/Moonshot/type.js +1 -1
  65. package/dist/esm/models/Yi/index.d.ts +4 -18
  66. package/dist/esm/models/Yi/index.js +48 -82
  67. package/dist/esm/models/Yi/type.d.ts +41 -15
  68. package/dist/esm/models/Yi/type.js +1 -1
  69. package/dist/esm/models/ZhiPu/index.d.ts +4 -18
  70. package/dist/esm/models/ZhiPu/index.js +59 -87
  71. package/dist/esm/models/ZhiPu/type.d.ts +19 -19
  72. package/dist/esm/models/ZhiPu/type.js +1 -1
  73. package/dist/esm/models/index.d.ts +16 -15
  74. package/dist/esm/models/index.js +17 -16
  75. package/dist/esm/models/model.d.ts +38 -0
  76. package/dist/esm/models/model.js +478 -0
  77. package/dist/esm/type.d.ts +76 -15
  78. package/dist/esm/type.js +5 -11
  79. package/dist/esm/utils.d.ts +9 -1
  80. package/dist/esm/utils.js +41 -1
  81. package/package.json +3 -3
  82. package/src/AI.ts +77 -0
  83. package/src/index.ts +3 -60
  84. package/src/models/Ark/index.ts +52 -54
  85. package/src/models/Ark/type.ts +60 -19
  86. package/src/models/DashScope/index.ts +56 -55
  87. package/src/models/DashScope/type.ts +63 -21
  88. package/src/models/HunYuan/index.ts +44 -67
  89. package/src/models/HunYuan/type.ts +68 -46
  90. package/src/models/HunYuan/util.ts +59 -0
  91. package/src/models/HunYuanBeta/index.ts +41 -75
  92. package/src/models/Moonshot/index.ts +52 -54
  93. package/src/models/Moonshot/type.ts +61 -7
  94. package/src/models/Yi/index.ts +59 -55
  95. package/src/models/Yi/type.ts +47 -19
  96. package/src/models/ZhiPu/index.ts +60 -52
  97. package/src/models/ZhiPu/type.ts +20 -9
  98. package/src/models/index.ts +25 -15
  99. package/src/models/model.ts +415 -0
  100. package/src/type.ts +100 -13
  101. package/src/utils.ts +53 -1
  102. package/dist/cjs/models/HunYuanBeta/type.d.ts +0 -52
  103. package/dist/cjs/models/HunYuanBeta/type.js +0 -3
  104. package/dist/esm/models/HunYuanBeta/type.d.ts +0 -52
  105. package/dist/esm/models/HunYuanBeta/type.js +0 -2
  106. package/src/models/HunYuanBeta/type.ts +0 -61
@@ -0,0 +1,481 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
24
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
49
+ var __rest = (this && this.__rest) || function (s, e) {
50
+ var t = {};
51
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
52
+ t[p] = s[p];
53
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
54
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
55
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
56
+ t[p[i]] = s[p[i]];
57
+ }
58
+ return t;
59
+ };
60
+ var __asyncValues = (this && this.__asyncValues) || function (o) {
61
+ if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
62
+ var m = o[Symbol.asyncIterator], i;
63
+ return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
64
+ function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
65
+ function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
66
+ };
67
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
68
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
69
+ if (ar || !(i in from)) {
70
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
71
+ ar[i] = from[i];
72
+ }
73
+ }
74
+ return to.concat(ar || Array.prototype.slice.call(from));
75
+ };
76
+ Object.defineProperty(exports, "__esModule", { value: true });
77
+ exports.toolMap = exports.ReactModel = void 0;
78
+ var utils_1 = require("../utils");
79
+ function processInput(obj) {
80
+ var _a;
81
+ var onStepFinish = obj.onStepFinish, abortSignal = obj.abortSignal, maxSteps = obj.maxSteps, b = __rest(obj, ["onStepFinish", "abortSignal", "maxSteps"]);
82
+ if (maxSteps != null && maxSteps < 1) {
83
+ throw new Error('`maxSteps` muse be greater than 0.');
84
+ }
85
+ return [
86
+ { onStepFinish: onStepFinish, abortSignal: abortSignal, maxSteps: maxSteps },
87
+ __assign(__assign({}, b), { tools: (_a = b.tools) === null || _a === void 0 ? void 0 : _a.map(function (tool) {
88
+ if ('fn' in tool) {
89
+ return (0, utils_1.functionToolToModelTool)(tool);
90
+ }
91
+ return tool;
92
+ }) }),
93
+ ];
94
+ }
95
+ var ReactModel = (function () {
96
+ function ReactModel(model) {
97
+ this.model = model;
98
+ }
99
+ ReactModel.prototype.generateText = function (_input) {
100
+ var _a, _b;
101
+ return __awaiter(this, void 0, void 0, function () {
102
+ var rawResponses, totalUsage, _c, _d, onStepFinish, _e, maxSteps, input, doGenerate, currentRes, currentStep, toolCall, stepUsage_1, toolCallResult, choice, e_1, lastChoice, lastMessage, text, messages, stepUsage;
103
+ var _this = this;
104
+ return __generator(this, function (_f) {
105
+ switch (_f.label) {
106
+ case 0:
107
+ rawResponses = [];
108
+ totalUsage = { completion_tokens: 0, prompt_tokens: 0, total_tokens: 0 };
109
+ _c = processInput(_input), _d = _c[0], onStepFinish = _d.onStepFinish, _e = _d.maxSteps, maxSteps = _e === void 0 ? 10 : _e, input = _c[1];
110
+ doGenerate = function () { return _this.model.doGenerate(input); };
111
+ return [4, doGenerate()];
112
+ case 1:
113
+ currentRes = _f.sent();
114
+ currentStep = 1;
115
+ currentRes.rawResponse && rawResponses.push(currentRes.rawResponse);
116
+ toolCall = null;
117
+ _f.label = 2;
118
+ case 2:
119
+ if (!(currentStep < maxSteps && (toolCall = getToolCallFromGenerate(currentRes)) != null)) return [3, 9];
120
+ stepUsage_1 = createSolidUsage(currentRes.usage);
121
+ addToUsage(totalUsage, stepUsage_1);
122
+ _f.label = 3;
123
+ case 3:
124
+ _f.trys.push([3, 7, , 8]);
125
+ return [4, callTool(toolCall)];
126
+ case 4:
127
+ toolCallResult = _f.sent();
128
+ choice = currentRes.choices[0];
129
+ return [4, (onStepFinish === null || onStepFinish === void 0 ? void 0 : onStepFinish({
130
+ finishReason: choice.finish_reason,
131
+ messages: input.messages.slice(),
132
+ text: choice.message.content,
133
+ toolCall: toolCall,
134
+ toolResult: toolCallResult,
135
+ stepUsage: stepUsage_1,
136
+ totalUsage: Object.assign({}, totalUsage),
137
+ }))];
138
+ case 5:
139
+ _f.sent();
140
+ pushNewMessages(input.messages, choice.message, toolCallResult);
141
+ return [4, doGenerate()];
142
+ case 6:
143
+ currentRes = _f.sent();
144
+ currentRes.rawResponse && rawResponses.push(currentRes.rawResponse);
145
+ currentStep += 1;
146
+ return [3, 8];
147
+ case 7:
148
+ e_1 = _f.sent();
149
+ return [2, {
150
+ text: '',
151
+ messages: input.messages,
152
+ usage: totalUsage,
153
+ error: e_1,
154
+ rawResponses: rawResponses,
155
+ }];
156
+ case 8: return [3, 2];
157
+ case 9:
158
+ lastChoice = (_a = currentRes === null || currentRes === void 0 ? void 0 : currentRes.choices) === null || _a === void 0 ? void 0 : _a[0];
159
+ lastMessage = lastChoice === null || lastChoice === void 0 ? void 0 : lastChoice.message;
160
+ text = (_b = lastMessage === null || lastMessage === void 0 ? void 0 : lastMessage.content) !== null && _b !== void 0 ? _b : '';
161
+ messages = lastMessage ? __spreadArray(__spreadArray([], input.messages, true), [lastMessage], false) : input.messages;
162
+ stepUsage = createSolidUsage(currentRes.usage);
163
+ addToUsage(totalUsage, stepUsage);
164
+ return [4, (onStepFinish === null || onStepFinish === void 0 ? void 0 : onStepFinish({
165
+ finishReason: lastChoice.finish_reason,
166
+ messages: messages.slice(),
167
+ text: text,
168
+ toolCall: getToolCallFromGenerate(currentRes),
169
+ toolResult: null,
170
+ stepUsage: stepUsage,
171
+ totalUsage: Object.assign({}, totalUsage),
172
+ }))];
173
+ case 10:
174
+ _f.sent();
175
+ return [2, {
176
+ text: text,
177
+ messages: messages,
178
+ usage: totalUsage,
179
+ rawResponses: rawResponses,
180
+ }];
181
+ }
182
+ });
183
+ });
184
+ };
185
+ ReactModel.prototype.streamText = function (_input) {
186
+ var _a;
187
+ return __awaiter(this, void 0, void 0, function () {
188
+ var totalUsage, _b, _c, onStepFinish, _d, maxSteps, input, doStream, currentRes, currentStep, readResult, readCurrentStream, _e, assistantMessage, stepUsage_2, toolCall, toolCallResult, e_2, _f, s1_1, s2_1, message_1, usage, messages, _g, s1_2, s2_2, messagePromise, usagePromise, message, finishReason, stepUsage, originStream, _h, s1, s2;
189
+ var _this = this;
190
+ return __generator(this, function (_j) {
191
+ switch (_j.label) {
192
+ case 0:
193
+ totalUsage = { completion_tokens: 0, prompt_tokens: 0, total_tokens: 0 };
194
+ _b = processInput(_input), _c = _b[0], onStepFinish = _c.onStepFinish, _d = _c.maxSteps, maxSteps = _d === void 0 ? 10 : _d, input = _b[1];
195
+ doStream = function () { return _this.model.doStream(input); };
196
+ return [4, doStream()];
197
+ case 1:
198
+ currentRes = _j.sent();
199
+ currentStep = 1;
200
+ readResult = null;
201
+ readCurrentStream = function () {
202
+ var _a = currentRes.tee(), oldStream = _a[0], newStream = _a[1];
203
+ currentRes = (0, utils_1.createAsyncIterable)(oldStream);
204
+ return readFunctionCallStream(newStream);
205
+ };
206
+ _j.label = 2;
207
+ case 2:
208
+ _e = currentStep < maxSteps;
209
+ if (!_e) return [3, 4];
210
+ return [4, readCurrentStream()];
211
+ case 3:
212
+ _e = (readResult = _j.sent()) != null;
213
+ _j.label = 4;
214
+ case 4:
215
+ if (!_e) return [3, 11];
216
+ assistantMessage = readResult.message, stepUsage_2 = readResult.usage;
217
+ addToUsage(totalUsage, stepUsage_2);
218
+ toolCall = (_a = assistantMessage.tool_calls) === null || _a === void 0 ? void 0 : _a[0];
219
+ _j.label = 5;
220
+ case 5:
221
+ _j.trys.push([5, 9, , 10]);
222
+ return [4, callTool(toolCall)];
223
+ case 6:
224
+ toolCallResult = _j.sent();
225
+ return [4, (onStepFinish === null || onStepFinish === void 0 ? void 0 : onStepFinish({
226
+ finishReason: 'tool_calls',
227
+ messages: input.messages.slice(),
228
+ text: assistantMessage.content,
229
+ toolCall: toolCall,
230
+ toolResult: toolCallResult,
231
+ stepUsage: stepUsage_2,
232
+ totalUsage: Object.assign({}, totalUsage),
233
+ }))];
234
+ case 7:
235
+ _j.sent();
236
+ pushNewMessages(input.messages, assistantMessage, toolCallResult);
237
+ return [4, doStream()];
238
+ case 8:
239
+ currentRes = _j.sent();
240
+ return [3, 10];
241
+ case 9:
242
+ e_2 = _j.sent();
243
+ _f = currentRes.tee(), s1_1 = _f[0], s2_1 = _f[1];
244
+ return [2, {
245
+ messages: Promise.resolve(input.messages),
246
+ dataStream: (0, utils_1.createAsyncIterable)(s1_1),
247
+ textStream: (0, utils_1.createAsyncIterable)(s2_1.pipeThrough(new utils_1.TransformStream({
248
+ transform: function (chunk, controller) {
249
+ var _a, _b, _c;
250
+ var str = (_c = (_b = (_a = chunk === null || chunk === void 0 ? void 0 : chunk.choices) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.delta) === null || _c === void 0 ? void 0 : _c.content;
251
+ if (typeof str === 'string')
252
+ controller.enqueue(str);
253
+ },
254
+ }))),
255
+ usage: Promise.resolve(totalUsage),
256
+ error: e_2,
257
+ }];
258
+ case 10: return [3, 2];
259
+ case 11: return [4, readCurrentStream()];
260
+ case 12:
261
+ readResult = _j.sent();
262
+ if (readResult) {
263
+ message_1 = readResult.message, usage = readResult.usage;
264
+ addToUsage(totalUsage, usage);
265
+ messages = __spreadArray(__spreadArray([], input.messages, true), [message_1], false);
266
+ onStepFinish({
267
+ messages: messages.slice(),
268
+ finishReason: 'tool_call',
269
+ stepUsage: usage,
270
+ text: message_1.content,
271
+ toolCall: message_1.tool_calls[0],
272
+ totalUsage: Object.assign({}, totalUsage),
273
+ });
274
+ _g = currentRes.tee(), s1_2 = _g[0], s2_2 = _g[1];
275
+ return [2, {
276
+ messages: Promise.resolve(__spreadArray(__spreadArray([], input.messages, true), [message_1], false)),
277
+ dataStream: (0, utils_1.createAsyncIterable)(s1_2),
278
+ textStream: (0, utils_1.createAsyncIterable)(s2_2.pipeThrough(new utils_1.TransformStream({
279
+ transform: function (chunk, controller) {
280
+ var _a, _b, _c;
281
+ var str = (_c = (_b = (_a = chunk === null || chunk === void 0 ? void 0 : chunk.choices) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.delta) === null || _c === void 0 ? void 0 : _c.content;
282
+ if (typeof str === 'string')
283
+ controller.enqueue(str);
284
+ },
285
+ }))),
286
+ usage: Promise.resolve(totalUsage),
287
+ }];
288
+ }
289
+ messagePromise = (0, utils_1.createPromise)();
290
+ usagePromise = (0, utils_1.createPromise)();
291
+ message = {
292
+ role: 'assistant',
293
+ content: '',
294
+ };
295
+ finishReason = '';
296
+ stepUsage = { completion_tokens: 0, prompt_tokens: 0, total_tokens: 0 };
297
+ originStream = currentRes.pipeThrough(new utils_1.TransformStream({
298
+ transform: function (chunk, controller) {
299
+ var _a, _b, _c, _d, _e, _f, _g, _h;
300
+ var content = (_c = (_b = (_a = chunk === null || chunk === void 0 ? void 0 : chunk.choices) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.delta) === null || _c === void 0 ? void 0 : _c.content;
301
+ if (typeof content === 'string') {
302
+ message.content += content;
303
+ }
304
+ var reason = (_e = (_d = chunk === null || chunk === void 0 ? void 0 : chunk.choices) === null || _d === void 0 ? void 0 : _d[0]) === null || _e === void 0 ? void 0 : _e.finish_reason;
305
+ if (reason)
306
+ finishReason = reason;
307
+ if ((_f = chunk === null || chunk === void 0 ? void 0 : chunk.usage) === null || _f === void 0 ? void 0 : _f.completion_tokens)
308
+ stepUsage.completion_tokens = chunk.usage.completion_tokens;
309
+ if ((_g = chunk === null || chunk === void 0 ? void 0 : chunk.usage) === null || _g === void 0 ? void 0 : _g.prompt_tokens)
310
+ stepUsage.prompt_tokens = chunk.usage.prompt_tokens;
311
+ if ((_h = chunk === null || chunk === void 0 ? void 0 : chunk.usage) === null || _h === void 0 ? void 0 : _h.total_tokens)
312
+ stepUsage.total_tokens = chunk.usage.total_tokens;
313
+ controller.enqueue(chunk);
314
+ },
315
+ flush: function () {
316
+ messagePromise.res(__spreadArray(__spreadArray([], input.messages, true), [message], false));
317
+ addToUsage(totalUsage, stepUsage);
318
+ usagePromise.res(Object.assign({}, totalUsage));
319
+ onStepFinish === null || onStepFinish === void 0 ? void 0 : onStepFinish({
320
+ messages: __spreadArray(__spreadArray([], input.messages, true), [message], false),
321
+ finishReason: finishReason,
322
+ text: message.content,
323
+ stepUsage: stepUsage,
324
+ totalUsage: Object.assign({}, totalUsage),
325
+ });
326
+ },
327
+ }));
328
+ _h = originStream.tee(), s1 = _h[0], s2 = _h[1];
329
+ return [2, {
330
+ messages: messagePromise.promise,
331
+ dataStream: (0, utils_1.createAsyncIterable)(s1),
332
+ textStream: (0, utils_1.createAsyncIterable)(s2.pipeThrough(new utils_1.TransformStream({
333
+ transform: function (chunk, controller) {
334
+ var _a, _b, _c;
335
+ var content = (_c = (_b = (_a = chunk === null || chunk === void 0 ? void 0 : chunk.choices) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.delta) === null || _c === void 0 ? void 0 : _c.content;
336
+ if (typeof content === 'string') {
337
+ controller.enqueue(content);
338
+ }
339
+ },
340
+ }))),
341
+ usage: usagePromise.promise,
342
+ }];
343
+ }
344
+ });
345
+ });
346
+ };
347
+ return ReactModel;
348
+ }());
349
+ exports.ReactModel = ReactModel;
350
+ function getToolCallFromGenerate(output) {
351
+ var _a;
352
+ var choice = (_a = output === null || output === void 0 ? void 0 : output.choices) === null || _a === void 0 ? void 0 : _a[0];
353
+ if (!choice)
354
+ return null;
355
+ var finish_reason = choice.finish_reason, message = choice.message;
356
+ if (finish_reason !== 'tool_calls')
357
+ return null;
358
+ if (!message)
359
+ return null;
360
+ if (!(0, utils_1.isToolCallAssistantMessage)(message))
361
+ return null;
362
+ return message.tool_calls[0];
363
+ }
364
+ function pushNewMessages(messages, assistantMessage, toolCallResult) {
365
+ messages.push(assistantMessage, {
366
+ role: 'tool',
367
+ tool_call_id: assistantMessage.tool_calls[0].id,
368
+ content: JSON.stringify(toolCallResult),
369
+ });
370
+ }
371
+ function readFunctionCallStream(stream) {
372
+ var _a, e_3, _b, _c;
373
+ var _d, _e, _f, _g, _h, _j;
374
+ return __awaiter(this, void 0, void 0, function () {
375
+ var stepUsage, aStream, retToolCall, retMessage, _k, aStream_1, aStream_1_1, chunk, choice, finish_reason, delta, toolCall, e_3_1;
376
+ return __generator(this, function (_l) {
377
+ switch (_l.label) {
378
+ case 0:
379
+ stepUsage = { completion_tokens: 0, prompt_tokens: 0, total_tokens: 0 };
380
+ aStream = (0, utils_1.createAsyncIterable)(stream);
381
+ retToolCall = {
382
+ id: '',
383
+ function: {
384
+ name: '',
385
+ arguments: '',
386
+ },
387
+ type: '',
388
+ };
389
+ retMessage = {
390
+ role: 'assistant',
391
+ content: '',
392
+ tool_calls: [retToolCall],
393
+ };
394
+ _l.label = 1;
395
+ case 1:
396
+ _l.trys.push([1, 6, 7, 12]);
397
+ _k = true, aStream_1 = __asyncValues(aStream);
398
+ _l.label = 2;
399
+ case 2: return [4, aStream_1.next()];
400
+ case 3:
401
+ if (!(aStream_1_1 = _l.sent(), _a = aStream_1_1.done, !_a)) return [3, 5];
402
+ _c = aStream_1_1.value;
403
+ _k = false;
404
+ try {
405
+ chunk = _c;
406
+ choice = chunk === null || chunk === void 0 ? void 0 : chunk.choices[0];
407
+ if (!choice)
408
+ return [2, null];
409
+ finish_reason = choice.finish_reason, delta = choice.delta;
410
+ if (finish_reason !== 'tool_calls')
411
+ return [2, null];
412
+ if (!delta)
413
+ return [3, 4];
414
+ if (delta.content)
415
+ retMessage.content += delta.content;
416
+ if (!('tool_calls' in delta))
417
+ return [3, 4];
418
+ toolCall = (_d = delta === null || delta === void 0 ? void 0 : delta.tool_calls) === null || _d === void 0 ? void 0 : _d[0];
419
+ if (toolCall === null || toolCall === void 0 ? void 0 : toolCall.id)
420
+ retToolCall.id = toolCall.id;
421
+ if (toolCall === null || toolCall === void 0 ? void 0 : toolCall.type)
422
+ retToolCall.type = toolCall.type;
423
+ if ((_e = toolCall === null || toolCall === void 0 ? void 0 : toolCall.function) === null || _e === void 0 ? void 0 : _e.name)
424
+ retToolCall.function.name = toolCall.function.name;
425
+ if ((_f = toolCall === null || toolCall === void 0 ? void 0 : toolCall.function) === null || _f === void 0 ? void 0 : _f.arguments)
426
+ retToolCall.function.arguments += toolCall.function.arguments;
427
+ if ((_g = chunk === null || chunk === void 0 ? void 0 : chunk.usage) === null || _g === void 0 ? void 0 : _g.completion_tokens)
428
+ stepUsage.completion_tokens = chunk.usage.completion_tokens;
429
+ if ((_h = chunk === null || chunk === void 0 ? void 0 : chunk.usage) === null || _h === void 0 ? void 0 : _h.prompt_tokens)
430
+ stepUsage.prompt_tokens = chunk.usage.prompt_tokens;
431
+ if ((_j = chunk === null || chunk === void 0 ? void 0 : chunk.usage) === null || _j === void 0 ? void 0 : _j.total_tokens)
432
+ stepUsage.total_tokens = chunk.usage.total_tokens;
433
+ }
434
+ finally {
435
+ _k = true;
436
+ }
437
+ _l.label = 4;
438
+ case 4: return [3, 2];
439
+ case 5: return [3, 12];
440
+ case 6:
441
+ e_3_1 = _l.sent();
442
+ e_3 = { error: e_3_1 };
443
+ return [3, 12];
444
+ case 7:
445
+ _l.trys.push([7, , 10, 11]);
446
+ if (!(!_k && !_a && (_b = aStream_1.return))) return [3, 9];
447
+ return [4, _b.call(aStream_1)];
448
+ case 8:
449
+ _l.sent();
450
+ _l.label = 9;
451
+ case 9: return [3, 11];
452
+ case 10:
453
+ if (e_3) throw e_3.error;
454
+ return [7];
455
+ case 11: return [7];
456
+ case 12: return [2, {
457
+ message: retMessage,
458
+ usage: stepUsage,
459
+ }];
460
+ }
461
+ });
462
+ });
463
+ }
464
+ exports.toolMap = new Map();
465
+ function callTool(toolCall) {
466
+ return exports.toolMap.get(toolCall.function.name)(JSON.parse(toolCall.function.arguments));
467
+ }
468
+ function createSolidUsage(usage) {
469
+ var _a, _b, _c;
470
+ return {
471
+ completion_tokens: (_a = usage === null || usage === void 0 ? void 0 : usage.completion_tokens) !== null && _a !== void 0 ? _a : 0,
472
+ prompt_tokens: (_b = usage === null || usage === void 0 ? void 0 : usage.prompt_tokens) !== null && _b !== void 0 ? _b : 0,
473
+ total_tokens: (_c = usage === null || usage === void 0 ? void 0 : usage.total_tokens) !== null && _c !== void 0 ? _c : 0,
474
+ };
475
+ }
476
+ function addToUsage(targetUsage, sourceUsage) {
477
+ targetUsage.completion_tokens += sourceUsage.completion_tokens;
478
+ targetUsage.prompt_tokens += sourceUsage.prompt_tokens;
479
+ targetUsage.total_tokens += sourceUsage.total_tokens;
480
+ }
481
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model.js","sourceRoot":"","sources":["../../../src/models/model.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  createAsyncIterable,\n  TransformStream,\n  createPromise,\n  isToolCallAssistantMessage,\n  functionToolToModelTool,\n} from '../utils'\nimport {\n  BaseChatModelInput,\n  BaseDoStreamOutputChunk,\n  DoStreamOutput,\n  DoGenerateOutput,\n  SimpleChatModel,\n  ToolCall,\n  ChatModelMessage,\n  AsyncIterableReadableStream,\n  Usage,\n  ToolCallAssistantMessage,\n  ModelTool,\n  FunctionTool,\n} from '../type'\n\ntype ReactModelInput = ReactProps & Omit<BaseChatModelInput, 'tools'> & { tools?: Array<ModelTool | FunctionTool> }\n\ninterface IOnStepFinish {\n  messages: Array<ChatModelMessage>\n  text?: string\n  toolCall?: ToolCall\n  toolResult?: unknown\n  finishReason?: string\n  stepUsage?: Usage\n  totalUsage?: Usage\n}\n\ninterface ReactProps {\n  maxSteps?: number\n  onStepFinish?: (prop: IOnStepFinish) => unknown\n  abortSignal?: AbortSignal // TODO: 实现 abortSignal\n}\n\nfunction processInput(obj: ReactModelInput): [ReactProps, BaseChatModelInput] {\n  const { onStepFinish, abortSignal, maxSteps, ...b } = obj\n\n  if (maxSteps != null && maxSteps < 1) {\n    throw new Error('`maxSteps` muse be greater than 0.')\n  }\n\n  return [\n    { onStepFinish, abortSignal, maxSteps },\n    {\n      ...b,\n      tools: b.tools?.map((tool) => {\n        if ('fn' in tool) {\n          return functionToolToModelTool(tool)\n        }\n        return tool\n      }),\n    },\n  ]\n}\n\nexport class ReactModel {\n  constructor(private model: SimpleChatModel) {}\n\n  public async generateText(_input: ReactModelInput): Promise<{\n    text: string\n    messages: Array<ChatModelMessage>\n    usage: Usage\n    rawResponses: Array<unknown>\n    error?: any\n  }> {\n    const rawResponses = []\n    const totalUsage: Usage = { completion_tokens: 0, prompt_tokens: 0, total_tokens: 0 }\n\n    const [{ onStepFinish, maxSteps = 10 }, input] = processInput(_input)\n\n    const doGenerate = () => this.model.doGenerate(input) // 后续代码会直接对 input.messages 原地修改，这里一直用同一个对象就行\n    let currentRes = await doGenerate()\n    let currentStep = 1\n    currentRes.rawResponse && rawResponses.push(currentRes.rawResponse)\n\n    let toolCall: ToolCall | null = null\n\n    // TODO: 一次对话有多个 tool call? 目前没有这种现象，暂时不处理\n    while (currentStep < maxSteps && (toolCall = getToolCallFromGenerate(currentRes)) != null) {\n      const stepUsage = createSolidUsage(currentRes.usage)\n      addToUsage(totalUsage, stepUsage)\n\n      // 当判断需要工具调用时\n      try {\n        const toolCallResult = await callTool(toolCall) // 调用\n\n        const choice = currentRes.choices[0] // getToolCallFromGenerate 保证了 choice 肯定存在\n\n        await onStepFinish?.({\n          finishReason: choice.finish_reason,\n          messages: input.messages.slice(),\n          text: choice.message.content,\n          toolCall,\n          toolResult: toolCallResult,\n          stepUsage,\n          totalUsage: Object.assign({}, totalUsage),\n        })\n\n        pushNewMessages(input.messages, choice.message as ToolCallAssistantMessage, toolCallResult) // 用调用结果修改最新的消息\n\n        currentRes = await doGenerate() // 循环对话\n        currentRes.rawResponse && rawResponses.push(currentRes.rawResponse)\n        currentStep += 1\n      } catch (e) {\n        return {\n          text: '',\n          messages: input.messages,\n          usage: totalUsage,\n          error: e,\n          rawResponses,\n        }\n      }\n    }\n\n    const lastChoice = currentRes?.choices?.[0]\n    const lastMessage = lastChoice?.message\n\n    const text = lastMessage?.content ?? ''\n    const messages = lastMessage ? [...input.messages, lastMessage] : input.messages\n\n    const stepUsage = createSolidUsage(currentRes.usage)\n    addToUsage(totalUsage, stepUsage)\n\n    await onStepFinish?.({\n      finishReason: lastChoice.finish_reason,\n      messages: messages.slice(),\n      text,\n      toolCall: getToolCallFromGenerate(currentRes),\n      toolResult: null,\n      stepUsage,\n      totalUsage: Object.assign({}, totalUsage),\n    })\n\n    return {\n      text,\n      messages,\n      usage: totalUsage,\n      rawResponses,\n    }\n  }\n\n  public async streamText(_input: ReactModelInput): Promise<{\n    dataStream: DoStreamOutput\n    textStream: AsyncIterableReadableStream<string>\n    messages: Promise<Array<ChatModelMessage>>\n    usage: Promise<Usage>\n    error?: any\n  }> {\n    const totalUsage: Usage = { completion_tokens: 0, prompt_tokens: 0, total_tokens: 0 }\n\n    const [{ onStepFinish, maxSteps = 10 }, input] = processInput(_input)\n    const doStream = () => this.model.doStream(input) // 后续代码会直接对 input.messages 原地修改，这里一直用同一个对象就行\n    let currentRes = await doStream()\n    const currentStep = 1\n    let readResult: { message: ToolCallAssistantMessage; usage: Usage } | null = null\n\n    const readCurrentStream = () => {\n      const [oldStream, newStream] = currentRes.tee()\n      currentRes = createAsyncIterable(oldStream)\n      return readFunctionCallStream(newStream)\n    }\n\n    // TODO: 一次对话有多个 tool call? 目前没有这种现象，暂时不处理\n    // 这里和 generateText 不太一样，除了解析出 toolCall 外，还需要从流中构造出其他完整的信息\n    while (currentStep < maxSteps && (readResult = await readCurrentStream()) != null) {\n      const { message: assistantMessage, usage: stepUsage } = readResult\n      addToUsage(totalUsage, stepUsage)\n\n      // 当判断需要工具调用时\n      const toolCall = assistantMessage.tool_calls?.[0] // 这个 toolCall 一定存在\n      try {\n        const toolCallResult = await callTool(toolCall) // 调用\n\n        await onStepFinish?.({\n          finishReason: 'tool_calls',\n          messages: input.messages.slice(),\n          text: assistantMessage.content,\n          toolCall,\n          toolResult: toolCallResult,\n          stepUsage,\n          totalUsage: Object.assign({}, totalUsage),\n        })\n\n        pushNewMessages(input.messages, assistantMessage, toolCallResult) // 用调用结果修改最新的消息\n        currentRes = await doStream() // 循环对话\n      } catch (e) {\n        const [s1, s2] = currentRes.tee()\n        return {\n          messages: Promise.resolve(input.messages),\n          dataStream: createAsyncIterable(s1),\n          textStream: createAsyncIterable(s2.pipeThrough(new TransformStream({\n            transform(chunk, controller) {\n              const str = chunk?.choices?.[0]?.delta?.content\n              if (typeof str === 'string') controller.enqueue(str)\n            },\n          }),),),\n          usage: Promise.resolve(totalUsage),\n          error: e,\n        }\n      }\n    }\n\n    /**\n     * 最后返回时，有几种情况：\n     * 1. 没超 maxStep 无工具调用\n     * 2. 超了 maxStep 有工具调用\n     * 3. 超了 maxStep 无工具调用\n     * never. 没超 maxStep，有工具调用，这时候会进到上面的 while 循环 block 中处理\n     *\n     * 其中 1. 3. 可以合并，没有工具调用就应该直接返回，无论 maxStep\n     *\n     * 所以合并为：\n     * 1. 无工具调用\n     * 2. 有工具调用，但是超过 maxStep\n     *\n     * 这两种情况都没进到 while 循环 block 中处理\n     * 我们需要 a. 塞 message b. 算 Usage c. 调用 onStepFinish\n     */\n\n    readResult = await readCurrentStream()\n\n    if (readResult) {\n      // 情况 2 有工具调用，但是超过 maxStep\n      const { message, usage } = readResult\n      addToUsage(totalUsage, usage)\n\n      const messages = [...input.messages, message]\n\n      onStepFinish({\n        messages: messages.slice(),\n        finishReason: 'tool_call',\n        stepUsage: usage,\n        text: message.content,\n        toolCall: message.tool_calls[0],\n        totalUsage: Object.assign({}, totalUsage),\n      })\n\n      const [s1, s2] = currentRes.tee()\n      return {\n        messages: Promise.resolve([...input.messages, message]),\n        dataStream: createAsyncIterable(s1),\n        textStream: createAsyncIterable(s2.pipeThrough(new TransformStream({\n          transform(chunk, controller) {\n            const str = chunk?.choices?.[0]?.delta?.content\n            if (typeof str === 'string') controller.enqueue(str)\n          },\n        }),),),\n        usage: Promise.resolve(totalUsage),\n      }\n    }\n    // 情况 1 无工具调用\n    const messagePromise = createPromise<Array<ChatModelMessage>>()\n    const usagePromise = createPromise<Usage>()\n\n    const message: ChatModelMessage = {\n      role: 'assistant',\n      content: '',\n    }\n    let finishReason = ''\n    const stepUsage: Usage = { completion_tokens: 0, prompt_tokens: 0, total_tokens: 0 }\n\n    const originStream = currentRes.pipeThrough(new TransformStream({\n      transform(chunk, controller) {\n        // 不改变 chunk 内容，只是拦截下内容拼最后的结果\n        const content = chunk?.choices?.[0]?.delta?.content\n        if (typeof content === 'string') {\n          message.content += content\n        }\n\n        const reason = chunk?.choices?.[0]?.finish_reason\n        if (reason) finishReason = reason\n\n        // TODO: 不同大模型的 stream usage 格式不一样，后续可能要调整.\n        // hunyuan 每个 chunk 都会有 usage，逐步增加，以最后一个的为准;\n        // zhipu 最后 chunk 会有 usage;\n        if (chunk?.usage?.completion_tokens) stepUsage.completion_tokens = chunk.usage.completion_tokens\n        if (chunk?.usage?.prompt_tokens) stepUsage.prompt_tokens = chunk.usage.prompt_tokens\n        if (chunk?.usage?.total_tokens) stepUsage.total_tokens = chunk.usage.total_tokens\n\n        controller.enqueue(chunk)\n      },\n      flush() {\n        messagePromise.res([...input.messages, message])\n        addToUsage(totalUsage, stepUsage)\n        usagePromise.res(Object.assign({}, totalUsage))\n        onStepFinish?.({\n          messages: [...input.messages, message],\n          finishReason,\n          text: message.content,\n          stepUsage,\n          totalUsage: Object.assign({}, totalUsage),\n        })\n      },\n    }),)\n\n    const [s1, s2] = originStream.tee()\n\n    return {\n      messages: messagePromise.promise,\n      dataStream: createAsyncIterable(s1),\n      textStream: createAsyncIterable(s2.pipeThrough(new TransformStream({\n        transform(chunk, controller) {\n          const content = chunk?.choices?.[0]?.delta?.content\n          if (typeof content === 'string') {\n            controller.enqueue(content)\n          }\n        },\n      }),),),\n      usage: usagePromise.promise,\n    }\n  }\n}\n\nfunction getToolCallFromGenerate(output: DoGenerateOutput) {\n  const choice = output?.choices?.[0]\n\n  if (!choice) return null\n\n  const { finish_reason, message } = choice\n\n  if (finish_reason !== 'tool_calls') return null\n  if (!message) return null\n  if (!isToolCallAssistantMessage(message)) return null\n\n  return message.tool_calls[0]\n}\n\nfunction pushNewMessages(\n  messages: Array<ChatModelMessage>,\n  assistantMessage: ToolCallAssistantMessage,\n  toolCallResult: unknown,\n) {\n  messages.push(assistantMessage, {\n    role: 'tool',\n    tool_call_id: assistantMessage.tool_calls[0].id,\n    content: JSON.stringify(toolCallResult),\n  })\n}\n\nasync function readFunctionCallStream(stream: ReadableStream<BaseDoStreamOutputChunk>,): Promise<{ message: ToolCallAssistantMessage; usage: Usage } | null> {\n  const stepUsage: Usage = { completion_tokens: 0, prompt_tokens: 0, total_tokens: 0 }\n  const aStream = createAsyncIterable(stream)\n\n  const retToolCall: ToolCall = {\n    id: '',\n    function: {\n      name: '',\n      arguments: '',\n    },\n    type: '',\n  }\n\n  const retMessage: ToolCallAssistantMessage = {\n    role: 'assistant',\n    content: '',\n    tool_calls: [retToolCall],\n  }\n\n  for await (const chunk of aStream) {\n    const choice = chunk?.choices[0]\n    if (!choice) return null\n\n    const { finish_reason, delta } = choice\n\n    if (finish_reason !== 'tool_calls') return null\n    if (!delta) continue\n\n    if (delta.content) retMessage.content += delta.content\n\n    if (!('tool_calls' in delta)) continue\n    const toolCall = delta?.tool_calls?.[0]\n    if (toolCall?.id) retToolCall.id = toolCall.id\n    if (toolCall?.type) retToolCall.type = toolCall.type\n    if (toolCall?.function?.name) retToolCall.function.name = toolCall.function.name\n    if (toolCall?.function?.arguments) retToolCall.function.arguments += toolCall.function.arguments\n\n    // TODO: 不同大模型的 stream usage 格式不一样，后续可能要调整.\n    // hunyuan 每个 chunk 都会有 usage，逐步增加，以最后一个的为准;\n    // zhipu 最后 chunk 会有 usage;\n    if (chunk?.usage?.completion_tokens) stepUsage.completion_tokens = chunk.usage.completion_tokens\n    if (chunk?.usage?.prompt_tokens) stepUsage.prompt_tokens = chunk.usage.prompt_tokens\n    if (chunk?.usage?.total_tokens) stepUsage.total_tokens = chunk.usage.total_tokens\n  }\n\n  return {\n    message: retMessage,\n    usage: stepUsage,\n  }\n}\n\nexport const toolMap = new Map<string, CallableFunction>()\n\nfunction callTool(toolCall: ToolCall) {\n  return toolMap.get(toolCall.function.name)(JSON.parse(toolCall.function.arguments))\n}\n\nfunction createSolidUsage(usage?: Partial<Usage>): Usage {\n  return {\n    completion_tokens: usage?.completion_tokens ?? 0,\n    prompt_tokens: usage?.prompt_tokens ?? 0,\n    total_tokens: usage?.total_tokens ?? 0,\n  }\n}\n\nfunction addToUsage(targetUsage: Usage, sourceUsage: Usage) {\n  targetUsage.completion_tokens += sourceUsage.completion_tokens\n  targetUsage.prompt_tokens += sourceUsage.prompt_tokens\n  targetUsage.total_tokens += sourceUsage.total_tokens\n}\n"]}
@@ -1,17 +1,13 @@
1
- import { type ParsedEvent } from './eventsource_parser';
2
- export declare abstract class ChatModel {
3
- abstract generateText(data: BaseChatModelInput): Promise<{
4
- text: string;
5
- rawResponse: any;
6
- }>;
7
- abstract streamText(data: BaseChatModelInput): Promise<StreamTextResult>;
8
- }
9
- export type ChatModelConstructor = typeof ChatModel;
10
- export declare abstract class StreamTextResult {
11
- abstract eventSourceStream: AsyncIterableReadableStream<ParsedEvent>;
12
- abstract dataStream: AsyncIterableReadableStream<any>;
13
- abstract textStream: AsyncIterableReadableStream<string>;
1
+ export declare abstract class SimpleChatModel {
2
+ abstract doGenerate(data: BaseChatModelInput): Promise<DoGenerateOutput>;
3
+ abstract doStream(data: BaseChatModelInput): Promise<DoStreamOutput>;
14
4
  }
5
+ type RawResponse = {
6
+ rawResponse?: any;
7
+ };
8
+ export type DoGenerateOutput = BaseDoGenerateOutput & RawResponse;
9
+ export type DoStreamOutput = AsyncIterableReadableStream<BaseDoStreamOutputChunk & RawResponse>;
10
+ export type ChatModelConstructor = typeof SimpleChatModel;
15
11
  export type AsyncIterableReadableStream<T> = ReadableStream<T> & {
16
12
  [Symbol.asyncIterator]: () => {
17
13
  next(): Promise<IteratorResult<T>>;
@@ -32,14 +28,79 @@ export interface IBotReqInput {
32
28
  stream?: boolean;
33
29
  }
34
30
  export type BotReq = <T extends IBotReqInput>(props: T) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>;
35
- type ChatModelMessage = {
36
- role: 'user' | 'system' | 'assistant';
31
+ export type UserMessage = {
32
+ role: 'user';
33
+ content: string;
34
+ };
35
+ export type SystemMessage = {
36
+ role: 'system';
37
+ content: string;
38
+ };
39
+ export type AssistantMessage = PlainAssistantMessage | ToolCallAssistantMessage;
40
+ export type PlainAssistantMessage = {
41
+ role: 'assistant';
42
+ content: string;
43
+ };
44
+ export type ToolCallAssistantMessage = {
45
+ role: 'assistant';
46
+ tool_calls: Array<ToolCall>;
47
+ content?: string;
48
+ };
49
+ export type ToolMessage = {
50
+ role: 'tool';
51
+ tool_call_id: string;
37
52
  content: string;
38
53
  };
54
+ export type ChatModelMessage = UserMessage | SystemMessage | AssistantMessage | ToolMessage;
55
+ export type FunctionTool = {
56
+ name: string;
57
+ description: string;
58
+ fn: CallableFunction;
59
+ parameters: object;
60
+ };
39
61
  export interface BaseChatModelInput {
40
62
  model: string;
41
63
  messages: Array<ChatModelMessage>;
42
64
  temperature?: number;
43
65
  top_p?: number;
66
+ tools?: Array<ModelTool>;
67
+ tool_choice?: 'none' | 'auto' | 'custom';
68
+ }
69
+ export type ModelTool = {
70
+ type: string;
71
+ function?: ModelToolFunction;
72
+ };
73
+ export type ModelToolFunction = {
74
+ name: string;
75
+ description: string;
76
+ parameters: string;
77
+ };
78
+ export type ToolCall = {
79
+ id: string;
80
+ type: string;
81
+ function: {
82
+ name: string;
83
+ arguments: string;
84
+ };
85
+ };
86
+ type FinishReason = 'tool_calls' | (string & {});
87
+ export type Usage = {
88
+ completion_tokens: number;
89
+ prompt_tokens: number;
90
+ total_tokens: number;
91
+ };
92
+ export interface BaseDoGenerateOutput {
93
+ choices?: Array<{
94
+ finish_reason?: FinishReason;
95
+ message?: ChatModelMessage;
96
+ }>;
97
+ usage?: Usage;
98
+ }
99
+ export interface BaseDoStreamOutputChunk {
100
+ choices?: Array<{
101
+ finish_reason?: FinishReason;
102
+ delta?: ChatModelMessage;
103
+ }>;
104
+ usage?: Usage;
44
105
  }
45
106
  export {};