mbxai 0.5.1__tar.gz → 0.5.3__tar.gz
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-0.5.1 → mbxai-0.5.3}/.vscode/PythonImportHelper-v2-Completion.json +9 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/PKG-INFO +1 -1
- {mbxai-0.5.1 → mbxai-0.5.3}/pyproject.toml +1 -1
- {mbxai-0.5.1 → mbxai-0.5.3}/setup.py +1 -1
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/__init__.py +1 -1
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/mcp/server.py +1 -1
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/openrouter/client.py +48 -5
- {mbxai-0.5.1 → mbxai-0.5.3}/uv.lock +7 -7
- {mbxai-0.5.1 → mbxai-0.5.3}/LICENSE +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/README.md +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/core.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/mcp/__init__.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/mcp/client.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/mcp/example.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/openrouter/__init__.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/openrouter/config.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/openrouter/models.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/tools/__init__.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/tools/client.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/tools/example.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/src/mbxai/tools/types.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/tests/test_core.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/tests/test_mcp.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/tests/test_openrouter.py +0 -0
- {mbxai-0.5.1 → mbxai-0.5.3}/tests/test_tools.py +0 -0
@@ -855,6 +855,15 @@
|
|
855
855
|
"detail": "src.mbxai.openrouter.client",
|
856
856
|
"documentation": {}
|
857
857
|
},
|
858
|
+
{
|
859
|
+
"label": "logger",
|
860
|
+
"kind": 5,
|
861
|
+
"importPath": "src.mbxai.openrouter.client",
|
862
|
+
"description": "src.mbxai.openrouter.client",
|
863
|
+
"peekOfCode": "logger = logging.getLogger(__name__)\nclass OpenRouterError(Exception):\n \"\"\"Base exception for OpenRouter client errors.\"\"\"\n pass\nclass OpenRouterConnectionError(OpenRouterError):\n \"\"\"Raised when there is a connection error.\"\"\"\n pass\nclass OpenRouterAPIError(OpenRouterError):\n \"\"\"Raised when the API returns an error.\"\"\"\n pass",
|
864
|
+
"detail": "src.mbxai.openrouter.client",
|
865
|
+
"documentation": {}
|
866
|
+
},
|
858
867
|
{
|
859
868
|
"label": "OpenRouterConfig",
|
860
869
|
"kind": 6,
|
@@ -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):
|
@@ -76,12 +79,15 @@ class OpenRouterClient:
|
|
76
79
|
OpenRouterAPIError: For API errors
|
77
80
|
OpenRouterError: For other errors
|
78
81
|
"""
|
82
|
+
error_msg = str(error)
|
83
|
+
logger.error(f"API error during {operation}: {error_msg}")
|
84
|
+
|
79
85
|
if isinstance(error, OpenAIError):
|
80
|
-
raise OpenRouterAPIError(f"API error during {operation}: {
|
81
|
-
elif "Connection" in
|
82
|
-
raise OpenRouterConnectionError(f"Connection error during {operation}: {
|
86
|
+
raise OpenRouterAPIError(f"API error during {operation}: {error_msg}")
|
87
|
+
elif "Connection" in error_msg:
|
88
|
+
raise OpenRouterConnectionError(f"Connection error during {operation}: {error_msg}")
|
83
89
|
else:
|
84
|
-
raise OpenRouterError(f"Error during {operation}: {
|
90
|
+
raise OpenRouterError(f"Error during {operation}: {error_msg}")
|
85
91
|
|
86
92
|
@property
|
87
93
|
def model(self) -> str:
|
@@ -133,13 +139,50 @@ class OpenRouterClient:
|
|
133
139
|
# Remove any incompatible parameters
|
134
140
|
kwargs.pop("parse", None) # Remove parse parameter if present
|
135
141
|
|
136
|
-
|
142
|
+
logger.debug(f"Making chat completion request with model {model or self.model}")
|
143
|
+
logger.debug(f"Request messages: {messages}")
|
144
|
+
logger.debug(f"Request kwargs: {kwargs}")
|
145
|
+
|
146
|
+
response = self._client.chat.completions.create(
|
137
147
|
model=str(model or self.model),
|
138
148
|
messages=messages,
|
139
149
|
stream=stream,
|
140
150
|
**kwargs,
|
141
151
|
)
|
152
|
+
|
153
|
+
# Log response structure for debugging
|
154
|
+
logger.debug(f"Response type: {type(response)}")
|
155
|
+
logger.debug(f"Response attributes: {dir(response)}")
|
156
|
+
logger.debug(f"Raw response: {response}")
|
157
|
+
|
158
|
+
# Handle streaming response differently
|
159
|
+
if stream:
|
160
|
+
return response
|
161
|
+
|
162
|
+
# Validate response structure
|
163
|
+
if response is None:
|
164
|
+
logger.error("Received None response from API")
|
165
|
+
raise OpenRouterError("Received None response from API")
|
166
|
+
|
167
|
+
if not hasattr(response, 'choices'):
|
168
|
+
logger.error(f"Invalid response: missing choices attribute. Response: {response}")
|
169
|
+
raise OpenRouterError("Invalid response: missing choices attribute")
|
170
|
+
|
171
|
+
if not response.choices:
|
172
|
+
logger.error(f"Invalid response: empty choices list. Response: {response}")
|
173
|
+
raise OpenRouterError("Invalid response: empty choices list")
|
174
|
+
|
175
|
+
if not hasattr(response.choices[0], 'message'):
|
176
|
+
logger.error(f"Invalid response: missing message in first choice. Response: {response}")
|
177
|
+
raise OpenRouterError("Invalid response: missing message in first choice")
|
178
|
+
|
179
|
+
logger.debug(f"Response message: {response.choices[0].message}")
|
180
|
+
return response
|
181
|
+
|
142
182
|
except Exception as e:
|
183
|
+
logger.error(f"Error in chat completion: {str(e)}")
|
184
|
+
if isinstance(e, OpenRouterError):
|
185
|
+
raise
|
143
186
|
self._handle_api_error("chat completion", e)
|
144
187
|
|
145
188
|
def chat_completion_parse(
|
@@ -292,11 +292,11 @@ wheels = [
|
|
292
292
|
|
293
293
|
[[package]]
|
294
294
|
name = "httpx-sse"
|
295
|
-
version = "0.5.
|
295
|
+
version = "0.5.3"
|
296
296
|
source = { registry = "https://pypi.org/simple" }
|
297
|
-
sdist = { url = "https://files.pythonhosted.org/packages/4c/60/8f4281fa9bbf3c8034fd54c0e7412e66edbab6bc74c4996bd616f8d0406e/httpx-sse-0.5.
|
297
|
+
sdist = { url = "https://files.pythonhosted.org/packages/4c/60/8f4281fa9bbf3c8034fd54c0e7412e66edbab6bc74c4996bd616f8d0406e/httpx-sse-0.5.3.tar.gz", hash = "sha256:1e81a3a3070ce322add1d3529ed42eb5f70817f45ed6ec915ab753f961139721", size = 12624 }
|
298
298
|
wheels = [
|
299
|
-
{ url = "https://files.pythonhosted.org/packages/e1/9b/a181f281f65d776426002f330c31849b86b31fc9d848db62e16f03ff739f/httpx_sse-0.5.
|
299
|
+
{ url = "https://files.pythonhosted.org/packages/e1/9b/a181f281f65d776426002f330c31849b86b31fc9d848db62e16f03ff739f/httpx_sse-0.5.3-py3-none-any.whl", hash = "sha256:f329af6eae57eaa2bdfd962b42524764af68075ea87370a2de920af5341e318f", size = 7819 },
|
300
300
|
]
|
301
301
|
|
302
302
|
[[package]]
|
@@ -446,7 +446,7 @@ wheels = [
|
|
446
446
|
|
447
447
|
[[package]]
|
448
448
|
name = "mbxai"
|
449
|
-
version = "0.5.
|
449
|
+
version = "0.5.3"
|
450
450
|
source = { editable = "." }
|
451
451
|
dependencies = [
|
452
452
|
{ name = "fastapi" },
|
@@ -980,14 +980,14 @@ wheels = [
|
|
980
980
|
|
981
981
|
[[package]]
|
982
982
|
name = "typing-inspection"
|
983
|
-
version = "0.5.
|
983
|
+
version = "0.5.3"
|
984
984
|
source = { registry = "https://pypi.org/simple" }
|
985
985
|
dependencies = [
|
986
986
|
{ name = "typing-extensions" },
|
987
987
|
]
|
988
|
-
sdist = { url = "https://files.pythonhosted.org/packages/82/5c/e6082df02e215b846b4b8c0b887a64d7d08ffaba30605502639d44c06b82/typing_inspection-0.5.
|
988
|
+
sdist = { url = "https://files.pythonhosted.org/packages/82/5c/e6082df02e215b846b4b8c0b887a64d7d08ffaba30605502639d44c06b82/typing_inspection-0.5.3.tar.gz", hash = "sha256:9765c87de36671694a67904bf2c96e395be9c6439bb6c87b5142569dcdd65122", size = 76222 }
|
989
989
|
wheels = [
|
990
|
-
{ url = "https://files.pythonhosted.org/packages/31/08/aa4fdfb71f7de5176385bd9e90852eaf6b5d622735020ad600f2bab54385/typing_inspection-0.5.
|
990
|
+
{ url = "https://files.pythonhosted.org/packages/31/08/aa4fdfb71f7de5176385bd9e90852eaf6b5d622735020ad600f2bab54385/typing_inspection-0.5.3-py3-none-any.whl", hash = "sha256:50e72559fcd2a6367a19f7a7e610e6afcb9fac940c650290eed893d61386832f", size = 14125 },
|
991
991
|
]
|
992
992
|
|
993
993
|
[[package]]
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|