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 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', JSON.stringify(response), function_call.name);
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', JSON.stringify({error}), function_call.name);
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 [options, functions];
34
+ return {options, functions};
35
35
  }
36
36
 
37
37
  promptFromFunctions(options, functions) {
@@ -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
- role: 'user',
46
- content: [
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 = await this.getAnthropic().messages.create(completion_payload);
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
- messages.push({
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: (message.role === 'function' ? 'FUNCTION RESPONSE: ' : '') + c.content,
97
+ text: c.content.trim(),
97
98
  };
98
99
 
99
100
  case 'function':
100
101
  return {
101
- type: 'text',
102
- text: '```CALL \n' + c.content.name + '\n' + JSON.stringify(c.content.arguments || {}) + '\n```',
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
 
@@ -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
  }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "type": "module",
3
3
  "name": "symposium",
4
- "version": "0.6.1",
4
+ "version": "0.6.3",
5
5
  "description": "Agents",
6
6
  "main": "index.js",
7
7
  "author": "Domenico Giambra",