symposium 0.6.1 → 0.6.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.
- package/Agent.js +12 -2
- package/Model.js +1 -1
- package/models/AnthropicModel.js +29 -12
- package/models/OpenAIModel.js +16 -0
- package/package.json +1 -1
package/Agent.js
CHANGED
|
@@ -235,10 +235,20 @@ export default class Agent {
|
|
|
235
235
|
|
|
236
236
|
try {
|
|
237
237
|
const response = await functions.get(function_call.name).tool.callFunction(thread, function_call.name, function_call.arguments);
|
|
238
|
-
thread.addMessage('function',
|
|
238
|
+
thread.addMessage('function', [
|
|
239
|
+
{
|
|
240
|
+
type: 'function_response',
|
|
241
|
+
content: {response, id: function_call.id || undefined},
|
|
242
|
+
},
|
|
243
|
+
], function_call.name);
|
|
239
244
|
await this.log('function_response', response);
|
|
240
245
|
} catch (error) {
|
|
241
|
-
thread.addMessage('function',
|
|
246
|
+
thread.addMessage('function', [
|
|
247
|
+
{
|
|
248
|
+
type: 'function_response',
|
|
249
|
+
content: {response: {error}},
|
|
250
|
+
},
|
|
251
|
+
], function_call.name);
|
|
242
252
|
await this.log('function_response', {error});
|
|
243
253
|
}
|
|
244
254
|
|
package/Model.js
CHANGED
|
@@ -31,7 +31,7 @@ export default class Model {
|
|
|
31
31
|
if (options.force_function && !functions.find(f => f.name === options.force_function))
|
|
32
32
|
throw new Error('Function ' + options.force_function + ' not found.');
|
|
33
33
|
|
|
34
|
-
return
|
|
34
|
+
return {options, functions};
|
|
35
35
|
}
|
|
36
36
|
|
|
37
37
|
promptFromFunctions(options, functions) {
|
package/models/AnthropicModel.js
CHANGED
|
@@ -41,15 +41,15 @@ export default class AnthropicModel extends Model {
|
|
|
41
41
|
};
|
|
42
42
|
|
|
43
43
|
if (options.force_function) {
|
|
44
|
-
completion_payload.messages.push({
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
{type: 'text', text: 'Use the ' + options.force_function + ' tool in your response.'},
|
|
48
|
-
],
|
|
44
|
+
completion_payload.messages[completion_payload.messages.length - 1].content.push({
|
|
45
|
+
type: 'text',
|
|
46
|
+
text: 'Usa il tool "' + options.force_function + '" nella tua prossima risposta!',
|
|
49
47
|
});
|
|
50
48
|
}
|
|
51
49
|
|
|
52
|
-
const message =
|
|
50
|
+
const message = completion_payload.tools.length ?
|
|
51
|
+
await this.getAnthropic().beta.tools.messages.create(completion_payload)
|
|
52
|
+
: await this.getAnthropic().messages.create(completion_payload);
|
|
53
53
|
|
|
54
54
|
const message_content = [];
|
|
55
55
|
if (message.content) {
|
|
@@ -63,6 +63,7 @@ export default class AnthropicModel extends Model {
|
|
|
63
63
|
message_content.push({
|
|
64
64
|
type: 'function',
|
|
65
65
|
content: {
|
|
66
|
+
id: m.id,
|
|
66
67
|
name: m.name,
|
|
67
68
|
arguments: m.input,
|
|
68
69
|
},
|
|
@@ -81,32 +82,48 @@ export default class AnthropicModel extends Model {
|
|
|
81
82
|
}
|
|
82
83
|
|
|
83
84
|
convertMessages(thread) {
|
|
84
|
-
let system = [], messages = [];
|
|
85
|
+
let system = [], messages = [], lastMessage = null;
|
|
85
86
|
for (let message of thread.messages) {
|
|
86
87
|
if (message.role === 'system') {
|
|
87
88
|
system.push(message.content.map(c => c.content).join("\n"));
|
|
88
89
|
} else {
|
|
89
|
-
|
|
90
|
+
const parsedMessage = {
|
|
90
91
|
role: message.role === 'function' ? 'user' : message.role,
|
|
91
92
|
content: message.content.map(c => {
|
|
92
93
|
switch (c.type) {
|
|
93
94
|
case 'text':
|
|
94
95
|
return {
|
|
95
96
|
type: 'text',
|
|
96
|
-
text:
|
|
97
|
+
text: c.content.trim(),
|
|
97
98
|
};
|
|
98
99
|
|
|
99
100
|
case 'function':
|
|
100
101
|
return {
|
|
101
|
-
type: '
|
|
102
|
-
|
|
102
|
+
type: 'tool_use',
|
|
103
|
+
name: c.content.name,
|
|
104
|
+
input: c.content.arguments,
|
|
105
|
+
id: c.content.id,
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
case 'function_response':
|
|
109
|
+
return {
|
|
110
|
+
type: 'tool_result',
|
|
111
|
+
content: c.content.response,
|
|
112
|
+
tool_use_id: c.content.id,
|
|
103
113
|
};
|
|
104
114
|
|
|
105
115
|
default:
|
|
106
116
|
throw new Error('Message type "' + c.type + '" unsupported by this model');
|
|
107
117
|
}
|
|
108
118
|
}),
|
|
109
|
-
}
|
|
119
|
+
};
|
|
120
|
+
|
|
121
|
+
if (lastMessage && lastMessage.role === parsedMessage.role) {
|
|
122
|
+
lastMessage.content = lastMessage.content.concat(message.content);
|
|
123
|
+
} else {
|
|
124
|
+
messages.push(parsedMessage);
|
|
125
|
+
lastMessage = parsedMessage;
|
|
126
|
+
}
|
|
110
127
|
}
|
|
111
128
|
}
|
|
112
129
|
|
package/models/OpenAIModel.js
CHANGED
|
@@ -122,6 +122,22 @@ export default class OpenAIModel extends Model {
|
|
|
122
122
|
}
|
|
123
123
|
break;
|
|
124
124
|
|
|
125
|
+
case 'function_response':
|
|
126
|
+
if (this.supports_functions) {
|
|
127
|
+
messages.push({
|
|
128
|
+
role: message.role,
|
|
129
|
+
content: JSON.stringify(c.content.response),
|
|
130
|
+
name: message.name,
|
|
131
|
+
});
|
|
132
|
+
} else {
|
|
133
|
+
messages.push({
|
|
134
|
+
role: 'user',
|
|
135
|
+
content: 'FUNCTION RESPONSE:\n' + JSON.stringify(c.content.response),
|
|
136
|
+
name: message.name,
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
break;
|
|
140
|
+
|
|
125
141
|
default:
|
|
126
142
|
throw new Error('Message type unsupported by this model');
|
|
127
143
|
}
|