mbxai 0.5.1__tar.gz → 0.5.2__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.
@@ -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,
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: mbxai
3
- Version: 0.5.1
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
@@ -4,7 +4,7 @@ build-backend = "hatchling.build"
4
4
 
5
5
  [project]
6
6
  name = "mbxai"
7
- version = "0.5.1"
7
+ version = "0.5.2"
8
8
  authors = [
9
9
  { name = "MBX AI" }
10
10
  ]
@@ -2,7 +2,7 @@ from setuptools import setup, find_packages
2
2
 
3
3
  setup(
4
4
  name="mbxai",
5
- version="0.5.1",
5
+ version="0.5.2",
6
6
  author="MBX AI",
7
7
  description="MBX AI SDK",
8
8
  long_description=open("README.md").read(),
@@ -2,4 +2,4 @@
2
2
  MBX AI package.
3
3
  """
4
4
 
5
- __version__ = "0.5.1"
5
+ __version__ = "0.5.2"
@@ -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.1",
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(
@@ -292,11 +292,11 @@ wheels = [
292
292
 
293
293
  [[package]]
294
294
  name = "httpx-sse"
295
- version = "0.5.1"
295
+ version = "0.5.2"
296
296
  source = { registry = "https://pypi.org/simple" }
297
- sdist = { url = "https://files.pythonhosted.org/packages/4c/60/8f4281fa9bbf3c8034fd54c0e7412e66edbab6bc74c4996bd616f8d0406e/httpx-sse-0.5.1.tar.gz", hash = "sha256:1e81a3a3070ce322add1d3529ed42eb5f70817f45ed6ec915ab753f961139721", size = 12624 }
297
+ sdist = { url = "https://files.pythonhosted.org/packages/4c/60/8f4281fa9bbf3c8034fd54c0e7412e66edbab6bc74c4996bd616f8d0406e/httpx-sse-0.5.2.tar.gz", hash = "sha256:1e81a3a3070ce322add1d3529ed42eb5f70817f45ed6ec915ab753f961139721", size = 12624 }
298
298
  wheels = [
299
- { url = "https://files.pythonhosted.org/packages/e1/9b/a181f281f65d776426002f330c31849b86b31fc9d848db62e16f03ff739f/httpx_sse-0.5.1-py3-none-any.whl", hash = "sha256:f329af6eae57eaa2bdfd962b42524764af68075ea87370a2de920af5341e318f", size = 7819 },
299
+ { url = "https://files.pythonhosted.org/packages/e1/9b/a181f281f65d776426002f330c31849b86b31fc9d848db62e16f03ff739f/httpx_sse-0.5.2-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.1"
449
+ version = "0.5.2"
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.1"
983
+ version = "0.5.2"
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.1.tar.gz", hash = "sha256:9765c87de36671694a67904bf2c96e395be9c6439bb6c87b5142569dcdd65122", size = 76222 }
988
+ sdist = { url = "https://files.pythonhosted.org/packages/82/5c/e6082df02e215b846b4b8c0b887a64d7d08ffaba30605502639d44c06b82/typing_inspection-0.5.2.tar.gz", hash = "sha256:9765c87de36671694a67904bf2c96e395be9c6439bb6c87b5142569dcdd65122", size = 76222 }
989
989
  wheels = [
990
- { url = "https://files.pythonhosted.org/packages/31/08/aa4fdfb71f7de5176385bd9e90852eaf6b5d622735020ad600f2bab54385/typing_inspection-0.5.1-py3-none-any.whl", hash = "sha256:50e72559fcd2a6367a19f7a7e610e6afcb9fac940c650290eed893d61386832f", size = 14125 },
990
+ { url = "https://files.pythonhosted.org/packages/31/08/aa4fdfb71f7de5176385bd9e90852eaf6b5d622735020ad600f2bab54385/typing_inspection-0.5.2-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