Phantom.Tool (phantom_mcp v0.2.0)
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
Summary
Functions
Tool response as audio content
Build a tool spec
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 => InputSchema.json(), optional(:outputSchema) => OutputSchema.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
The Phantom.Router.tool/3
macro will build these specs.
@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.