mbxai 0.5.0__py3-none-any.whl → 0.5.2__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.0"
5
+ __version__ = "0.5.2"
mbxai/mcp/client.py CHANGED
@@ -19,6 +19,7 @@ class MCPTool(Tool):
19
19
  service: str = Field(description="The service that provides the tool")
20
20
  strict: bool = Field(default=True, description="Whether the tool response is strictly validated")
21
21
  input_schema: dict[str, Any] = Field(description="The input schema for the tool")
22
+ function: Callable[..., Any] | None = Field(default=None, description="The function that implements the tool")
22
23
 
23
24
  def to_openai_function(self) -> dict[str, Any]:
24
25
  """Convert the tool to an OpenAI function definition."""
@@ -125,9 +126,11 @@ class MCPClient(ToolClient):
125
126
  # Create the tool function
126
127
  tool_function = self._create_tool_function(tool)
127
128
 
129
+ # Set the function after creation
130
+ tool.function = tool_function
131
+
128
132
  # Register the tool with ToolClient
129
133
  self._tools[tool.name] = tool
130
- tool.function = tool_function
131
134
  logger.info(f"Successfully registered tool: {tool.name}")
132
135
  except Exception as e:
133
136
  logger.error(f"Failed to register tool: {str(e)}")
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.0",
34
+ version="0.5.2",
35
35
  )
36
36
 
37
37
  # Initialize MCP server
@@ -7,6 +7,9 @@ from openai import OpenAI, OpenAIError
7
7
  from pydantic import BaseModel, TypeAdapter
8
8
  from .models import OpenRouterModel, OpenRouterModelRegistry
9
9
  from .config import OpenRouterConfig
10
+ import logging
11
+
12
+ logger = logging.getLogger(__name__)
10
13
 
11
14
 
12
15
  class OpenRouterError(Exception):
@@ -133,13 +136,32 @@ class OpenRouterClient:
133
136
  # Remove any incompatible parameters
134
137
  kwargs.pop("parse", None) # Remove parse parameter if present
135
138
 
136
- return self._client.chat.completions.create(
139
+ logger.debug(f"Making chat completion request with model {model or self.model}")
140
+ response = self._client.chat.completions.create(
137
141
  model=str(model or self.model),
138
142
  messages=messages,
139
143
  stream=stream,
140
144
  **kwargs,
141
145
  )
146
+
147
+ # Log response structure for debugging
148
+ logger.debug(f"Response type: {type(response)}")
149
+ logger.debug(f"Response attributes: {dir(response)}")
150
+
151
+ # Validate response structure
152
+ if not hasattr(response, 'choices') or not response.choices:
153
+ logger.error("Invalid response: missing choices")
154
+ raise OpenRouterError("Invalid response: missing choices")
155
+
156
+ if not hasattr(response.choices[0], 'message'):
157
+ logger.error("Invalid response: missing message in first choice")
158
+ raise OpenRouterError("Invalid response: missing message in first choice")
159
+
160
+ logger.debug(f"Response message: {response.choices[0].message}")
161
+ return response
162
+
142
163
  except Exception as e:
164
+ logger.error(f"Error in chat completion: {str(e)}")
143
165
  self._handle_api_error("chat completion", e)
144
166
 
145
167
  def chat_completion_parse(
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: mbxai
3
- Version: 0.5.0
3
+ Version: 0.5.2
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=wVJ8x7MtN4VeN_VyyppKqGepPR_Ko096DeXHM7znB7E,47
1
+ mbxai/__init__.py,sha256=fQrXtVudyVaDP1s-lHxflDN7wNf2J4SrZHqDeDyOthk,47
2
2
  mbxai/core.py,sha256=WMvmU9TTa7M_m-qWsUew4xH8Ul6xseCZ2iBCXJTW-Bs,196
3
3
  mbxai/mcp/__init__.py,sha256=_ek9iYdYqW5saKetj4qDci11jxesQDiHPJRpHMKkxgU,175
4
- mbxai/mcp/client.py,sha256=N5w_cTEF9vMwnBoGvvenYSX8YswAogJBEd312sHyrPM,5324
4
+ mbxai/mcp/client.py,sha256=CYm_5HiB3hZUYfahzM_senilPgH2oZwSevf2up1JTF0,5506
5
5
  mbxai/mcp/example.py,sha256=oaol7AvvZnX86JWNz64KvPjab5gg1VjVN3G8eFSzuaE,2350
6
- mbxai/mcp/server.py,sha256=QCRIoHw0eJjrYFpnD1dFngjKHcb3v6_qWAUT2sF8-dk,3462
6
+ mbxai/mcp/server.py,sha256=rEqGWMhaWDxutwC8Eq7djq4EFH4MH8RMdZIEAYIwquc,3462
7
7
  mbxai/openrouter/__init__.py,sha256=Ito9Qp_B6q-RLGAQcYyTJVWwR2YAZvNqE-HIYXxhtD8,298
8
- mbxai/openrouter/client.py,sha256=NPccB7Slou5tSc8DvXvItLdoDMgU0pcxW1lKcRKQXp0,8865
8
+ mbxai/openrouter/client.py,sha256=05_brXaQwrx_kBJPRwh5uiCHnWbgixI3nQWmx9xare0,9916
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
12
  mbxai/tools/client.py,sha256=PDkDTvpwAs8-F8CcF6wjjq2Z-VhYpjA9RXTK64Rwa3Y,5418
13
13
  mbxai/tools/example.py,sha256=1HgKK39zzUuwFbnp3f0ThyWVfA_8P28PZcTwaUw5K78,2232
14
14
  mbxai/tools/types.py,sha256=ZHnmiDXpH6wZhiZ-Tj9PiPMJaW1aiDAq5It2gpiwNp0,831
15
- mbxai-0.5.0.dist-info/METADATA,sha256=TtjY0FTk9MG12PhtlNggSDNa5VIvp1nSOGa9oLf6pKc,4107
16
- mbxai-0.5.0.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
17
- mbxai-0.5.0.dist-info/licenses/LICENSE,sha256=hEyhc4FxwYo3NQ40yNgZ7STqwVk-1_XcTXOnAPbGJAw,1069
18
- mbxai-0.5.0.dist-info/RECORD,,
15
+ mbxai-0.5.2.dist-info/METADATA,sha256=jB1PQS8nFzupdjxuatX7Iun3JpSubaK5LZ785zbl_iE,4107
16
+ mbxai-0.5.2.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
17
+ mbxai-0.5.2.dist-info/licenses/LICENSE,sha256=hEyhc4FxwYo3NQ40yNgZ7STqwVk-1_XcTXOnAPbGJAw,1069
18
+ mbxai-0.5.2.dist-info/RECORD,,
File without changes