Phantom.Tool (phantom_mcp v0.3.2)
View SourceThe Model Context Protocol (MCP) allows servers to expose tools that can be invoked by language models. Tools enable models to interact with external systems, such as querying databases, calling APIs, or performing computations. Each tool is uniquely identified by a name and includes metadata describing its schema.
https://modelcontextprotocol.io/specification/2025-03-26/server/tools
sequenceDiagram
participant LLM
participant Client
participant Server
Note over Client,Server: Discovery
Client->>Server: tools/list
Server-->>Client: List of tools
Note over Client,LLM: Tool Selection
LLM->>Client: Select tool to use
Note over Client,Server: Invocation
Client->>Server: tools/call
Server-->>Client: Tool result
Client->>LLM: Process result
Note over Client,Server: Updates
Server--)Client: tools/list_changed
Client->>Server: tools/list
Server-->>Client: Updated tools
Summary
Functions
Tool response as audio content
Build a tool spec. Be intentional with the name and description when defining the tool since it will inform the LLM when to use the tool.
Embedded resource response.
Tool response as image content
Resource link reponse.
Formats the response from an MCP Router to the MCP specification
Represent a Tool spec as json when listing the available tools to clients.
Types
@type embedded_resource_response() :: %{ content: [ type: :resource, resource: embedded_text_resource() | embedded_blob_resource() ] }
@type error_response() :: %{isError: true, content: [type: :text, text: String.t()]}
@type json() :: %{ :name => String.t(), :description => String.t(), :inputSchema => Phantom.Tool.JSONSchema.json(), optional(:outputSchema) => Phantom.Tool.JSONSchema.json(), optional(:annotations) => Phantom.Tool.Annotation.json() }
@type response() :: image_response() | audio_response() | text_response() | structured_response() | embedded_resource_response() | resource_link_response()
@type t() :: %Phantom.Tool{ annotations: Phantom.Tool.Annotation.t(), description: String.t(), function: atom(), handler: module(), input_schema: Phantom.Tool.JSONSchema.t(), meta: map(), mime_type: String.t(), name: String.t(), output_schema: Phantom.Tool.JSONSchema.t() }
@type text_response() :: %{content: [type: :text, text: String.t()]}
Functions
Tool response as audio content
The :mime_type
will be fetched from the current tool within the scope of
the request if not provided, but you will need to provide the rest.
binary
- Binary data.:mime_type
(optional) MIME type. Defaults to"application/octet-stream"
For example:
Phantom.Tool.audio(File.read!("game-over.wav"))
Phantom.Tool.audio(
File.read!("game-over.wav"),
mime_type: "audio/wav"
)
Build a tool spec. Be intentional with the name and description when defining the tool since it will inform the LLM when to use the tool.
The Phantom.Router.tool/3
macro will build these specs.
Fields:
:name
- The name of the tool.:title
A human-readable title for the tool, useful for UI display.:description
- The description of the tool and when to use it.:mime_type
- the MIME type of the results.:handler
- The module to call.:function
- The function to call on the handler module.:output_schema
- the JSON schema of the results.:input_schema
- The JSON schema of the input arguments.:read_only
Iftrue
, indicates the tool does not modify its environment.:destructive
Iftrue
, the tool may perform destructive updates (only meaningful when:read_only
isfalse
).:idempotent
Iftrue
, calling the tool repeatedly with the same arguments has no additional effect (only meaningful when:read_only
isfalse
).:open_world
Iftrue
, the tool may interact with an "open world" of external entities.
@spec embedded_resource(string_uri :: String.t(), map()) :: embedded_resource_response()
Embedded resource response.
Typically used with your router's read_resource/3
function.
See Phantom.Router.read_resource/3
for more information
@spec error(message :: String.t()) :: error_response()
Tool response as image content
The :mime_type
will be fetched from the current tool within the scope of
the request if not provided, but you will need to provide the rest.
binary
- Binary data.:mime_type
(optional) MIME type. Defaults to"application/octet-stream"
For example:
Phantom.Tool.image(File.read!("tower.png"))
Phantom.Tool.audio(
File.read!("tower.png"),
mime_type: "image/png"
)
@spec resource_link(string_uri :: String.t(), Phantom.ResourceTemplate.t(), map()) :: resource_link_response()
Resource link reponse.
Typically used with your router's resource_uri/3
function.
See Phantom.Router.resource_uri/3
for more information.
Formats the response from an MCP Router to the MCP specification
@spec text(map()) :: structured_response()
@spec text(String.t()) :: text_response()
Represent a Tool spec as json when listing the available tools to clients.