@shuttl-io/core 0.2.0 → 0.4.3

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 (95) hide show
  1. package/.jsii +5562 -0
  2. package/.package.env +1 -0
  3. package/CHANGELOG.md +77 -0
  4. package/README.md +353 -1
  5. package/dist/Server.d.ts +1 -0
  6. package/dist/Server.js +1 -1
  7. package/dist/agent.js +2 -2
  8. package/dist/app.d.ts +2 -2
  9. package/dist/app.js +8 -6
  10. package/dist/model.js +1 -1
  11. package/dist/outcomes/CombinationOutcome.js +1 -1
  12. package/dist/outcomes/IOutcomes.js +1 -1
  13. package/dist/outcomes/StreamingOutcome.js +1 -1
  14. package/dist/secrets.js +2 -2
  15. package/dist/server/http.d.ts +44 -0
  16. package/dist/server/http.js +721 -4
  17. package/dist/tools/tool.js +2 -2
  18. package/dist/tools/toolkit.js +1 -1
  19. package/dist/trigger/ApiTrigger.js +1 -1
  20. package/dist/trigger/EmailTrigger.js +1 -1
  21. package/dist/trigger/FileTrigger.js +1 -1
  22. package/dist/trigger/ITrigger.js +1 -1
  23. package/dist/trigger/RateTrigger.js +1 -1
  24. package/package.json +2 -2
  25. package/publish.sh +436 -43
  26. package/dist/src/Server.d.ts +0 -5
  27. package/dist/src/Server.js +0 -3
  28. package/dist/src/Triggers.d.ts +0 -0
  29. package/dist/src/Triggers.js +0 -2
  30. package/dist/src/agent.d.ts +0 -49
  31. package/dist/src/agent.js +0 -251
  32. package/dist/src/app.d.ts +0 -17
  33. package/dist/src/app.js +0 -46
  34. package/dist/src/index.d.ts +0 -12
  35. package/dist/src/index.js +0 -29
  36. package/dist/src/model.d.ts +0 -6
  37. package/dist/src/model.js +0 -16
  38. package/dist/src/models/openAi.d.ts +0 -38
  39. package/dist/src/models/openAi.js +0 -344
  40. package/dist/src/models/types.d.ts +0 -101
  41. package/dist/src/models/types.js +0 -27
  42. package/dist/src/outcomes/CombinationOutcome.d.ts +0 -9
  43. package/dist/src/outcomes/CombinationOutcome.js +0 -41
  44. package/dist/src/outcomes/IOutcomes.d.ts +0 -9
  45. package/dist/src/outcomes/IOutcomes.js +0 -19
  46. package/dist/src/outcomes/StreamingOutcome.d.ts +0 -6
  47. package/dist/src/outcomes/StreamingOutcome.js +0 -30
  48. package/dist/src/outcomes/index.d.ts +0 -3
  49. package/dist/src/outcomes/index.js +0 -20
  50. package/dist/src/secrets.d.ts +0 -19
  51. package/dist/src/secrets.js +0 -34
  52. package/dist/src/server/http.d.ts +0 -68
  53. package/dist/src/server/http.js +0 -654
  54. package/dist/src/server/index.d.ts +0 -1
  55. package/dist/src/server/index.js +0 -18
  56. package/dist/src/tools/tool.d.ts +0 -33
  57. package/dist/src/tools/tool.js +0 -49
  58. package/dist/src/tools/toolkit.d.ts +0 -13
  59. package/dist/src/tools/toolkit.js +0 -19
  60. package/dist/src/trigger/ApiTrigger.d.ts +0 -37
  61. package/dist/src/trigger/ApiTrigger.js +0 -106
  62. package/dist/src/trigger/EmailTrigger.d.ts +0 -15
  63. package/dist/src/trigger/EmailTrigger.js +0 -22
  64. package/dist/src/trigger/FileTrigger.d.ts +0 -14
  65. package/dist/src/trigger/FileTrigger.js +0 -37
  66. package/dist/src/trigger/ITrigger.d.ts +0 -89
  67. package/dist/src/trigger/ITrigger.js +0 -35
  68. package/dist/src/trigger/RateTrigger.d.ts +0 -23
  69. package/dist/src/trigger/RateTrigger.js +0 -58
  70. package/dist/src/trigger/index.d.ts +0 -5
  71. package/dist/src/trigger/index.js +0 -22
  72. package/dist/tests/agent.test.d.ts +0 -1
  73. package/dist/tests/agent.test.js +0 -388
  74. package/dist/tests/agentStreamer.test.d.ts +0 -1
  75. package/dist/tests/agentStreamer.test.js +0 -530
  76. package/dist/tests/app.test.d.ts +0 -1
  77. package/dist/tests/app.test.js +0 -423
  78. package/dist/tests/model.test.d.ts +0 -1
  79. package/dist/tests/model.test.js +0 -310
  80. package/dist/tests/openAi.test.d.ts +0 -1
  81. package/dist/tests/openAi.test.js +0 -701
  82. package/dist/tests/outcomes.test.d.ts +0 -1
  83. package/dist/tests/outcomes.test.js +0 -257
  84. package/dist/tests/secrets.test.d.ts +0 -1
  85. package/dist/tests/secrets.test.js +0 -263
  86. package/dist/tests/server/http.test.d.ts +0 -1
  87. package/dist/tests/server/http.test.js +0 -553
  88. package/dist/tests/tool.test.d.ts +0 -1
  89. package/dist/tests/tool.test.js +0 -315
  90. package/dist/tests/toolkit.test.d.ts +0 -1
  91. package/dist/tests/toolkit.test.js +0 -189
  92. package/dist/tests/triggers.test.d.ts +0 -1
  93. package/dist/tests/triggers.test.js +0 -203
  94. package/dist/tests/types.test.d.ts +0 -1
  95. package/dist/tests/types.test.js +0 -429
@@ -1,344 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.OpenAIFactory = exports.OpenAI = exports.OpenAIBadKeyError = exports.OpenAIError = void 0;
4
- const types_1 = require("./types");
5
- class OpenAIError extends Error {
6
- constructor(message, statusCode, error) {
7
- super(message);
8
- this.statusCode = statusCode;
9
- this.error = error;
10
- this.isRetryable = true;
11
- this.isRetryable = true;
12
- }
13
- }
14
- exports.OpenAIError = OpenAIError;
15
- class OpenAIBadKeyError extends Error {
16
- constructor(message, statusCode, error) {
17
- super(message);
18
- this.statusCode = statusCode;
19
- this.error = error;
20
- this.isRetryable = false;
21
- this.isRetryable = false;
22
- }
23
- }
24
- exports.OpenAIBadKeyError = OpenAIBadKeyError;
25
- class OpenAI {
26
- constructor(identifier, apiKey, systemPrompt, tools) {
27
- this.identifier = identifier;
28
- this.apiKey = apiKey;
29
- this.systemPrompt = systemPrompt;
30
- this.tools = tools;
31
- this.messages = [];
32
- this.inputs = [];
33
- this.isDoneReceiving = true;
34
- // this.threadId = crypto.randomUUID();
35
- this.threadIDPromise = this.getThreadId();
36
- this.messages.push({
37
- content: systemPrompt,
38
- role: "system",
39
- });
40
- }
41
- async getThreadId() {
42
- // Make a request to the OpenAI API to create a new conversation. Use Node primitives to make the request.
43
- const response = await fetch("https://api.openai.com/v1/conversations", {
44
- method: "POST",
45
- headers: {
46
- "Authorization": `Bearer ${this.apiKey}`,
47
- "Content-Type": "application/json",
48
- },
49
- body: JSON.stringify({
50
- items: [
51
- {
52
- role: "system",
53
- content: this.systemPrompt,
54
- }
55
- ]
56
- }),
57
- });
58
- if (!response.ok) {
59
- const error = await response.json();
60
- throw new OpenAIError("failed to create thread", response.status, error);
61
- }
62
- const data = await response.json();
63
- const threadId = data.id;
64
- return threadId;
65
- }
66
- async invoke(prompt, streamer) {
67
- // If the model is not done receiving, wait for it to be done
68
- if (!this.isDoneReceiving) {
69
- return new Promise((resolve) => {
70
- setTimeout(async () => {
71
- await this.invoke(prompt, streamer);
72
- resolve();
73
- }, 0);
74
- });
75
- }
76
- this.isDoneReceiving = false;
77
- this.inputs.push(...prompt);
78
- if (!this.threadId) {
79
- this.threadId = await this.threadIDPromise;
80
- }
81
- // this.inputs.push(...prompt);
82
- const stream = true;
83
- const tools = this.tools?.map(tool => ({
84
- type: "function",
85
- name: tool.name,
86
- description: tool.description,
87
- parameters: {
88
- type: "object",
89
- properties: Object.entries(tool.schema?.properties ?? {}).reduce((acc, [name, arg]) => {
90
- const property = {
91
- type: arg.argType,
92
- description: arg.description,
93
- default: arg.defaultValue,
94
- };
95
- if (arg.enumValues) {
96
- property.enum = arg.enumValues;
97
- }
98
- acc[name] = property;
99
- return acc;
100
- }, {}),
101
- required: Object.entries(tool.schema?.properties ?? {}).filter(([_, arg]) => arg.required).map(([name]) => name),
102
- }
103
- }));
104
- const body = {
105
- model: this.identifier,
106
- conversation: this.threadId,
107
- input: this.inputs.map(input => this.createInput(input)),
108
- parallel_tool_calls: false,
109
- stream,
110
- tools: tools ?? [],
111
- };
112
- streamer.recieve(this, {
113
- eventName: "response.requested",
114
- data: {
115
- typeName: "response.requested",
116
- requested: body,
117
- threadId: this.threadId,
118
- },
119
- });
120
- try {
121
- const response = await fetch(`https://api.openai.com/v1/responses`, {
122
- method: "POST",
123
- headers: {
124
- "Authorization": `Bearer ${this.apiKey}`,
125
- "Content-Type": "application/json",
126
- },
127
- body: JSON.stringify(body),
128
- });
129
- if (!response.ok) {
130
- const error = await response.json();
131
- if (response.status === 401 && error.error.code === "invalid_api_key") {
132
- throw new OpenAIBadKeyError("bad API key", response.status, error);
133
- }
134
- throw new OpenAIError("failed to invoke model", response.status, error);
135
- }
136
- if (stream) {
137
- const reader = await response.body?.getReader();
138
- const decoder = new TextDecoder();
139
- let buffer = "";
140
- while (true) {
141
- const result = await reader?.read();
142
- if (!result) {
143
- break;
144
- }
145
- const { done, value } = result;
146
- if (done) {
147
- streamer.recieve(this, {
148
- eventName: "overall.completed",
149
- data: {
150
- typeName: "overall.completed",
151
- },
152
- threadId: this.threadId,
153
- });
154
- break;
155
- }
156
- buffer += decoder.decode(value, { stream: true });
157
- // Process complete messages (delimited by double newlines)
158
- let separatorIndex;
159
- while ((separatorIndex = buffer.indexOf("\n\n")) !== -1) {
160
- const rawMessage = buffer.slice(0, separatorIndex);
161
- buffer = buffer.slice(separatorIndex + 2);
162
- if (!rawMessage.trim()) {
163
- continue;
164
- }
165
- // Raw data is a string in the format of `event: <event_name>\ndata: <event_data>`
166
- const eventMatch = rawMessage.match(/^event: (.+)$/m);
167
- const dataMatch = rawMessage.match(/^data: (.+)$/m);
168
- if (eventMatch && dataMatch) {
169
- const eventName = eventMatch[1];
170
- const eventData = dataMatch[1];
171
- const data = JSON.parse(eventData);
172
- const response = this.createResponse(eventName, data);
173
- streamer.recieve(this, response);
174
- }
175
- }
176
- }
177
- }
178
- else {
179
- const data = await response.json();
180
- streamer.recieve(this, data);
181
- streamer.recieve(this, {
182
- eventName: "overall.completed",
183
- data: {
184
- typeName: "overall.completed",
185
- },
186
- threadId: this.threadId,
187
- });
188
- }
189
- }
190
- finally {
191
- this.isDoneReceiving = true;
192
- }
193
- }
194
- createInputContent(content) {
195
- if (content.typeName === "image") {
196
- return {
197
- type: "input_image",
198
- image_url: content.image,
199
- };
200
- }
201
- if (content.typeName === "file") {
202
- // Handle file attachments with base64 content
203
- if (content.fileData) {
204
- return {
205
- type: "input_file",
206
- filename: content.fileData.name,
207
- file_data: `data:${content.fileData.mimeType || "application/octet-stream"};base64,${content.fileData.content}`,
208
- };
209
- }
210
- // Fallback to URL-based file reference
211
- return {
212
- type: "input_file",
213
- file_url: content.file,
214
- };
215
- }
216
- return {
217
- type: "input_text",
218
- text: content.text,
219
- };
220
- }
221
- createInput(input) {
222
- if ("role" in input) {
223
- const realInput = input;
224
- // if content is not a string, content should be transformed to a chat GPT input
225
- if (typeof realInput.content !== "string") {
226
- if ((0, types_1.isInputContentArray)(realInput.content)) {
227
- const content = realInput.content.flatMap(c => this.createInputContent(c));
228
- return { role: realInput.role, content: content };
229
- }
230
- else if ((0, types_1.isInputContent)(realInput.content)) {
231
- let content = this.createInputContent(realInput.content);
232
- if (Array.isArray(content)) {
233
- return { role: realInput.role, content: content };
234
- }
235
- return { role: realInput.role, content: [content] };
236
- }
237
- }
238
- return { role: realInput.role, content: realInput.content };
239
- }
240
- return input;
241
- }
242
- createResponse(eventName, data) {
243
- switch (eventName) {
244
- case "response.completed":
245
- const response = data.response.output.reduce((acc, output) => {
246
- if (output.type === "function_call") {
247
- acc.push({
248
- typeName: "tool_call",
249
- toolCall: output,
250
- });
251
- }
252
- if (output.type === "message") {
253
- output.content.forEach((content) => {
254
- acc.push({
255
- typeName: "output_text",
256
- outputText: {
257
- outputType: "output_text",
258
- text: content.text,
259
- },
260
- });
261
- });
262
- }
263
- return acc;
264
- }, []);
265
- return {
266
- eventName: "response.completed",
267
- modelInstance: this,
268
- data: {
269
- typeName: "response.completed",
270
- ...response,
271
- },
272
- usage: data.response.usage,
273
- };
274
- case "response.output_text.delta":
275
- return {
276
- eventName: "response.output_text_delta",
277
- modelInstance: this,
278
- data: {
279
- typeName: "output_text_delta",
280
- outputTextDelta: {
281
- outputType: "output_text_delta",
282
- delta: data.delta,
283
- sequenceNumber: data.sequence_number,
284
- },
285
- },
286
- };
287
- case "response.content_part.done":
288
- return {
289
- eventName: "response.content_part.done",
290
- modelInstance: this,
291
- data: {
292
- typeName: "output_text",
293
- outputText: {
294
- outputType: "output_text",
295
- text: data.part.text,
296
- },
297
- },
298
- };
299
- case "response.output_item.done":
300
- const output = data.item;
301
- if (output.type === "message") {
302
- return {
303
- eventName: "response.output_text.done",
304
- modelInstance: this,
305
- data: {
306
- typeName: "output_text.part.done",
307
- outputText: {
308
- outputType: "output_text",
309
- text: output.content[0].text,
310
- }
311
- },
312
- };
313
- }
314
- return {
315
- eventName: "response.completed",
316
- modelInstance: this,
317
- data: {
318
- typeName: "tool_call",
319
- toolCall: {
320
- outputType: "tool_call",
321
- name: output.name,
322
- arguments: JSON.parse(output.arguments),
323
- callId: output.call_id,
324
- },
325
- },
326
- };
327
- default:
328
- return data;
329
- }
330
- }
331
- }
332
- exports.OpenAI = OpenAI;
333
- class OpenAIFactory {
334
- constructor(identifier, apiKey) {
335
- this.identifier = identifier;
336
- this.apiKey = apiKey;
337
- this.create = this.create.bind(this);
338
- }
339
- async create(props) {
340
- return new OpenAI(this.identifier, await this.apiKey.resolveSecret(), props.systemPrompt, props.tools);
341
- }
342
- }
343
- exports.OpenAIFactory = OpenAIFactory;
344
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3BlbkFpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21vZGVscy9vcGVuQWkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsbUNBWWlCO0FBR2pCLE1BQWEsV0FBWSxTQUFRLEtBQUs7SUFFbEMsWUFDSSxPQUFlLEVBQ0MsVUFBa0IsRUFDbEIsS0FBVTtRQUUxQixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFIQyxlQUFVLEdBQVYsVUFBVSxDQUFRO1FBQ2xCLFVBQUssR0FBTCxLQUFLLENBQUs7UUFKZCxnQkFBVyxHQUFZLElBQUksQ0FBQztRQU94QyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztJQUM1QixDQUFDO0NBQ0o7QUFWRCxrQ0FVQztBQUNELE1BQWEsaUJBQWtCLFNBQVEsS0FBSztJQUV4QyxZQUFZLE9BQWUsRUFBa0IsVUFBa0IsRUFBa0IsS0FBVTtRQUN2RixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFEMEIsZUFBVSxHQUFWLFVBQVUsQ0FBUTtRQUFrQixVQUFLLEdBQUwsS0FBSyxDQUFLO1FBRDNFLGdCQUFXLEdBQVksS0FBSyxDQUFDO1FBR3pDLElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxDQUFDO0lBQzdCLENBQUM7Q0FDSjtBQU5ELDhDQU1DO0FBRUQsTUFBYSxNQUFNO0lBT2YsWUFDb0IsVUFBa0IsRUFDbEIsTUFBYyxFQUNkLFlBQW9CLEVBQ3BCLEtBQWU7UUFIZixlQUFVLEdBQVYsVUFBVSxDQUFRO1FBQ2xCLFdBQU0sR0FBTixNQUFNLENBQVE7UUFDZCxpQkFBWSxHQUFaLFlBQVksQ0FBUTtRQUNwQixVQUFLLEdBQUwsS0FBSyxDQUFVO1FBVmxCLGFBQVEsR0FBbUIsRUFBRSxDQUFDO1FBR3ZDLFdBQU0sR0FBd0MsRUFBRSxDQUFDO1FBQ2xELG9CQUFlLEdBQVksSUFBSSxDQUFDO1FBU25DLHVDQUF1QztRQUN2QyxJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FB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Q0osQ0FBQztnQkFDTixDQUFDO2dCQUNELE9BQU87b0JBQ0gsU0FBUyxFQUFFLG9CQUFvQjtvQkFDL0IsYUFBYSxFQUFFLElBQUk7b0JBQ25CLElBQUksRUFBRTt3QkFDRixRQUFRLEVBQUUsV0FBVzt3QkFDckIsUUFBUSxFQUFFOzRCQUNOLFVBQVUsRUFBRSxXQUFXOzRCQUN2QixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUk7NEJBQ2pCLFNBQVMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUM7NEJBQ3ZDLE1BQU0sRUFBRSxNQUFNLENBQUMsT0FBTzt5QkFDekI7cUJBQ0o7aUJBQ0osQ0FBQztZQUNOO2dCQUNJLE9BQU8sSUFBSSxDQUFDO1FBQ3BCLENBQUM7SUFDTCxDQUFDO0NBQ0o7QUFwVUQsd0JBb1VDO0FBRUQsTUFBYSxhQUFhO0lBQ3RCLFlBQ29CLFVBQWtCLEVBQ2xCLE1BQWU7UUFEZixlQUFVLEdBQVYsVUFBVSxDQUFRO1FBQ2xCLFdBQU0sR0FBTixNQUFNLENBQVM7UUFFL0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRU0sS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUF5QjtRQUN6QyxPQUFPLElBQUksTUFBTSxDQUNiLElBQUksQ0FBQyxVQUFVLEVBQ2YsTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsRUFBRSxFQUNqQyxLQUFLLENBQUMsWUFBWSxFQUNsQixLQUFLLENBQUMsS0FBSyxDQUNkLENBQUM7SUFDTixDQUFDO0NBQ0o7QUFoQkQsc0NBZ0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVNlY3JldCB9IGZyb20gXCIuLi9zZWNyZXRzXCI7XG5pbXBvcnQgeyBcbiAgICBJTW9kZWwsIFxuICAgIElNb2RlbEZhY3RvcnksIFxuICAgIElNb2RlbEZhY3RvcnlQcm9wcyxcbiAgICBNb2RlbENvbnRlbnQsXG4gICAgSU1vZGVsU3RyZWFtZXIsXG4gICAgTW9kZWxSZXNwb25zZSxcbiAgICBUb29sQ2FsbFJlc3BvbnNlLFxuICAgIE1vZGVsUmVzcG9uc2VEYXRhLFxuICAgIGlzSW5wdXRDb250ZW50QXJyYXksXG4gICAgaXNJbnB1dENvbnRlbnQsXG4gICAgSW5wdXRDb250ZW50LFxufSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHsgSVRvb2wgfSBmcm9tIFwiLi4vdG9vbHMvdG9vbFwiO1xuXG5leHBvcnQgY2xhc3MgT3BlbkFJRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gICAgcHVibGljIHJlYWRvbmx5IGlzUmV0cnlhYmxlOiBib29sZWFuID0gdHJ1ZTtcbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgbWVzc2FnZTogc3RyaW5nLCBcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHN0YXR1c0NvZGU6IG51bWJlciwgXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBlcnJvcjogYW55LFxuICAgICkge1xuICAgICAgICBzdXBlcihtZXNzYWdlKTtcbiAgICAgICAgdGhpcy5pc1JldHJ5YWJsZSA9IHRydWU7XG4gICAgfVxufVxuZXhwb3J0IGNsYXNzIE9wZW5BSUJhZEtleUVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICAgIHB1YmxpYyByZWFkb25seSBpc1JldHJ5YWJsZTogYm9vbGVhbiA9IGZhbHNlO1xuICAgIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZywgcHVibGljIHJlYWRvbmx5IHN0YXR1c0NvZGU6IG51bWJlciwgcHVibGljIHJlYWRvbmx5IGVycm9yOiBhbnkpIHtcbiAgICAgICAgc3VwZXIobWVzc2FnZSk7XG4gICAgICAgIHRoaXMuaXNSZXRyeWFibGUgPSBmYWxzZTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBPcGVuQUkgaW1wbGVtZW50cyBJTW9kZWwge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgbWVzc2FnZXM6IE1vZGVsQ29udGVudFtdID0gW107XG4gICAgcHJpdmF0ZSB0aHJlYWRJRFByb21pc2U6IFByb21pc2U8c3RyaW5nPjtcbiAgICBwdWJsaWMgdGhyZWFkSWQ/OiBzdHJpbmc7XG4gICAgcHJpdmF0ZSBpbnB1dHM6IChNb2RlbENvbnRlbnQgfCBUb29sQ2FsbFJlc3BvbnNlKVtdID0gW107XG4gICAgcHVibGljIGlzRG9uZVJlY2VpdmluZzogYm9vbGVhbiA9IHRydWU7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBpZGVudGlmaWVyOiBzdHJpbmcsXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBhcGlLZXk6IHN0cmluZyxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHN5c3RlbVByb21wdDogc3RyaW5nLFxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgdG9vbHM/OiBJVG9vbFtdLFxuICAgICl7XG5cbiAgICAgICAgLy8gdGhpcy50aHJlYWRJZCA9IGNyeXB0by5yYW5kb21VVUlEKCk7XG4gICAgICAgIHRoaXMudGhyZWFkSURQcm9taXNlID0gdGhpcy5nZXRUaHJlYWRJZCgpO1xuICAgICAgICB0aGlzLm1lc3NhZ2VzLnB1c2goe1xuICAgICAgICAgICAgY29udGVudDogc3lzdGVtUHJvbXB0LFxuICAgICAgICAgICAgcm9sZTogXCJzeXN0ZW1cIixcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBhc3luYyBnZXRUaHJlYWRJZCgpOiBQcm9taXNlPHN0cmluZz4ge1xuICAgICAgICAvLyBNYWtlIGEgcmVxdWVzdCB0byB0aGUgT3BlbkFJIEFQSSB0byBjcmVhdGUgYSBuZXcgY29udmVyc2F0aW9uLiBVc2UgTm9kZSBwcmltaXRpdmVzIHRvIG1ha2UgdGhlIHJlcXVlc3QuXG4gICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2goXCJodHRwczovL2FwaS5vcGVuYWkuY29tL3YxL2NvbnZlcnNhdGlvbnNcIiwge1xuICAgICAgICAgICAgbWV0aG9kOiBcIlBPU1RcIixcbiAgICAgICAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgICAgICAgICBcIkF1dGhvcml6YXRpb25cIjogYEJlYXJlciAke3RoaXMuYXBpS2V5fWAsXG4gICAgICAgICAgICAgICAgXCJDb250ZW50LVR5cGVcIjogXCJhcHBsaWNhdGlvbi9qc29uXCIsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgYm9keTogSlNPTi5zdHJpbmdpZnkoe1xuICAgICAgICAgICAgICAgIGl0ZW1zOiBbXG4gICAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJvbGU6IFwic3lzdGVtXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICBjb250ZW50OiB0aGlzLnN5c3RlbVByb21wdCxcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICAgIH0pLFxuICAgICAgICB9KTtcbiAgICAgICAgaWYgKCFyZXNwb25zZS5vaykge1xuICAgICAgICAgICAgY29uc3QgZXJyb3IgPSBhd2FpdCByZXNwb25zZS5qc29uKCk7XG4gICAgICAgICAgICB0aHJvdyBuZXcgT3BlbkFJRXJyb3IoXCJmYWlsZWQgdG8gY3JlYXRlIHRocmVhZFwiLCByZXNwb25zZS5zdGF0dXMsIGVycm9yKTtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBkYXRhID0gYXdhaXQgcmVzcG9uc2UuanNvbigpIGFzIHsgaWQ6IHN0cmluZywgb2JqZWN0OiBzdHJpbmcgfTtcbiAgICAgICAgY29uc3QgdGhyZWFkSWQgPSBkYXRhLmlkO1xuICAgICAgICByZXR1cm4gdGhyZWFkSWQ7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIGludm9rZShwcm9tcHQ6IE1vZGVsQ29udGVudFtdLCBzdHJlYW1lcjogSU1vZGVsU3RyZWFtZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgLy8gSWYgdGhlIG1vZGVsIGlzIG5vdCBkb25lIHJlY2VpdmluZywgd2FpdCBmb3IgaXQgdG8gYmUgZG9uZVxuICAgICAgICBpZiAoIXRoaXMuaXNEb25lUmVjZWl2aW5nKSB7XG4gICAgICAgICAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRUaW1lb3V0KGFzeW5jICgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgYXdhaXQgdGhpcy5pbnZva2UocHJvbXB0LCBzdHJlYW1lcik7XG4gICAgICAgICAgICAgICAgICAgIHJlc29sdmUoKTtcbiAgICAgICAgICAgICAgICB9LCAwKTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuaXNEb25lUmVjZWl2aW5nID0gZmFsc2U7XG4gICAgICAgIHRoaXMuaW5wdXRzLnB1c2goLi4ucHJvbXB0KTtcbiAgICAgICAgaWYgKCF0aGlzLnRocmVhZElkKSB7XG4gICAgICAgICAgICB0aGlzLnRocmVhZElkID0gYXdhaXQgdGhpcy50aHJlYWRJRFByb21pc2U7XG4gICAgICAgIH1cbiAgICAgICAgLy8gdGhpcy5pbnB1dHMucHVzaCguLi5wcm9tcHQpO1xuICAgICAgICBjb25zdCBzdHJlYW0gPSB0cnVlO1xuICAgICAgICBjb25zdCB0b29scyA9IHRoaXMudG9vbHM/Lm1hcCh0b29sID0+ICh7XG4gICAgICAgICAgICB0eXBlOiBcImZ1bmN0aW9uXCIsXG4gICAgICAgICAgICBuYW1lOiB0b29sLm5hbWUsXG4gICAgICAgICAgICBkZXNjcmlwdGlvbjogdG9vbC5kZXNjcmlwdGlvbixcbiAgICAgICAgICAgIHBhcmFtZXRlcnM6IHtcbiAgICAgICAgICAgICAgICB0eXBlOiBcIm9iamVjdFwiLFxuICAgICAgICAgICAgICAgIHByb3BlcnRpZXM6IE9iamVjdC5lbnRyaWVzKHRvb2wuc2NoZW1hPy5wcm9wZXJ0aWVzID8/IHt9KS5yZWR1Y2UoKGFjYywgW25hbWUsIGFyZ10pID0+IHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgcHJvcGVydHk6IFJlY29yZDxzdHJpbmcsIGFueT4gPSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0eXBlOiBhcmcuYXJnVHlwZSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGRlc2NyaXB0aW9uOiBhcmcuZGVzY3JpcHRpb24sXG4gICAgICAgICAgICAgICAgICAgICAgICBkZWZhdWx0OiBhcmcuZGVmYXVsdFZhbHVlLFxuICAgICAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgICAgICAgICBpZiAoYXJnLmVudW1WYWx1ZXMpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHByb3BlcnR5LmVudW0gPSBhcmcuZW51bVZhbHVlcztcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBhY2NbbmFtZV0gPSBwcm9wZXJ0eTtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgICAgICAgICAgICB9LCB7fSBhcyBSZWNvcmQ8c3RyaW5nLCBhbnk+KSxcbiAgICAgICAgICAgICAgICByZXF1aXJlZDogT2JqZWN0LmVudHJpZXModG9vbC5zY2hlbWE/LnByb3BlcnRpZXMgPz8ge30pLmZpbHRlcigoW18sIGFyZ10pID0+IGFyZy5yZXF1aXJlZCkubWFwKChbbmFtZV0pID0+IG5hbWUpLFxuICAgICAgICAgICAgfVxuICAgICAgICB9KSk7XG4gICAgICAgIGNvbnN0IGJvZHkgPSB7XG4gICAgICAgICAgICAgICAgbW9kZWw6IHRoaXMuaWRlbnRpZmllcixcbiAgICAgICAgICAgICAgICBjb252ZXJzYXRpb246IHRoaXMudGhyZWFkSWQsXG4gICAgICAgICAgICAgICAgaW5wdXQ6IHRoaXMuaW5wdXRzLm1hcChpbnB1dCA9PiB0aGlzLmNyZWF0ZUlucHV0KGlucHV0KSksXG4gICAgICAgICAgICAgICAgcGFyYWxsZWxfdG9vbF9jYWxsczogZmFsc2UsXG4gICAgICAgICAgICAgICAgc3RyZWFtLFxuICAgICAgICAgICAgICAgIHRvb2xzOiB0b29scyA/PyBbXSxcbiAgICAgICAgfVxuICAgICAgICBzdHJlYW1lci5yZWNpZXZlKHRoaXMsIHtcbiAgICAgICAgICAgIGV2ZW50TmFtZTogXCJyZXNwb25zZS5yZXF1ZXN0ZWRcIixcbiAgICAgICAgICAgIGRhdGE6IHtcbiAgICAgICAgICAgICAgICB0eXBlTmFtZTogXCJyZXNwb25zZS5yZXF1ZXN0ZWRcIixcbiAgICAgICAgICAgICAgICByZXF1ZXN0ZWQ6IGJvZHksXG4gICAgICAgICAgICAgICAgdGhyZWFkSWQ6IHRoaXMudGhyZWFkSWQsXG4gICAgICAgICAgICB9LFxuICAgICAgICB9KTtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2goYGh0dHBzOi8vYXBpLm9wZW5haS5jb20vdjEvcmVzcG9uc2VzYCwge1xuICAgICAgICAgICAgICAgIG1ldGhvZDogXCJQT1NUXCIsXG4gICAgICAgICAgICAgICAgaGVhZGVyczoge1xuICAgICAgICAgICAgICAgICAgICBcIkF1dGhvcml6YXRpb25cIjogYEJlYXJlciAke3RoaXMuYXBpS2V5fWAsXG4gICAgICAgICAgICAgICAgICAgIFwiQ29udGVudC1UeXBlXCI6IFwiYXBwbGljYXRpb24vanNvblwiLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgYm9keTogSlNPTi5zdHJpbmdpZnkoYm9keSksXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIGlmICghcmVzcG9uc2Uub2spIHtcbiAgICAgICAgICAgICAgICBjb25zdCBlcnJvciA9IGF3YWl0IHJlc3BvbnNlLmpzb24oKSBhcyBhbnk7XG4gICAgICAgICAgICAgICAgaWYgKHJlc3BvbnNlLnN0YXR1cyA9PT0gNDAxICYmIGVycm9yLmVycm9yLmNvZGUgPT09IFwiaW52YWxpZF9hcGlfa2V5XCIpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhyb3cgbmV3IE9wZW5BSUJhZEtleUVycm9yKFwiYmFkIEFQSSBrZXlcIiwgcmVzcG9uc2Uuc3RhdHVzLCBlcnJvcik7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHRocm93IG5ldyBPcGVuQUlFcnJvcihcImZhaWxlZCB0byBpbnZva2UgbW9kZWxcIiwgcmVzcG9uc2Uuc3RhdHVzLCBlcnJvcik7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoc3RyZWFtKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgcmVhZGVyID0gYXdhaXQgcmVzcG9uc2UuYm9keT8uZ2V0UmVhZGVyKCk7XG4gICAgICAgICAgICAgICAgY29uc3QgZGVjb2RlciA9IG5ldyBUZXh0RGVjb2RlcigpO1xuICAgICAgICAgICAgICAgIGxldCBidWZmZXIgPSBcIlwiO1xuXG4gICAgICAgICAgICAgICAgd2hpbGUgKHRydWUpIHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgcmVhZGVyPy5yZWFkKCk7XG4gICAgICAgICAgICAgICAgICAgIGlmICghcmVzdWx0KSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBjb25zdCB7IGRvbmUsIHZhbHVlIH0gPSByZXN1bHQ7XG4gICAgICAgICAgICAgICAgICAgIGlmIChkb25lKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBzdHJlYW1lci5yZWNpZXZlKHRoaXMsIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBldmVudE5hbWU6IFwib3ZlcmFsbC5jb21wbGV0ZWRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHR5cGVOYW1lOiBcIm92ZXJhbGwuY29tcGxldGVkXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aHJlYWRJZDogdGhpcy50aHJlYWRJZCxcbiAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgIGJ1ZmZlciArPSBkZWNvZGVyLmRlY29kZSh2YWx1ZSwgeyBzdHJlYW06IHRydWUgfSk7XG4gICAgICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgICAgICAvLyBQcm9jZXNzIGNvbXBsZXRlIG1lc3NhZ2VzIChkZWxpbWl0ZWQgYnkgZG91YmxlIG5ld2xpbmVzKVxuICAgICAgICAgICAgICAgICAgICBsZXQgc2VwYXJhdG9ySW5kZXg6IG51bWJlcjtcbiAgICAgICAgICAgICAgICAgICAgd2hpbGUgKChzZXBhcmF0b3JJbmRleCA9IGJ1ZmZlci5pbmRleE9mKFwiXFxuXFxuXCIpKSAhPT0gLTEpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbnN0IHJhd01lc3NhZ2UgPSBidWZmZXIuc2xpY2UoMCwgc2VwYXJhdG9ySW5kZXgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgYnVmZmVyID0gYnVmZmVyLnNsaWNlKHNlcGFyYXRvckluZGV4ICsgMik7XG4gICAgICAgICAgICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmICghcmF3TWVzc2FnZS50cmltKCkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgICAgICAgICAgLy8gUmF3IGRhdGEgaXMgYSBzdHJpbmcgaW4gdGhlIGZvcm1hdCBvZiBgZXZlbnQ6IDxldmVudF9uYW1lPlxcbmRhdGE6IDxldmVudF9kYXRhPmBcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbnN0IGV2ZW50TWF0Y2ggPSByYXdNZXNzYWdlLm1hdGNoKC9eZXZlbnQ6ICguKykkL20pO1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QgZGF0YU1hdGNoID0gcmF3TWVzc2FnZS5tYXRjaCgvXmRhdGE6ICguKykkL20pO1xuICAgICAgICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAoZXZlbnRNYXRjaCAmJiBkYXRhTWF0Y2gpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBldmVudE5hbWUgPSBldmVudE1hdGNoWzFdO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNvbnN0IGV2ZW50RGF0YSA9IGRhdGFNYXRjaFsxXTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBkYXRhID0gSlNPTi5wYXJzZShldmVudERhdGEpIGFzIGFueTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zdCByZXNwb25zZSA9IHRoaXMuY3JlYXRlUmVzcG9uc2UoZXZlbnROYW1lLCBkYXRhKTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdHJlYW1lci5yZWNpZXZlKHRoaXMsIHJlc3BvbnNlKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICBjb25zdCBkYXRhID0gYXdhaXQgcmVzcG9uc2UuanNvbigpO1xuICAgICAgICAgICAgICAgIHN0cmVhbWVyLnJlY2lldmUodGhpcywgZGF0YSBhcyBhbnkpO1xuICAgICAgICAgICAgICAgIHN0cmVhbWVyLnJlY2lldmUodGhpcywge1xuICAgICAgICAgICAgICAgICAgICBldmVudE5hbWU6IFwib3ZlcmFsbC5jb21wbGV0ZWRcIixcbiAgICAgICAgICAgICAgICAgICAgZGF0YToge1xuICAgICAgICAgICAgICAgICAgICAgICAgdHlwZU5hbWU6IFwib3ZlcmFsbC5jb21wbGV0ZWRcIixcbiAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICAgICAgdGhyZWFkSWQ6IHRoaXMudGhyZWFkSWQsXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgfVxuICAgICAgICBmaW5hbGx5IHtcbiAgICAgICAgICAgIHRoaXMuaXNEb25lUmVjZWl2aW5nID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICBcbiAgICB9XG5cbiAgICBwcml2YXRlIGNyZWF0ZUlucHV0Q29udGVudChjb250ZW50OiBJbnB1dENvbnRlbnQpIHtcbiAgICAgICAgXG4gICAgICAgIGlmIChjb250ZW50LnR5cGVOYW1lID09PSBcImltYWdlXCIpIHtcbiAgICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAgICAgdHlwZTogXCJpbnB1dF9pbWFnZVwiLFxuICAgICAgICAgICAgICAgIGltYWdlX3VybDogY29udGVudC5pbWFnZSxcbiAgICAgICAgICAgIH07XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGNvbnRlbnQudHlwZU5hbWUgPT09IFwiZmlsZVwiKSB7XG4gICAgICAgICAgICAvLyBIYW5kbGUgZmlsZSBhdHRhY2htZW50cyB3aXRoIGJhc2U2NCBjb250ZW50XG4gICAgICAgICAgICBpZiAoY29udGVudC5maWxlRGF0YSkge1xuICAgICAgICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAgICAgICAgIHR5cGU6IFwiaW5wdXRfZmlsZVwiLFxuICAgICAgICAgICAgICAgICAgICBmaWxlbmFtZTogY29udGVudC5maWxlRGF0YS5uYW1lLFxuICAgICAgICAgICAgICAgICAgICBmaWxlX2RhdGE6IGBkYXRhOiR7Y29udGVudC5maWxlRGF0YS5taW1lVHlwZSB8fCBcImFwcGxpY2F0aW9uL29jdGV0LXN0cmVhbVwifTtiYXNlNjQsJHtjb250ZW50LmZpbGVEYXRhLmNvbnRlbnR9YCxcbiAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgLy8gRmFsbGJhY2sgdG8gVVJMLWJhc2VkIGZpbGUgcmVmZXJlbmNlXG4gICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgIHR5cGU6IFwiaW5wdXRfZmlsZVwiLFxuICAgICAgICAgICAgICAgIGZpbGVfdXJsOiBjb250ZW50LmZpbGUsXG4gICAgICAgICAgICB9O1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0eXBlOiBcImlucHV0X3RleHRcIixcbiAgICAgICAgICAgIHRleHQ6IGNvbnRlbnQudGV4dCxcbiAgICAgICAgfTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGNyZWF0ZUlucHV0KGlucHV0OiBNb2RlbENvbnRlbnQgfCBUb29sQ2FsbFJlc3BvbnNlKTogTW9kZWxDb250ZW50IHwgVG9vbENhbGxSZXNwb25zZSB7XG4gICAgICAgIGlmIChcInJvbGVcIiBpbiBpbnB1dCkge1xuICAgICAgICAgICAgY29uc3QgcmVhbElucHV0ID0gaW5wdXQgYXMgTW9kZWxDb250ZW50O1xuICAgICAgICAgICAgLy8gaWYgY29udGVudCBpcyBub3QgYSBzdHJpbmcsIGNvbnRlbnQgc2hvdWxkIGJlIHRyYW5zZm9ybWVkIHRvIGEgY2hhdCBHUFQgaW5wdXRcbiAgICAgICAgICAgIGlmICh0eXBlb2YgcmVhbElucHV0LmNvbnRlbnQgIT09IFwic3RyaW5nXCIpIHtcbiAgICAgICAgICAgICAgICBpZiAoaXNJbnB1dENvbnRlbnRBcnJheShyZWFsSW5wdXQuY29udGVudCkpIHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgY29udGVudCA9IHJlYWxJbnB1dC5jb250ZW50LmZsYXRNYXAoYyA9PiB0aGlzLmNyZWF0ZUlucHV0Q29udGVudChjKSk7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB7cm9sZTogcmVhbElucHV0LnJvbGUsIGNvbnRlbnQ6IGNvbnRlbnR9O1xuICAgICAgICAgICAgICAgIH0gZWxzZSBpZiAoaXNJbnB1dENvbnRlbnQocmVhbElucHV0LmNvbnRlbnQpKSB7XG4gICAgICAgICAgICAgICAgICAgIGxldCBjb250ZW50ID0gdGhpcy5jcmVhdGVJbnB1dENvbnRlbnQocmVhbElucHV0LmNvbnRlbnQpO1xuICAgICAgICAgICAgICAgICAgICBpZiAoQXJyYXkuaXNBcnJheShjb250ZW50KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHsgcm9sZTogcmVhbElucHV0LnJvbGUsIGNvbnRlbnQ6IGNvbnRlbnQgfTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICByZXR1cm4geyByb2xlOiByZWFsSW5wdXQucm9sZSwgY29udGVudDogW2NvbnRlbnRdIH07XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIHsgcm9sZTogcmVhbElucHV0LnJvbGUsIGNvbnRlbnQ6IHJlYWxJbnB1dC5jb250ZW50IH07XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGlucHV0IGFzIFRvb2xDYWxsUmVzcG9uc2U7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjcmVhdGVSZXNwb25zZShldmVudE5hbWU6IHN0cmluZywgZGF0YTogYW55KTogTW9kZWxSZXNwb25zZSB7XG4gICAgICAgIHN3aXRjaChldmVudE5hbWUpIHtcbiAgICAgICAgICAgIGNhc2UgXCJyZXNwb25zZS5jb21wbGV0ZWRcIjpcbiAgICAgICAgICAgICAgICBjb25zdCByZXNwb25zZSA9IGRhdGEucmVzcG9uc2Uub3V0cHV0LnJlZHVjZSgoYWNjOiBNb2RlbFJlc3BvbnNlRGF0YVtdLCBvdXRwdXQ6IGFueSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAob3V0cHV0LnR5cGUgPT09IFwiZnVuY3Rpb25fY2FsbFwiKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBhY2MucHVzaCh7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdHlwZU5hbWU6IFwidG9vbF9jYWxsXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdG9vbENhbGw6IG91dHB1dCxcbiAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIGlmIChvdXRwdXQudHlwZSA9PT0gXCJtZXNzYWdlXCIpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG91dHB1dC5jb250ZW50LmZvckVhY2goKGNvbnRlbnQ6IGFueSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFjYy5wdXNoKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdHlwZU5hbWU6IFwib3V0cHV0X3RleHRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb3V0cHV0VGV4dDoge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb3V0cHV0VHlwZTogXCJvdXRwdXRfdGV4dFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGV4dDogY29udGVudC50ZXh0LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgICAgICAgICAgICB9LCBbXSk7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgZXZlbnROYW1lOiBcInJlc3BvbnNlLmNvbXBsZXRlZFwiLFxuICAgICAgICAgICAgICAgICAgICBtb2RlbEluc3RhbmNlOiB0aGlzLFxuICAgICAgICAgICAgICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0eXBlTmFtZTogXCJyZXNwb25zZS5jb21wbGV0ZWRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIC4uLnJlc3BvbnNlLFxuICAgICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgICAgICB1c2FnZTogZGF0YS5yZXNwb25zZS51c2FnZSxcbiAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgY2FzZSBcInJlc3BvbnNlLm91dHB1dF90ZXh0LmRlbHRhXCI6XG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgZXZlbnROYW1lOiBcInJlc3BvbnNlLm91dHB1dF90ZXh0X2RlbHRhXCIsXG4gICAgICAgICAgICAgICAgICAgIG1vZGVsSW5zdGFuY2U6IHRoaXMsXG4gICAgICAgICAgICAgICAgICAgIGRhdGE6IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHR5cGVOYW1lOiBcIm91dHB1dF90ZXh0X2RlbHRhXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICBvdXRwdXRUZXh0RGVsdGE6IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBvdXRwdXRUeXBlOiBcIm91dHB1dF90ZXh0X2RlbHRhXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVsdGE6IGRhdGEuZGVsdGEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc2VxdWVuY2VOdW1iZXI6IGRhdGEuc2VxdWVuY2VfbnVtYmVyLFxuICAgICAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgY2FzZSBcInJlc3BvbnNlLmNvbnRlbnRfcGFydC5kb25lXCI6XG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgZXZlbnROYW1lOiBcInJlc3BvbnNlLmNvbnRlbnRfcGFydC5kb25lXCIsXG4gICAgICAgICAgICAgICAgICAgIG1vZGVsSW5zdGFuY2U6IHRoaXMsXG4gICAgICAgICAgICAgICAgICAgIGRhdGE6IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHR5cGVOYW1lOiBcIm91dHB1dF90ZXh0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICBvdXRwdXRUZXh0OiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgb3V0cHV0VHlwZTogXCJvdXRwdXRfdGV4dFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRleHQ6IGRhdGEucGFydC50ZXh0LFxuICAgICAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgY2FzZSBcInJlc3BvbnNlLm91dHB1dF9pdGVtLmRvbmVcIjpcbiAgICAgICAgICAgICAgICBjb25zdCBvdXRwdXQgPSBkYXRhLml0ZW07XG4gICAgICAgICAgICAgICAgaWYgKG91dHB1dC50eXBlID09PSBcIm1lc3NhZ2VcIikge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZXZlbnROYW1lOiBcInJlc3BvbnNlLm91dHB1dF90ZXh0LmRvbmVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIG1vZGVsSW5zdGFuY2U6IHRoaXMsXG4gICAgICAgICAgICAgICAgICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdHlwZU5hbWU6IFwib3V0cHV0X3RleHQucGFydC5kb25lXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgb3V0cHV0VGV4dDoge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvdXRwdXRUeXBlOiBcIm91dHB1dF90ZXh0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRleHQ6IG91dHB1dC5jb250ZW50WzBdLnRleHQsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICAgICAgfTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgZXZlbnROYW1lOiBcInJlc3BvbnNlLmNvbXBsZXRlZFwiLFxuICAgICAgICAgICAgICAgICAgICBtb2RlbEluc3RhbmNlOiB0aGlzLFxuICAgICAgICAgICAgICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0eXBlTmFtZTogXCJ0b29sX2NhbGxcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIHRvb2xDYWxsOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgb3V0cHV0VHlwZTogXCJ0b29sX2NhbGxcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBuYW1lOiBvdXRwdXQubmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBhcmd1bWVudHM6IEpTT04ucGFyc2Uob3V0cHV0LmFyZ3VtZW50cyksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgY2FsbElkOiBvdXRwdXQuY2FsbF9pZCxcbiAgICAgICAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgfTtcbiAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGRhdGE7XG4gICAgICAgIH1cbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBPcGVuQUlGYWN0b3J5IGltcGxlbWVudHMgSU1vZGVsRmFjdG9yeSB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBpZGVudGlmaWVyOiBzdHJpbmcsXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBhcGlLZXk6IElTZWNyZXQsXG4gICAgKXtcbiAgICAgICAgdGhpcy5jcmVhdGUgPSB0aGlzLmNyZWF0ZS5iaW5kKHRoaXMpO1xuICAgIH1cblxuICAgIHB1YmxpYyBhc3luYyBjcmVhdGUocHJvcHM6IElNb2RlbEZhY3RvcnlQcm9wcyk6IFByb21pc2U8SU1vZGVsPiB7XG4gICAgICAgIHJldHVybiBuZXcgT3BlbkFJKFxuICAgICAgICAgICAgdGhpcy5pZGVudGlmaWVyLFxuICAgICAgICAgICAgYXdhaXQgdGhpcy5hcGlLZXkucmVzb2x2ZVNlY3JldCgpLFxuICAgICAgICAgICAgcHJvcHMuc3lzdGVtUHJvbXB0LFxuICAgICAgICAgICAgcHJvcHMudG9vbHMsXG4gICAgICAgICk7XG4gICAgfVxufSJdfQ==
@@ -1,101 +0,0 @@
1
- import { ITool } from "../tools/tool";
2
- /**
3
- * Represents a file attachment sent with a chat message
4
- */
5
- export interface FileAttachment {
6
- /** The file name */
7
- readonly name: string;
8
- /** The file path (optional, may not be relevant in all contexts) */
9
- readonly path?: string;
10
- /** Base64 encoded file content */
11
- readonly content: string;
12
- /** MIME type of the file */
13
- readonly mimeType?: string;
14
- }
15
- export declare const isFileAttachment: (obj: any) => obj is FileAttachment;
16
- export declare const isFileAttachmentArray: (arr: any) => arr is FileAttachment[];
17
- export interface InputContent {
18
- readonly typeName: "text" | "image" | "file";
19
- readonly text?: string;
20
- readonly image?: string;
21
- readonly file?: string;
22
- /** For file type, can include base64 content */
23
- readonly fileData?: FileAttachment;
24
- }
25
- export declare const isInputContent: (content: any) => content is InputContent;
26
- export declare const isInputContentArray: (content: any) => content is InputContent[];
27
- export interface ModelContent {
28
- readonly content: string | InputContent | InputContent[];
29
- readonly role: "user" | "assistant" | "system";
30
- }
31
- /**
32
- * @internal
33
- */
34
- export interface GenericArguments {
35
- [key: string]: any;
36
- }
37
- export interface ModelToolOutput {
38
- readonly outputType: "tool_call";
39
- readonly name: string;
40
- readonly arguments: Record<string, unknown>;
41
- readonly callId: string;
42
- }
43
- export interface ModelTextOutput {
44
- readonly outputType: "output_text";
45
- readonly text: string;
46
- }
47
- export interface InputTokensDetails {
48
- readonly cachedTokens: number;
49
- }
50
- export interface OutputTokensDetails {
51
- readonly reasoningTokens: number;
52
- }
53
- export interface ModelDeltaOutput {
54
- readonly outputType: "output_text_delta";
55
- readonly delta: string;
56
- readonly sequenceNumber: number;
57
- }
58
- export interface Usage {
59
- readonly inputTokens: number;
60
- readonly inputTokensDetails: InputTokensDetails;
61
- readonly outputTokens: number;
62
- readonly outputTokensDetails: OutputTokensDetails;
63
- readonly totalTokens: number;
64
- }
65
- export interface ModelResponseData {
66
- readonly typeName: "response.requested" | "tool_call" | "output_text" | "output_text_delta" | "response.completed" | "output_text.part.done" | "overall.completed";
67
- readonly toolCall?: ModelToolOutput;
68
- readonly outputText?: ModelTextOutput;
69
- readonly outputTextDelta?: ModelDeltaOutput;
70
- readonly requested?: any;
71
- readonly threadId?: string;
72
- }
73
- export interface ModelResponse {
74
- readonly eventName: string;
75
- readonly data: ModelResponseData[] | ModelResponseData;
76
- readonly usage?: Usage;
77
- readonly modelInstance?: IModel;
78
- readonly threadId?: string;
79
- }
80
- export type ToolCallResponse = Record<string, unknown>;
81
- export interface IModelStreamer {
82
- recieve(model: IModel, content: ModelResponse): Promise<void>;
83
- }
84
- export interface IModel {
85
- readonly threadId?: string;
86
- invoke(prompt: (ModelContent | ToolCallResponse)[], streamer: IModelStreamer): Promise<void>;
87
- }
88
- export interface IModelFactoryProps {
89
- readonly systemPrompt: string;
90
- readonly tools?: ITool[];
91
- }
92
- export interface IModelFactory {
93
- create(props: IModelFactoryProps): Promise<IModel>;
94
- }
95
- export interface ModelResponseStreamValue {
96
- readonly value: ModelResponse | undefined;
97
- readonly done: boolean;
98
- }
99
- export interface IModelResponseStream {
100
- next(): Promise<ModelResponseStreamValue>;
101
- }
@@ -1,27 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isInputContentArray = exports.isInputContent = exports.isFileAttachmentArray = exports.isFileAttachment = void 0;
4
- const isFileAttachment = (obj) => {
5
- return typeof obj === "object"
6
- && obj !== null
7
- && typeof obj.name === "string"
8
- && typeof obj.content === "string";
9
- };
10
- exports.isFileAttachment = isFileAttachment;
11
- const isFileAttachmentArray = (arr) => {
12
- return Array.isArray(arr) && arr.every(exports.isFileAttachment);
13
- };
14
- exports.isFileAttachmentArray = isFileAttachmentArray;
15
- const isInputContent = (content) => {
16
- return typeof (content) !== "string"
17
- && !Array.isArray(content)
18
- && content !== null
19
- && typeof content === "object"
20
- && "typeName" in content;
21
- };
22
- exports.isInputContent = isInputContent;
23
- const isInputContentArray = (content) => {
24
- return Array.isArray(content) && content.every(exports.isInputContent);
25
- };
26
- exports.isInputContentArray = isInputContentArray;
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWxzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWdCTyxNQUFNLGdCQUFnQixHQUFHLENBQUMsR0FBUSxFQUF5QixFQUFFO0lBQ2hFLE9BQU8sT0FBTyxHQUFHLEtBQUssUUFBUTtXQUN2QixHQUFHLEtBQUssSUFBSTtXQUNaLE9BQU8sR0FBRyxDQUFDLElBQUksS0FBSyxRQUFRO1dBQzVCLE9BQU8sR0FBRyxDQUFDLE9BQU8sS0FBSyxRQUFRLENBQUM7QUFDM0MsQ0FBQyxDQUFBO0FBTFksUUFBQSxnQkFBZ0Isb0JBSzVCO0FBRU0sTUFBTSxxQkFBcUIsR0FBRyxDQUFDLEdBQVEsRUFBMkIsRUFBRTtJQUN2RSxPQUFPLEtBQUssQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyx3QkFBZ0IsQ0FBQyxDQUFDO0FBQzdELENBQUMsQ0FBQTtBQUZZLFFBQUEscUJBQXFCLHlCQUVqQztBQVVNLE1BQU0sY0FBYyxHQUFHLENBQUMsT0FBWSxFQUEyQixFQUFFO0lBQ3BFLE9BQU8sT0FBTSxDQUFDLE9BQU8sQ0FBQyxLQUFLLFFBQVE7V0FDNUIsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQztXQUN2QixPQUFPLEtBQUssSUFBSTtXQUNoQixPQUFPLE9BQU8sS0FBSyxRQUFRO1dBQzNCLFVBQVUsSUFBSSxPQUFPLENBQUM7QUFDakMsQ0FBQyxDQUFBO0FBTlksUUFBQSxjQUFjLGtCQU0xQjtBQUVNLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxPQUFZLEVBQTZCLEVBQUU7SUFDM0UsT0FBTyxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLENBQUMsc0JBQWMsQ0FBQyxDQUFDO0FBQ25FLENBQUMsQ0FBQTtBQUZZLFFBQUEsbUJBQW1CLHVCQUUvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElUb29sIH0gZnJvbSBcIi4uL3Rvb2xzL3Rvb2xcIjtcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgZmlsZSBhdHRhY2htZW50IHNlbnQgd2l0aCBhIGNoYXQgbWVzc2FnZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEZpbGVBdHRhY2htZW50IHtcbiAgICAvKiogVGhlIGZpbGUgbmFtZSAqL1xuICAgIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgICAvKiogVGhlIGZpbGUgcGF0aCAob3B0aW9uYWwsIG1heSBub3QgYmUgcmVsZXZhbnQgaW4gYWxsIGNvbnRleHRzKSAqL1xuICAgIHJlYWRvbmx5IHBhdGg/OiBzdHJpbmc7XG4gICAgLyoqIEJhc2U2NCBlbmNvZGVkIGZpbGUgY29udGVudCAqL1xuICAgIHJlYWRvbmx5IGNvbnRlbnQ6IHN0cmluZztcbiAgICAvKiogTUlNRSB0eXBlIG9mIHRoZSBmaWxlICovXG4gICAgcmVhZG9ubHkgbWltZVR5cGU/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBpc0ZpbGVBdHRhY2htZW50ID0gKG9iajogYW55KTogb2JqIGlzIEZpbGVBdHRhY2htZW50ID0+IHtcbiAgICByZXR1cm4gdHlwZW9mIG9iaiA9PT0gXCJvYmplY3RcIiBcbiAgICAgICAgJiYgb2JqICE9PSBudWxsIFxuICAgICAgICAmJiB0eXBlb2Ygb2JqLm5hbWUgPT09IFwic3RyaW5nXCJcbiAgICAgICAgJiYgdHlwZW9mIG9iai5jb250ZW50ID09PSBcInN0cmluZ1wiO1xufVxuXG5leHBvcnQgY29uc3QgaXNGaWxlQXR0YWNobWVudEFycmF5ID0gKGFycjogYW55KTogYXJyIGlzIEZpbGVBdHRhY2htZW50W10gPT4ge1xuICAgIHJldHVybiBBcnJheS5pc0FycmF5KGFycikgJiYgYXJyLmV2ZXJ5KGlzRmlsZUF0dGFjaG1lbnQpO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElucHV0Q29udGVudCB7XG4gICAgcmVhZG9ubHkgdHlwZU5hbWU6IFwidGV4dFwiIHwgXCJpbWFnZVwiIHwgXCJmaWxlXCI7XG4gICAgcmVhZG9ubHkgdGV4dD86IHN0cmluZztcbiAgICByZWFkb25seSBpbWFnZT86IHN0cmluZztcbiAgICByZWFkb25seSBmaWxlPzogc3RyaW5nO1xuICAgIC8qKiBGb3IgZmlsZSB0eXBlLCBjYW4gaW5jbHVkZSBiYXNlNjQgY29udGVudCAqL1xuICAgIHJlYWRvbmx5IGZpbGVEYXRhPzogRmlsZUF0dGFjaG1lbnQ7XG59XG5leHBvcnQgY29uc3QgaXNJbnB1dENvbnRlbnQgPSAoY29udGVudDogYW55KTogY29udGVudCBpcyBJbnB1dENvbnRlbnQgPT4ge1xuICAgIHJldHVybiB0eXBlb2YoY29udGVudCkgIT09IFwic3RyaW5nXCIgXG4gICAgICAgICYmICFBcnJheS5pc0FycmF5KGNvbnRlbnQpIFxuICAgICAgICAmJiBjb250ZW50ICE9PSBudWxsIFxuICAgICAgICAmJiB0eXBlb2YgY29udGVudCA9PT0gXCJvYmplY3RcIlxuICAgICAgICAmJiBcInR5cGVOYW1lXCIgaW4gY29udGVudDtcbn1cblxuZXhwb3J0IGNvbnN0IGlzSW5wdXRDb250ZW50QXJyYXkgPSAoY29udGVudDogYW55KTogY29udGVudCBpcyBJbnB1dENvbnRlbnRbXSA9PiB7XG4gICAgcmV0dXJuIEFycmF5LmlzQXJyYXkoY29udGVudCkgJiYgY29udGVudC5ldmVyeShpc0lucHV0Q29udGVudCk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTW9kZWxDb250ZW50IHtcbiAgICByZWFkb25seSBjb250ZW50OiBzdHJpbmcgfCBJbnB1dENvbnRlbnQgfCBJbnB1dENvbnRlbnRbXTtcbiAgICByZWFkb25seSByb2xlOiBcInVzZXJcIiB8IFwiYXNzaXN0YW50XCIgfCBcInN5c3RlbVwiO1xufVxuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEdlbmVyaWNBcmd1bWVudHMge1xuICAgIFtrZXk6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNb2RlbFRvb2xPdXRwdXQge1xuICAgIHJlYWRvbmx5IG91dHB1dFR5cGU6IFwidG9vbF9jYWxsXCI7XG4gICAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICAgIHJlYWRvbmx5IGFyZ3VtZW50czogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG4gICAgcmVhZG9ubHkgY2FsbElkOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTW9kZWxUZXh0T3V0cHV0IHtcbiAgICByZWFkb25seSBvdXRwdXRUeXBlOiBcIm91dHB1dF90ZXh0XCI7XG4gICAgcmVhZG9ubHkgdGV4dDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElucHV0VG9rZW5zRGV0YWlscyB7XG4gICAgcmVhZG9ubHkgY2FjaGVkVG9rZW5zOiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgT3V0cHV0VG9rZW5zRGV0YWlscyB7XG4gICAgcmVhZG9ubHkgcmVhc29uaW5nVG9rZW5zOiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTW9kZWxEZWx0YU91dHB1dCB7XG4gICAgcmVhZG9ubHkgb3V0cHV0VHlwZTogXCJvdXRwdXRfdGV4dF9kZWx0YVwiO1xuICAgIHJlYWRvbmx5IGRlbHRhOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgc2VxdWVuY2VOdW1iZXI6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVc2FnZSB7XG4gICAgcmVhZG9ubHkgaW5wdXRUb2tlbnM6IG51bWJlcjtcbiAgICByZWFkb25seSBpbnB1dFRva2Vuc0RldGFpbHM6IElucHV0VG9rZW5zRGV0YWlscztcbiAgICByZWFkb25seSBvdXRwdXRUb2tlbnM6IG51bWJlcjtcbiAgICByZWFkb25seSBvdXRwdXRUb2tlbnNEZXRhaWxzOiBPdXRwdXRUb2tlbnNEZXRhaWxzO1xuICAgIHJlYWRvbmx5IHRvdGFsVG9rZW5zOiBudW1iZXI7XG59XG5leHBvcnQgaW50ZXJmYWNlIE1vZGVsUmVzcG9uc2VEYXRhIHtcbiAgICByZWFkb25seSB0eXBlTmFtZTogXCJyZXNwb25zZS5yZXF1ZXN0ZWRcIiB8IFwidG9vbF9jYWxsXCIgfCBcIm91dHB1dF90ZXh0XCIgfCBcIm91dHB1dF90ZXh0X2RlbHRhXCIgfCBcInJlc3BvbnNlLmNvbXBsZXRlZFwiIHwgXCJvdXRwdXRfdGV4dC5wYXJ0LmRvbmVcIiB8IFwib3ZlcmFsbC5jb21wbGV0ZWRcIjsgXG4gICAgcmVhZG9ubHkgdG9vbENhbGw/OiBNb2RlbFRvb2xPdXRwdXQ7XG4gICAgcmVhZG9ubHkgb3V0cHV0VGV4dD86IE1vZGVsVGV4dE91dHB1dDtcbiAgICByZWFkb25seSBvdXRwdXRUZXh0RGVsdGE/OiBNb2RlbERlbHRhT3V0cHV0O1xuICAgIHJlYWRvbmx5IHJlcXVlc3RlZD86IGFueVxuICAgIHJlYWRvbmx5IHRocmVhZElkPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1vZGVsUmVzcG9uc2Uge1xuICAgIHJlYWRvbmx5IGV2ZW50TmFtZTogc3RyaW5nO1xuICAgIHJlYWRvbmx5IGRhdGE6IE1vZGVsUmVzcG9uc2VEYXRhW10gfCBNb2RlbFJlc3BvbnNlRGF0YTtcbiAgICByZWFkb25seSB1c2FnZT86IFVzYWdlO1xuICAgIHJlYWRvbmx5IG1vZGVsSW5zdGFuY2U/OiBJTW9kZWw7XG4gICAgcmVhZG9ubHkgdGhyZWFkSWQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIFRvb2xDYWxsUmVzcG9uc2UgPSBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcblxuZXhwb3J0IGludGVyZmFjZSBJTW9kZWxTdHJlYW1lciB7XG4gICAgcmVjaWV2ZShtb2RlbDogSU1vZGVsLCBjb250ZW50OiBNb2RlbFJlc3BvbnNlKTogUHJvbWlzZTx2b2lkPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTW9kZWwge1xuICAgIHJlYWRvbmx5IHRocmVhZElkPzogc3RyaW5nO1xuICAgIC8vIGlzQmxvY2tlZCgpOiBib29sZWFuO1xuICAgIGludm9rZShwcm9tcHQ6IChNb2RlbENvbnRlbnQgfCBUb29sQ2FsbFJlc3BvbnNlKVtdLCBzdHJlYW1lcjogSU1vZGVsU3RyZWFtZXIpOiBQcm9taXNlPHZvaWQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElNb2RlbEZhY3RvcnlQcm9wcyB7XG4gICAgcmVhZG9ubHkgc3lzdGVtUHJvbXB0OiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgdG9vbHM/OiBJVG9vbFtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElNb2RlbEZhY3Rvcnkge1xuICAgIGNyZWF0ZShwcm9wczogSU1vZGVsRmFjdG9yeVByb3BzKTogUHJvbWlzZTxJTW9kZWw+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1vZGVsUmVzcG9uc2VTdHJlYW1WYWx1ZSB7XG4gICAgcmVhZG9ubHkgdmFsdWU6IE1vZGVsUmVzcG9uc2UgfCB1bmRlZmluZWQ7XG4gICAgcmVhZG9ubHkgZG9uZTogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTW9kZWxSZXNwb25zZVN0cmVhbSB7XG4gICAgbmV4dCgpOiBQcm9taXNlPE1vZGVsUmVzcG9uc2VTdHJlYW1WYWx1ZT47XG59Il19
@@ -1,9 +0,0 @@
1
- import { IOutcome } from "./IOutcomes";
2
- import { IModelResponseStream } from "../models/types";
3
- export declare class Outcomes implements IOutcome {
4
- private outcomes;
5
- constructor(outcomes: IOutcome[]);
6
- static combine(...outcomes: IOutcome[]): Outcomes;
7
- send(messageStream: IModelResponseStream): Promise<void>;
8
- bindToRequest(request: any): Promise<void>;
9
- }
@@ -1,41 +0,0 @@
1
- "use strict";
2
- var _a;
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.Outcomes = void 0;
5
- const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
- class Outcomes {
7
- constructor(outcomes) {
8
- this.outcomes = outcomes;
9
- }
10
- static combine(...outcomes) {
11
- return new Outcomes(outcomes);
12
- }
13
- async send(messageStream) {
14
- let shouldContinue = true;
15
- while (shouldContinue) {
16
- const value = await messageStream.next();
17
- if (value.done) {
18
- shouldContinue = false;
19
- }
20
- const createNext = {
21
- next: async () => {
22
- return value;
23
- },
24
- };
25
- const allOutcomeResults = [];
26
- for (const outcome of this.outcomes) {
27
- const result = outcome.send(createNext);
28
- allOutcomeResults.push(result);
29
- }
30
- await Promise.all(allOutcomeResults);
31
- }
32
- return Promise.resolve();
33
- }
34
- async bindToRequest(request) {
35
- await Promise.all(this.outcomes.map(outcome => outcome.bindToRequest(request)));
36
- }
37
- }
38
- exports.Outcomes = Outcomes;
39
- _a = JSII_RTTI_SYMBOL_1;
40
- Outcomes[_a] = { fqn: "@shuttl-io/core.Outcomes", version: "0.1.7-0" };
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29tYmluYXRpb25PdXRjb21lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL291dGNvbWVzL0NvbWJpbmF0aW9uT3V0Y29tZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUdBLE1BQWEsUUFBUTtJQUdqQixZQUFtQixRQUFvQjtRQUNuQyxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUM3QixDQUFDO0lBQ00sTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLFFBQW9CO1FBQ3pDLE9BQU8sSUFBSSxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJLENBQUMsYUFBbUM7UUFDakQsSUFBSSxjQUFjLEdBQUcsSUFBSSxDQUFDO1FBQzFCLE9BQU8sY0FBYyxFQUFFLENBQUM7WUFDcEIsTUFBTSxLQUFLLEdBQUcsTUFBTSxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDekMsSUFBSSxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQ2IsY0FBYyxHQUFHLEtBQUssQ0FBQztZQUMzQixDQUFDO1lBQ0QsTUFBTSxVQUFVLEdBQUc7Z0JBQ2YsSUFBSSxFQUFFLEtBQUssSUFBSSxFQUFFO29CQUNiLE9BQU8sS0FBSyxDQUFDO2dCQUNqQixDQUFDO2FBQ0osQ0FBQTtZQUNELE1BQU0saUJBQWlCLEdBQUcsRUFBRSxDQUFBO1lBQzVCLEtBQUssTUFBTSxPQUFPLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUNsQyxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2dCQUN4QyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDbkMsQ0FBQztZQUNELE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3pDLENBQUM7UUFDRCxPQUFPLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRU0sS0FBSyxDQUFDLGFBQWEsQ0FBQyxPQUFZO1FBQ25DLE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3BGLENBQUM7O0FBbENMLDRCQW1DQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElPdXRjb21lIH0gZnJvbSBcIi4vSU91dGNvbWVzXCI7XG5pbXBvcnQgeyBJTW9kZWxSZXNwb25zZVN0cmVhbSB9IGZyb20gXCIuLi9tb2RlbHMvdHlwZXNcIjtcblxuZXhwb3J0IGNsYXNzIE91dGNvbWVzIGltcGxlbWVudHMgSU91dGNvbWUge1xuICAgIHByaXZhdGUgb3V0Y29tZXM6IElPdXRjb21lW107XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3Iob3V0Y29tZXM6IElPdXRjb21lW10pIHtcbiAgICAgICAgdGhpcy5vdXRjb21lcyA9IG91dGNvbWVzO1xuICAgIH1cbiAgICBwdWJsaWMgc3RhdGljIGNvbWJpbmUoLi4ub3V0Y29tZXM6IElPdXRjb21lW10pOiBPdXRjb21lcyB7IFxuICAgICAgICByZXR1cm4gbmV3IE91dGNvbWVzKG91dGNvbWVzKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgYXN5bmMgc2VuZChtZXNzYWdlU3RyZWFtOiBJTW9kZWxSZXNwb25zZVN0cmVhbSk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICBsZXQgc2hvdWxkQ29udGludWUgPSB0cnVlO1xuICAgICAgICB3aGlsZSAoc2hvdWxkQ29udGludWUpIHtcbiAgICAgICAgICAgIGNvbnN0IHZhbHVlID0gYXdhaXQgbWVzc2FnZVN0cmVhbS5uZXh0KCk7XG4gICAgICAgICAgICBpZiAodmFsdWUuZG9uZSkge1xuICAgICAgICAgICAgICAgIHNob3VsZENvbnRpbnVlID0gZmFsc2U7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjb25zdCBjcmVhdGVOZXh0ID0ge1xuICAgICAgICAgICAgICAgIG5leHQ6IGFzeW5jICgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjb25zdCBhbGxPdXRjb21lUmVzdWx0cyA9IFtdXG4gICAgICAgICAgICBmb3IgKGNvbnN0IG91dGNvbWUgb2YgdGhpcy5vdXRjb21lcykge1xuICAgICAgICAgICAgICAgIGNvbnN0IHJlc3VsdCA9IG91dGNvbWUuc2VuZChjcmVhdGVOZXh0KTtcbiAgICAgICAgICAgICAgICBhbGxPdXRjb21lUmVzdWx0cy5wdXNoKHJlc3VsdCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBhd2FpdCBQcm9taXNlLmFsbChhbGxPdXRjb21lUmVzdWx0cyk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgpO1xuICAgIH1cblxuICAgIHB1YmxpYyBhc3luYyBiaW5kVG9SZXF1ZXN0KHJlcXVlc3Q6IGFueSk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICBhd2FpdCBQcm9taXNlLmFsbCh0aGlzLm91dGNvbWVzLm1hcChvdXRjb21lID0+IG91dGNvbWUuYmluZFRvUmVxdWVzdChyZXF1ZXN0KSkpO1xuICAgIH1cbn0iXX0=
@@ -1,9 +0,0 @@
1
- import { IModelResponseStream } from "../models/types";
2
- export interface IOutcome {
3
- send(messageStream: IModelResponseStream): Promise<void>;
4
- bindToRequest(request: any): Promise<void>;
5
- }
6
- export declare class SlackOutcome implements IOutcome {
7
- send(messageStream: IModelResponseStream): Promise<void>;
8
- bindToRequest(request: any): Promise<void>;
9
- }
@@ -1,19 +0,0 @@
1
- "use strict";
2
- var _a;
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.SlackOutcome = void 0;
5
- const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
- class SlackOutcome {
7
- send(messageStream) {
8
- console.log("Sending message to Slack:", messageStream);
9
- return Promise.resolve();
10
- }
11
- bindToRequest(request) {
12
- console.log("Binding request to Slack:", request);
13
- return Promise.resolve();
14
- }
15
- }
16
- exports.SlackOutcome = SlackOutcome;
17
- _a = JSII_RTTI_SYMBOL_1;
18
- SlackOutcome[_a] = { fqn: "@shuttl-io/core.SlackOutcome", version: "0.1.7-0" };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSU91dGNvbWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL291dGNvbWVzL0lPdXRjb21lcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQU9BLE1BQWEsWUFBWTtJQUNkLElBQUksQ0FBQyxhQUFtQztRQUMzQyxPQUFPLENBQUMsR0FBRyxDQUFDLDJCQUEyQixFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQ3hELE9BQU8sT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQzdCLENBQUM7SUFFTSxhQUFhLENBQUMsT0FBWTtRQUM3QixPQUFPLENBQUMsR0FBRyxDQUFDLDJCQUEyQixFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ2xELE9BQU8sT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQzdCLENBQUM7O0FBVEwsb0NBVUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJTW9kZWxSZXNwb25zZVN0cmVhbSB9IGZyb20gXCIuLi9tb2RlbHMvdHlwZXNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBJT3V0Y29tZSB7XG4gICBzZW5kKG1lc3NhZ2VTdHJlYW06IElNb2RlbFJlc3BvbnNlU3RyZWFtKSA6IFByb21pc2U8dm9pZD47XG4gICBiaW5kVG9SZXF1ZXN0KHJlcXVlc3Q6IGFueSkgOiBQcm9taXNlPHZvaWQ+O1xufVxuXG5leHBvcnQgY2xhc3MgU2xhY2tPdXRjb21lIGltcGxlbWVudHMgSU91dGNvbWUge1xuICAgIHB1YmxpYyBzZW5kKG1lc3NhZ2VTdHJlYW06IElNb2RlbFJlc3BvbnNlU3RyZWFtKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgICAgIGNvbnNvbGUubG9nKFwiU2VuZGluZyBtZXNzYWdlIHRvIFNsYWNrOlwiLCBtZXNzYWdlU3RyZWFtKTtcbiAgICAgICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgpO1xuICAgIH1cblxuICAgIHB1YmxpYyBiaW5kVG9SZXF1ZXN0KHJlcXVlc3Q6IGFueSk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICBjb25zb2xlLmxvZyhcIkJpbmRpbmcgcmVxdWVzdCB0byBTbGFjazpcIiwgcmVxdWVzdCk7XG4gICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoKTtcbiAgICB9XG59Il19
@@ -1,6 +0,0 @@
1
- import { IOutcome } from "./IOutcomes";
2
- import { IModelResponseStream } from "../models/types";
3
- export declare class StreamingOutcome implements IOutcome {
4
- send(messageStream: IModelResponseStream): Promise<void>;
5
- bindToRequest(request: any): Promise<void>;
6
- }