mbxai 0.5.5__py3-none-any.whl → 0.5.6__py3-none-any.whl

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.
mbxai/__init__.py CHANGED
@@ -2,4 +2,4 @@
2
2
  MBX AI package.
3
3
  """
4
4
 
5
- __version__ = "0.5.5"
5
+ __version__ = "0.5.6"
mbxai/mcp/server.py CHANGED
@@ -31,7 +31,7 @@ class MCPServer:
31
31
  self.app = FastAPI(
32
32
  title=self.name,
33
33
  description=self.description,
34
- version="0.5.5",
34
+ version="0.5.6",
35
35
  )
36
36
 
37
37
  # Initialize MCP server
mbxai/tools/client.py CHANGED
@@ -95,12 +95,33 @@ class ToolClient:
95
95
 
96
96
  # Handle each tool call
97
97
  for tool_call in message.tool_calls:
98
+ logger.debug(f"Processing tool call: {tool_call}")
99
+ logger.debug(f"Tool call ID: {tool_call.id}")
100
+ logger.debug(f"Tool call function: {tool_call.function}")
101
+ logger.debug(f"Tool call arguments: {tool_call.function.arguments}")
102
+
98
103
  tool = self._tools.get(tool_call.function.name)
99
104
  if not tool:
100
105
  raise ValueError(f"Unknown tool: {tool_call.function.name}")
101
106
 
107
+ # Parse arguments if they're a string
108
+ arguments = tool_call.function.arguments
109
+ logger.debug(f"Raw arguments type: {type(arguments)}")
110
+ logger.debug(f"Raw arguments: {arguments}")
111
+
112
+ if isinstance(arguments, str):
113
+ import json
114
+ try:
115
+ arguments = json.loads(arguments)
116
+ logger.debug(f"Parsed arguments: {arguments}")
117
+ except json.JSONDecodeError as e:
118
+ logger.error(f"Failed to parse tool arguments: {e}")
119
+ raise ValueError(f"Invalid tool arguments format: {arguments}")
120
+
102
121
  # Call the tool
103
- result = tool.function(**tool_call.function.arguments)
122
+ logger.debug(f"Calling tool {tool.name} with arguments: {arguments}")
123
+ result = tool.function(**arguments)
124
+ logger.debug(f"Tool result: {result}")
104
125
 
105
126
  # Add the tool response to the messages
106
127
  messages.append({
@@ -160,12 +181,33 @@ class ToolClient:
160
181
 
161
182
  # Handle each tool call
162
183
  for tool_call in message.tool_calls:
184
+ logger.debug(f"Processing tool call: {tool_call}")
185
+ logger.debug(f"Tool call ID: {tool_call.id}")
186
+ logger.debug(f"Tool call function: {tool_call.function}")
187
+ logger.debug(f"Tool call arguments: {tool_call.function.arguments}")
188
+
163
189
  tool = self._tools.get(tool_call.function.name)
164
190
  if not tool:
165
191
  raise ValueError(f"Unknown tool: {tool_call.function.name}")
166
192
 
193
+ # Parse arguments if they're a string
194
+ arguments = tool_call.function.arguments
195
+ logger.debug(f"Raw arguments type: {type(arguments)}")
196
+ logger.debug(f"Raw arguments: {arguments}")
197
+
198
+ if isinstance(arguments, str):
199
+ import json
200
+ try:
201
+ arguments = json.loads(arguments)
202
+ logger.debug(f"Parsed arguments: {arguments}")
203
+ except json.JSONDecodeError as e:
204
+ logger.error(f"Failed to parse tool arguments: {e}")
205
+ raise ValueError(f"Invalid tool arguments format: {arguments}")
206
+
167
207
  # Call the tool
168
- result = tool.function(**tool_call.function.arguments)
208
+ logger.debug(f"Calling tool {tool.name} with arguments: {arguments}")
209
+ result = tool.function(**arguments)
210
+ logger.debug(f"Tool result: {result}")
169
211
 
170
212
  # Add the tool response to the messages
171
213
  messages.append({
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: mbxai
3
- Version: 0.5.5
3
+ Version: 0.5.6
4
4
  Summary: MBX AI SDK
5
5
  Project-URL: Homepage, https://www.mibexx.de
6
6
  Project-URL: Documentation, https://www.mibexx.de
@@ -1,18 +1,18 @@
1
- mbxai/__init__.py,sha256=9R6hwrMZv42Y8AiBgP0KTxJvokh8rDG_HHmedMSnNDE,47
1
+ mbxai/__init__.py,sha256=3cCdE3UF7hWaEKRs2Ftl0x1qU4zqaFY1bNSZR5-JcZ0,47
2
2
  mbxai/core.py,sha256=WMvmU9TTa7M_m-qWsUew4xH8Ul6xseCZ2iBCXJTW-Bs,196
3
3
  mbxai/mcp/__init__.py,sha256=_ek9iYdYqW5saKetj4qDci11jxesQDiHPJRpHMKkxgU,175
4
4
  mbxai/mcp/client.py,sha256=QxVeQRBQryeEGXDU8X_9qQBfT-ubDd9L9KSc5-P354U,5590
5
5
  mbxai/mcp/example.py,sha256=oaol7AvvZnX86JWNz64KvPjab5gg1VjVN3G8eFSzuaE,2350
6
- mbxai/mcp/server.py,sha256=EJwK4GRsUG2xLfZocFsHpp31qu4GGWvwH7s50AG4qH8,3462
6
+ mbxai/mcp/server.py,sha256=LGhjJvUg2CiQ5i0C0aAqeXRghboz5sn7YBOEIaoSPXc,3462
7
7
  mbxai/openrouter/__init__.py,sha256=Ito9Qp_B6q-RLGAQcYyTJVWwR2YAZvNqE-HIYXxhtD8,298
8
8
  mbxai/openrouter/client.py,sha256=XLRMRNRJH96Jl6_af0KkzRDdLJnixh8I3RvEEcFuXyg,10840
9
9
  mbxai/openrouter/config.py,sha256=MTX_YHsFrM7JYqovJSkEF6JzVyIdajeI5Dja2CALH58,2874
10
10
  mbxai/openrouter/models.py,sha256=b3IjjtZAjeGOf2rLsdnCD1HacjTnS8jmv_ZXorc-KJQ,2604
11
11
  mbxai/tools/__init__.py,sha256=QUFaXhDm-UKcuAtT1rbKzhBkvyRBVokcQIOf9cxIuwc,160
12
- mbxai/tools/client.py,sha256=t4qjiKtWeiV5s6Dj_eh7VLm1YmmKN2zVMDAf6DRmADw,5504
12
+ mbxai/tools/client.py,sha256=f4i4lyLWeI81NPwnV8Rz1cO5bGh6kLHcxahNijUrTxw,7718
13
13
  mbxai/tools/example.py,sha256=1HgKK39zzUuwFbnp3f0ThyWVfA_8P28PZcTwaUw5K78,2232
14
14
  mbxai/tools/types.py,sha256=fo5t9UbsHGynhA88vD_ecgDqL8iLvt2E1h1ym43Rrgk,745
15
- mbxai-0.5.5.dist-info/METADATA,sha256=EwoHlZOsXYdG8fI7uEXu-sA2uHqeKP_k3vaGUo-sp8M,4107
16
- mbxai-0.5.5.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
17
- mbxai-0.5.5.dist-info/licenses/LICENSE,sha256=hEyhc4FxwYo3NQ40yNgZ7STqwVk-1_XcTXOnAPbGJAw,1069
18
- mbxai-0.5.5.dist-info/RECORD,,
15
+ mbxai-0.5.6.dist-info/METADATA,sha256=Y4o8ab_4BJvwsAvlrWD72eLkyg8S5v4LfWmeH6hsGBo,4107
16
+ mbxai-0.5.6.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
17
+ mbxai-0.5.6.dist-info/licenses/LICENSE,sha256=hEyhc4FxwYo3NQ40yNgZ7STqwVk-1_XcTXOnAPbGJAw,1069
18
+ mbxai-0.5.6.dist-info/RECORD,,
File without changes