npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

simple-fal-mcp

v0.1.2

Published

Model Context Protocol (MCP) server for fal.ai model discovery, execution, and ephemeral local workspaces.

Readme

simple-fal-mcp

Model Context Protocol (MCP) server for Codex and Claude Code with fal model discovery, execution, pricing, request follow-up, temp workspaces, and local media post-process.

Current scope:

  • normal fal model endpoints only
  • queue and sync execution
  • image, video, and audio generation workflows
  • local temp workspace management and media finishing
  • no realtime/websocket flows in v1

Conceptual fal MCP visual

Tools

  • fal_status: always available; returns config/auth/capability state, setup-web state, media availability, saved cursors, and workspace summary.
  • fal_setup_web: local setup panel controller with actions status, start, stop.
  • fal_model: model discovery tool with actions search, next, get, pricing, estimate.
  • fal_cost: pricing/cost tool with actions price, estimate, usage, usage_next, request.
  • fal_run: submits one model run, supports local-file uploads, and saves request state in a temp workspace.
  • fal_request: request follow-up tool with actions status, wait, result, materialize, cancel, history, history_next.
  • fal_workspace: local workspace manager with actions list, get, delete, cleanup.
  • fal_media: local media tool with actions inspect, open, reveal, image_convert, image_resize, video_convert, video_trim, video_reverse, video_concat, image_sequence_to_video, extract_frame, mux_audio, audio_convert, audio_reverse, audio_concat.

Quick flow examples:

  • fal_model({ "action": "search", "query": "kling image to video" })
  • fal_model({ "action": "get", "endpointId": "fal-ai/kling-video/o1/standard/image-to-video", "schemaMode": "summary" })
  • fal_run({ "endpointId": "fal-ai/nano-banana-2", "input": { "prompt": "..." } })
  • fal_request({ "action": "wait", "runId": "..." })
  • fal_media({ "action": "image_resize", "workspaceId": "...", "inputPath": "runs/.../artifacts/01-images-0.png", "width": 1280, "height": 720, "fit": "cover" })

Install (npx)

Requirements:

  • Node >= 20.19.0
  • ffmpeg and ffprobe for video/audio actions

Codex

codex mcp remove simple-fal
codex mcp add simple-fal -- \
  npx -y simple-fal-mcp@latest

Ask your agent to run fal_status, call fal_setup_web with action: "start" if needed, and then send you setupWeb.url.

Optional: pass keys via env when adding:

codex mcp add simple-fal -- \
  --env FAL_KEY="$FAL_KEY" \
  --env FAL_ADMIN_KEY="$FAL_ADMIN_KEY" \
  -- npx -y simple-fal-mcp@latest

Claude Code

claude mcp remove simple-fal
claude mcp add --transport stdio simple-fal -- \
  npx -y simple-fal-mcp@latest

Ask Claude Code to run fal_status, call fal_setup_web with action: "start" if needed, and then share setupWeb.url.

Optional: pass keys via env when adding:

claude mcp add --transport stdio \
  --env FAL_KEY="$FAL_KEY" \
  --env FAL_ADMIN_KEY="$FAL_ADMIN_KEY" \
  simple-fal -- \
  npx -y simple-fal-mcp@latest

How To Use

Think of simple-fal-mcp as your "fal execution layer":

  • discover live models
  • inspect schema before spending money
  • check price or estimate cost
  • run with raw input and optional local-file uploads
  • continue by saved runId or requestId
  • finish outputs locally in a temp workspace

Typical flow

  1. Add the MCP server with the npx install command above.

  2. Ask your agent for setup status:

  • Run fal_status and tell me what is missing.
  1. If needed, ask for the setup link:
  • If setup web is not running, call fal_setup_web with action=start and give me setupWeb.url.
  1. Open the link, save the fal key, and optionally save an admin key. In some clients, you may need to restart the agent process after key changes so all tools see refreshed auth cleanly.

  2. Search and inspect before running:

  • Search fal for a Kling first/last-frame video model.
  • Show me the schema summary and upload pointer hints for this model.
  • Show me the live price and estimate a 5-second run.
  1. Run the model:
  • Submit this fal run and return the request id immediately.
  • Wait for that run and fetch the result when it is done.
  1. Finish locally if needed:
  • Resize this frame to 1280x720 with cover.
  • Mux this audio onto the video.
  • Open the final file.
  1. Clean up later:
  • Show me the last workspace.
  • Clean old fal temp workspaces.

What to ask your agent (examples)

  • Setup:
    • Please configure simple-fal and give me the setup link.
  • Discovery:
    • Find a cheap image-to-video model and show me the schema summary.
  • Pricing:
    • Show me the live price for this endpoint and estimate a 5-second run.
  • Execution:
    • Run this fal endpoint with these local files and save everything to a temp workspace.
  • Follow-up:
    • Wait for my last fal run and fetch the result if it is done.
  • Local media:
    • Resize this image to 1280x720 cover, reverse the final video, and open it.

Copy-Paste For AGENTS.md / CLAUDE.md

You can add explicit usage instructions like this:

If user uses simple-fal-mcp:

1) Setup flow
- Call fal_status.
- If setup is incomplete, call fal_setup_web(action=start) and return setupWeb.url.
- Tell user to open the local setup page and save the key.
- When setup is finished or user asks to close it, call fal_setup_web(action=stop).

2) Discovery and pricing
- Use fal_model(action=search) to find endpoints.
- Use fal_model(action=get, schemaMode=summary) before requesting raw OpenAPI.
- Use fal_cost(action=price) or fal_cost(action=estimate) before expensive runs when useful.

3) Run flow
- Prefer fal_run with wait=submit.
- Use uploadFiles for local files instead of pasting inline data.
- Follow queued runs with fal_request(action=wait|status|result).
- Use fal_request(action=materialize) if the provider run finished but local files are missing.

4) Workspace and media
- Prefer workspace-relative follow-up by runId/workspaceId.
- Use fal_media for local resize/convert/trim/mux/reveal/open steps.
- Keep final files by copying them out of the temp workspace.

5) Safety
- Never expose fal keys, admin keys, or setup tokens in user-visible messages.
- Do not claim realtime/websocket support in v1.

Configuration

Default paths:

  • $XDG_CONFIG_HOME/simple-fal-mcp/config.json
  • $XDG_CONFIG_HOME/simple-fal-mcp/auth.json
  • $XDG_CONFIG_HOME/simple-fal-mcp/state.json
  • or ~/.config/simple-fal-mcp/...

File roles:

  • config.json: runtime defaults and workspace settings
  • auth.json: fal API key and optional admin key
  • state.json: saved cursors, request history state, usage cursor state, and workspace index

Env precedence:

  1. CLI args
  2. environment variables
  3. config/auth/state files

Supported env vars:

  • FAL_KEY
  • FAL_ADMIN_KEY
  • FAL_DEFAULT_WAIT_MS
  • FAL_POLL_INTERVAL_MS
  • FAL_MODEL_SEARCH_LIMIT
  • FAL_ARTIFACT_DOWNLOAD_LIMIT
  • FAL_OBJECT_TTL_SECONDS
  • FAL_DOWNLOAD_OUTPUTS
  • FAL_WORKSPACE_ROOT
  • FAL_WORKSPACE_AUTO_CLEANUP_HOURS
  • FAL_SETUP_WEB_AUTO_STOP_MINUTES

Useful CLI args:

  • --fal-key
  • --fal-admin-key
  • --config
  • --auth
  • --state
  • --setup-host
  • --setup-port
  • --setup-token

Local Workspace Model

Generated outputs are stored under a local temp root by default:

/tmp/simple-fal-mcp/workspaces/<workspace-id>/

Each run gets a directory with:

  • request.json
  • status.json
  • response.json
  • artifacts/

These files are temp state, not permanent storage. If you want to keep an output, copy it out of the workspace.

Local Development

bun install
bun run lint
bun run typecheck
bun run build
bun run self-test

Notes

  • Model discovery and schema inspection use fal’s live APIs instead of a hardcoded local catalog.
  • fal_run defaults to queue mode with wait: "submit" and saves request state locally so later tools can recover by runId.
  • Local uploads are resolved before submit and recorded in run metadata.
  • Provider success and local artifact download are treated separately, so a completed run stays completed even when local mirroring needs a retry.
  • The setup page does not expose the stored fal key or admin key back to the browser after either has been saved.