mbxai 0.5.0__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.
- {mbxai-0.5.0 → mbxai-0.5.2}/.vscode/PythonImportHelper-v2-Completion.json +12 -3
- {mbxai-0.5.0 → mbxai-0.5.2}/PKG-INFO +1 -1
- {mbxai-0.5.0 → mbxai-0.5.2}/pyproject.toml +1 -1
- {mbxai-0.5.0 → mbxai-0.5.2}/setup.py +1 -1
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/__init__.py +1 -1
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/mcp/client.py +4 -1
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/mcp/server.py +1 -1
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/openrouter/client.py +23 -1
- {mbxai-0.5.0 → mbxai-0.5.2}/uv.lock +7 -7
- {mbxai-0.5.0 → mbxai-0.5.2}/LICENSE +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/README.md +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/core.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/mcp/__init__.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/mcp/example.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/openrouter/__init__.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/openrouter/config.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/openrouter/models.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/tools/__init__.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/tools/client.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/tools/example.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/src/mbxai/tools/types.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/tests/test_core.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/tests/test_mcp.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/tests/test_openrouter.py +0 -0
- {mbxai-0.5.0 → mbxai-0.5.2}/tests/test_tools.py +0 -0
@@ -734,7 +734,7 @@
|
|
734
734
|
"kind": 6,
|
735
735
|
"importPath": "src.mbxai.mcp.client",
|
736
736
|
"description": "src.mbxai.mcp.client",
|
737
|
-
"peekOfCode": "class MCPTool(Tool):\n \"\"\"MCP tool definition.\"\"\"\n internal_url: str | None = Field(default=None, description=\"The internal URL to invoke the tool\")\n service: str = Field(description=\"The service that provides the tool\")\n strict: bool = Field(default=True, description=\"Whether the tool response is strictly validated\")\n input_schema: dict[str, Any] = Field(description=\"The input schema for the tool\")\n def to_openai_function(self) -> dict[str, Any]:\n \"\"\"Convert the tool to an OpenAI function definition.\"\"\"\n return {
|
737
|
+
"peekOfCode": "class MCPTool(Tool):\n \"\"\"MCP tool definition.\"\"\"\n internal_url: str | None = Field(default=None, description=\"The internal URL to invoke the tool\")\n service: str = Field(description=\"The service that provides the tool\")\n strict: bool = Field(default=True, description=\"Whether the tool response is strictly validated\")\n input_schema: dict[str, Any] = Field(description=\"The input schema for the tool\")\n function: Callable[..., Any] | None = Field(default=None, description=\"The function that implements the tool\")\n def to_openai_function(self) -> dict[str, Any]:\n \"\"\"Convert the tool to an OpenAI function definition.\"\"\"\n return {",
|
738
738
|
"detail": "src.mbxai.mcp.client",
|
739
739
|
"documentation": {}
|
740
740
|
},
|
@@ -752,7 +752,7 @@
|
|
752
752
|
"kind": 5,
|
753
753
|
"importPath": "src.mbxai.mcp.client",
|
754
754
|
"description": "src.mbxai.mcp.client",
|
755
|
-
"peekOfCode": "logger = logging.getLogger(__name__)\nT = TypeVar(\"T\", bound=BaseModel)\nclass MCPTool(Tool):\n \"\"\"MCP tool definition.\"\"\"\n internal_url: str | None = Field(default=None, description=\"The internal URL to invoke the tool\")\n service: str = Field(description=\"The service that provides the tool\")\n strict: bool = Field(default=True, description=\"Whether the tool response is strictly validated\")\n input_schema: dict[str, Any] = Field(description=\"The input schema for the tool\")\n def to_openai_function(self) -> dict[str, Any]
|
755
|
+
"peekOfCode": "logger = logging.getLogger(__name__)\nT = TypeVar(\"T\", bound=BaseModel)\nclass MCPTool(Tool):\n \"\"\"MCP tool definition.\"\"\"\n internal_url: str | None = Field(default=None, description=\"The internal URL to invoke the tool\")\n service: str = Field(description=\"The service that provides the tool\")\n strict: bool = Field(default=True, description=\"Whether the tool response is strictly validated\")\n input_schema: dict[str, Any] = Field(description=\"The input schema for the tool\")\n function: Callable[..., Any] | None = Field(default=None, description=\"The function that implements the tool\")\n def to_openai_function(self) -> dict[str, Any]:",
|
756
756
|
"detail": "src.mbxai.mcp.client",
|
757
757
|
"documentation": {}
|
758
758
|
},
|
@@ -761,7 +761,7 @@
|
|
761
761
|
"kind": 5,
|
762
762
|
"importPath": "src.mbxai.mcp.client",
|
763
763
|
"description": "src.mbxai.mcp.client",
|
764
|
-
"peekOfCode": "T = TypeVar(\"T\", bound=BaseModel)\nclass MCPTool(Tool):\n \"\"\"MCP tool definition.\"\"\"\n internal_url: str | None = Field(default=None, description=\"The internal URL to invoke the tool\")\n service: str = Field(description=\"The service that provides the tool\")\n strict: bool = Field(default=True, description=\"Whether the tool response is strictly validated\")\n input_schema: dict[str, Any] = Field(description=\"The input schema for the tool\")\n def to_openai_function(self) -> dict[str, Any]:\n \"\"\"Convert the tool to an OpenAI function definition.\"\"\"
|
764
|
+
"peekOfCode": "T = TypeVar(\"T\", bound=BaseModel)\nclass MCPTool(Tool):\n \"\"\"MCP tool definition.\"\"\"\n internal_url: str | None = Field(default=None, description=\"The internal URL to invoke the tool\")\n service: str = Field(description=\"The service that provides the tool\")\n strict: bool = Field(default=True, description=\"Whether the tool response is strictly validated\")\n input_schema: dict[str, Any] = Field(description=\"The input schema for the tool\")\n function: Callable[..., Any] | None = Field(default=None, description=\"The function that implements the tool\")\n def to_openai_function(self) -> dict[str, Any]:\n \"\"\"Convert the tool to an OpenAI function definition.\"\"\"",
|
765
765
|
"detail": "src.mbxai.mcp.client",
|
766
766
|
"documentation": {}
|
767
767
|
},
|
@@ -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,
|
@@ -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)}")
|
@@ -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
|
-
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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
|
File without changes
|
File without changes
|