@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.
- package/dist/cjs/AI.d.ts +27 -0
- package/dist/cjs/AI.js +154 -0
- package/dist/cjs/index.d.ts +13 -38
- package/dist/cjs/index.js +9 -73
- package/dist/cjs/models/Ark/index.d.ts +4 -18
- package/dist/cjs/models/Ark/index.js +45 -82
- package/dist/cjs/models/Ark/type.d.ts +52 -19
- package/dist/cjs/models/Ark/type.js +1 -1
- package/dist/cjs/models/DashScope/index.d.ts +4 -18
- package/dist/cjs/models/DashScope/index.js +45 -82
- package/dist/cjs/models/DashScope/type.d.ts +55 -24
- package/dist/cjs/models/DashScope/type.js +1 -1
- package/dist/cjs/models/HunYuan/index.d.ts +4 -19
- package/dist/cjs/models/HunYuan/index.js +47 -107
- package/dist/cjs/models/HunYuan/type.d.ts +68 -48
- package/dist/cjs/models/HunYuan/type.js +1 -1
- package/dist/cjs/models/HunYuan/util.d.ts +4 -0
- package/dist/cjs/models/HunYuan/util.js +58 -0
- package/dist/cjs/models/HunYuanBeta/index.d.ts +4 -19
- package/dist/cjs/models/HunYuanBeta/index.js +42 -110
- package/dist/cjs/models/Moonshot/index.d.ts +4 -18
- package/dist/cjs/models/Moonshot/index.js +45 -82
- package/dist/cjs/models/Moonshot/type.d.ts +63 -9
- package/dist/cjs/models/Moonshot/type.js +1 -1
- package/dist/cjs/models/Yi/index.d.ts +4 -18
- package/dist/cjs/models/Yi/index.js +48 -82
- package/dist/cjs/models/Yi/type.d.ts +41 -15
- package/dist/cjs/models/Yi/type.js +1 -1
- package/dist/cjs/models/ZhiPu/index.d.ts +4 -18
- package/dist/cjs/models/ZhiPu/index.js +59 -87
- package/dist/cjs/models/ZhiPu/type.d.ts +19 -19
- package/dist/cjs/models/ZhiPu/type.js +1 -1
- package/dist/cjs/models/index.d.ts +16 -15
- package/dist/cjs/models/index.js +26 -23
- package/dist/cjs/models/model.d.ts +38 -0
- package/dist/cjs/models/model.js +481 -0
- package/dist/cjs/type.d.ts +76 -15
- package/dist/cjs/type.js +6 -12
- package/dist/cjs/utils.d.ts +9 -1
- package/dist/cjs/utils.js +46 -2
- package/dist/esm/AI.d.ts +27 -0
- package/dist/esm/AI.js +128 -0
- package/dist/esm/index.d.ts +13 -38
- package/dist/esm/index.js +4 -70
- package/dist/esm/models/Ark/index.d.ts +4 -18
- package/dist/esm/models/Ark/index.js +45 -82
- package/dist/esm/models/Ark/type.d.ts +52 -19
- package/dist/esm/models/Ark/type.js +1 -1
- package/dist/esm/models/DashScope/index.d.ts +4 -18
- package/dist/esm/models/DashScope/index.js +45 -82
- package/dist/esm/models/DashScope/type.d.ts +55 -24
- package/dist/esm/models/DashScope/type.js +1 -1
- package/dist/esm/models/HunYuan/index.d.ts +4 -19
- package/dist/esm/models/HunYuan/index.js +47 -107
- package/dist/esm/models/HunYuan/type.d.ts +68 -48
- package/dist/esm/models/HunYuan/type.js +1 -1
- package/dist/esm/models/HunYuan/util.d.ts +4 -0
- package/dist/esm/models/HunYuan/util.js +53 -0
- package/dist/esm/models/HunYuanBeta/index.d.ts +4 -19
- package/dist/esm/models/HunYuanBeta/index.js +42 -110
- package/dist/esm/models/Moonshot/index.d.ts +4 -18
- package/dist/esm/models/Moonshot/index.js +45 -82
- package/dist/esm/models/Moonshot/type.d.ts +63 -9
- package/dist/esm/models/Moonshot/type.js +1 -1
- package/dist/esm/models/Yi/index.d.ts +4 -18
- package/dist/esm/models/Yi/index.js +48 -82
- package/dist/esm/models/Yi/type.d.ts +41 -15
- package/dist/esm/models/Yi/type.js +1 -1
- package/dist/esm/models/ZhiPu/index.d.ts +4 -18
- package/dist/esm/models/ZhiPu/index.js +59 -87
- package/dist/esm/models/ZhiPu/type.d.ts +19 -19
- package/dist/esm/models/ZhiPu/type.js +1 -1
- package/dist/esm/models/index.d.ts +16 -15
- package/dist/esm/models/index.js +17 -16
- package/dist/esm/models/model.d.ts +38 -0
- package/dist/esm/models/model.js +478 -0
- package/dist/esm/type.d.ts +76 -15
- package/dist/esm/type.js +5 -11
- package/dist/esm/utils.d.ts +9 -1
- package/dist/esm/utils.js +41 -1
- package/package.json +3 -3
- package/src/AI.ts +77 -0
- package/src/index.ts +3 -60
- package/src/models/Ark/index.ts +52 -54
- package/src/models/Ark/type.ts +60 -19
- package/src/models/DashScope/index.ts +56 -55
- package/src/models/DashScope/type.ts +63 -21
- package/src/models/HunYuan/index.ts +44 -67
- package/src/models/HunYuan/type.ts +68 -46
- package/src/models/HunYuan/util.ts +59 -0
- package/src/models/HunYuanBeta/index.ts +41 -75
- package/src/models/Moonshot/index.ts +52 -54
- package/src/models/Moonshot/type.ts +61 -7
- package/src/models/Yi/index.ts +59 -55
- package/src/models/Yi/type.ts +47 -19
- package/src/models/ZhiPu/index.ts +60 -52
- package/src/models/ZhiPu/type.ts +20 -9
- package/src/models/index.ts +25 -15
- package/src/models/model.ts +415 -0
- package/src/type.ts +100 -13
- package/src/utils.ts +53 -1
- package/dist/cjs/models/HunYuanBeta/type.d.ts +0 -52
- package/dist/cjs/models/HunYuanBeta/type.js +0 -3
- package/dist/esm/models/HunYuanBeta/type.d.ts +0 -52
- package/dist/esm/models/HunYuanBeta/type.js +0 -2
- 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"]}
|
package/dist/cjs/type.d.ts
CHANGED
|
@@ -1,17 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
abstract
|
|
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
|
|
36
|
-
role: 'user'
|
|
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 {};
|