From all-skills
Exposes MCP tools for Phoenix apps: execute Elixir code, run SQL queries, list Ecto schemas, fetch docs/logs/source. Use for AI assistant integration, runtime debugging, Tidewave setup.
npx claudepluginhub vinnie357/claude-skills --plugin alliumThis skill uses the workspace's default tool permissions.
Tidewave is a dev tool by Dashbit that connects AI coding assistants to running Phoenix applications via the Model Context Protocol (MCP). It exposes runtime introspection tools: Ecto schemas, code execution, documentation lookup, log inspection, and SQL queries.
Searches, retrieves, and installs Agent Skills from prompts.chat registry using MCP tools like search_skills and get_skill. Activates for finding skills, browsing catalogs, or extending Claude.
Searches prompts.chat for AI prompt templates by keyword or category, retrieves by ID with variable handling, and improves prompts via AI. Use for discovering or enhancing prompts.
Checks Next.js compilation errors using a running Turbopack dev server after code edits. Fixes actionable issues before reporting complete. Replaces `next build`.
Tidewave is a dev tool by Dashbit that connects AI coding assistants to running Phoenix applications via the Model Context Protocol (MCP). It exposes runtime introspection tools: Ecto schemas, code execution, documentation lookup, log inspection, and SQL queries.
Current version: ~> 0.5 (v0.5.6 released 2026-03-13)
mix archive.install hex igniter_new
mix igniter.install tidewave
mix.exs:defp deps do
[
{:tidewave, "~> 0.5", only: :dev}
]
end
lib/my_app_web/endpoint.ex before the code_reloading? block:if Mix.env() == :dev do
plug Tidewave
end
if code_reloading? do
# ...existing code reload plugs...
end
mix deps.get
Apply the manual steps to the application defining the Phoenix endpoint (typically apps/your_app_web).
Tidewave exposes an MCP server at /tidewave/mcp on the Phoenix app's port. The transport type is HTTP (streamable).
Default URL: http://localhost:4000/tidewave/mcp
claude mcp add --transport http tidewave http://localhost:4000/tidewave/mcp
Add to CLAUDE.md to encourage MCP tool usage:
Always use Tidewave's tools for evaluating code, querying the database, etc.
Use `get_docs` to access documentation and `get_source_location` to find module/function definitions.
| Editor | Config File | URL Key |
|---|---|---|
| Cursor | .cursor/mcp.json | mcpServers.tidewave.url |
| VS Code | .vscode/mcp.json | servers.tidewave.url |
| Zed | Zed settings.json | context_servers.tidewave.settings.url |
All use URL: http://localhost:4000/tidewave/mcp
| Tool | Description |
|---|---|
project_eval | Execute Elixir code within the running application runtime |
execute_sql_query | Run SQL queries against the application database |
get_ecto_schemas | List all Ecto schema modules with their fields and associations |
get_ash_resources | List all Ash resources (when using the Ash framework) |
get_docs | Retrieve documentation for modules/functions using exact project versions |
search_package_docs | Query hexdocs.pm filtered to project dependencies (availability varies by framework) |
get_source_location | Find module/function source code file paths and line numbers |
get_models | List all application modules with their file locations |
get_logs | Access server logs; supports log level filtering (added v0.5.5) |
Note: search_package_docs may not be available in all frameworks. Verify availability for your setup.
Introspect schemas before writing queries:
get_ecto_schemas → discover schema structure → execute_sql_query
Look up documentation for project dependencies:
get_docs for specific modules, search_package_docs for broader hex dependency searches
Execute and test code in the running app:
project_eval → run Elixir expressions against live application state
if Mix.env() == :dev do
plug Tidewave,
allow_remote_access: false,
inspect_opts: [pretty: true, limit: 50]
end
| Option | Default | Description |
|---|---|---|
allow_remote_access | false | Allow connections from non-localhost |
inspect_opts | [] | Options passed to Kernel.inspect/2 for output formatting |
team | nil | Team configuration (e.g., [id: "my-company"]) |
The Tidewave desktop/CLI app (tidewave_app) runs a standalone MCP server without requiring a Phoenix application. Useful for containers, remote dev environments, or non-Phoenix Elixir projects.
http://localhost:9832cargo run -p tidewave-cli [-- --help]| Scenario | Use |
|---|---|
| Phoenix application | plug Tidewave in endpoint.ex |
| Container/remote dev | CLI app or plug with allow_remote_access: true |
| Non-Phoenix Elixir | CLI app |
| Standalone MCP server | CLI app on port 9832 |
Enable in config/dev.exs to help Tidewave map rendered HTML back to source HEEx templates:
config :phoenix_live_view,
debug_heex_annotations: true
config :phoenix,
debug_attributes: true
Requires Phoenix LiveView v1.1+ (current: 1.1.27).
Mix.env() == :dev or only: :dev in depsallow_remote_access: true only on trusted networksunsafe-eval in script-src directives and disables frame-ancestors restrictionsmix phx.serverhttp://127.0.0.1:4000/tidewave/mcp if IPv6 causes issuesplug Tidewave is placed before if code_reloading? in endpoint.exmix deps.getclaude in your terminal and confirm authenticationwhich claude:tidewave is added to the correct mix.exs in the umbrella