- 
                Notifications
    You must be signed in to change notification settings 
- Fork 773
update mcp dependency; add ability to add icons #560
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 5 commits
7a07857
              c577c45
              536c453
              183e6f5
              9a9f968
              3057704
              3fd7eed
              File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -1,4 +1,5 @@ | ||
| import asyncio | ||
| import base64 | ||
|         
                  coderabbitai[bot] marked this conversation as resolved.
              Outdated
          
            Show resolved
            Hide resolved | ||
| import os | ||
| import sys | ||
| import functools | ||
|  | @@ -18,11 +19,11 @@ | |
| ) | ||
| from datetime import timedelta | ||
| from contextlib import asynccontextmanager | ||
| from importlib import resources | ||
|         
                  coderabbitai[bot] marked this conversation as resolved.
              Outdated
          
            Show resolved
            Hide resolved | ||
|  | ||
| from mcp import ServerSession | ||
| from mcp.server.fastmcp import FastMCP | ||
| from mcp.types import ToolAnnotations, Icon | ||
|  | ||
| from mcp_agent.core.context import Context, initialize_context, cleanup_context | ||
| from mcp_agent.config import Settings, get_settings | ||
| from mcp_agent.executor.signal_registry import SignalRegistry | ||
|  | @@ -53,6 +54,11 @@ | |
| P = ParamSpec("P") | ||
| R = TypeVar("R") | ||
|  | ||
| phetch = Icon( | ||
| src="https://s3.us-east-1.amazonaws.com/publicdata.lastmileai.com/phetch.png", | ||
| mimeType="image/png", | ||
| sizes=["48x48"], | ||
| ) | ||
|  | ||
| class MCPApp: | ||
| """ | ||
|  | @@ -86,6 +92,7 @@ def __init__( | |
| signal_notification: SignalWaitCallback | None = None, | ||
| upstream_session: Optional["ServerSession"] = None, | ||
| model_selector: ModelSelector | None = None, | ||
| icons: list[Icon] | None = None, | ||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should this be something configurable on the config as well? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We have to include it as a parameter to the  | ||
| ): | ||
| """ | ||
| Initialize the application with a name and optional settings. | ||
|  | @@ -136,6 +143,10 @@ def __init__( | |
| self._signal_notification = signal_notification | ||
| self._upstream_session = upstream_session | ||
| self._model_selector = model_selector | ||
| if icons: | ||
| self._icons = icons | ||
| else: | ||
| self._icons = [phetch] | ||
|  | ||
| self._workflows: Dict[str, Type["Workflow"]] = {} # id to workflow class | ||
| # Deferred tool declarations to register with MCP server when available | ||
|  | @@ -835,6 +846,8 @@ def decorator(fn: Callable[P, R]) -> Callable[P, R]: | |
| icons_list.append(Icon(**icon)) | ||
| else: | ||
| raise TypeError("icons entries must be Icon or mapping") | ||
| else: | ||
| icons_list = [phetch] | ||
|  | ||
| meta_payload: Dict[str, Any] | None = None | ||
| if meta is not None: | ||
|  | @@ -943,6 +956,8 @@ def decorator(fn: Callable[P, R]) -> Callable[P, R]: | |
| icons_list.append(Icon(**icon)) | ||
| else: | ||
| raise TypeError("icons entries must be Icon or mapping") | ||
| else: | ||
| icons_list = [phetch] | ||
|  | ||
| meta_payload: Dict[str, Any] | None = None | ||
| if meta is not None: | ||
|  | @@ -954,6 +969,7 @@ def decorator(fn: Callable[P, R]) -> Callable[P, R]: | |
| description=description, | ||
| mark_sync_tool=False, | ||
| ) | ||
|  | ||
| # Defer alias tool registration for run/get_status | ||
| self._declared_tools.append( | ||
| { | ||
|  | ||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The example is missing the required import for
Path. Consider addingfrom pathlib import Pathto the code example to ensure users can copy and run it without errors.Spotted by Graphite Agent

Is this helpful? React 👍 or 👎 to let us know.