Skip to main content
Glama
nami2111

junobuild-mcp-server

by nami2111

junobuild-mcp-server

Unofficial MCP server for Juno. Not affiliated with or endorsed by the Juno team.

Manage satellites, hosting, serverless functions, changes and more through any MCP-compatible client. Includes a built-in documentation tool to access Juno's official guides and references.

Features

  • 18 tools across 6 domains — CLI coverage for identity, config, hosting, functions, changes, and documentation

  • Progress streaming — long-running operations (deploy, publish, upgrade) emit real-time progress updates via MCP notifications/progress

  • Log streamingstreamLogs: true mirrors raw stdout/stderr lines as MCP notifications/message events, independent of progress

  • Automatic retry — network-dependent operations can retry on transient failures with exponential backoff

  • CLI binary caching — resolves juno binary path once, eliminating npx overhead on every call

  • CLI version check — verifies installed @junobuild/cli meets the minimum supported version on first call

  • Structured error parsing — common CLI failures (auth, network, missing config) surface as actionable messages

  • Config file writingjuno_config_init can write config files directly to disk

  • Auth verificationjuno_auth_status wraps juno whoami for read-only identity checks

  • Docs caching — documentation responses backed by an LRU cache (50 entries, 1 h TTL)

  • Tunable limits — character limit, default timeout, and network timeout overridable via env vars

Related MCP server: MCPJungle mcp gateway

Client Setup

Choose your AI coding agent below for specific setup instructions.

Claude Code

CLI (recommended):

claude mcp add junobuild npx -y junobuild-mcp-server

Config file:

Scope

Location

User

~/.claude/mcp.json

Project

.mcp.json

{
  "mcpServers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Codex

CLI:

codex mcp add junobuild -- npx -y junobuild-mcp-server

Config file:

Scope

Location

Global

~/.codex/config.toml

Project

.codex/config.toml

[mcp_servers.junobuild]
command = "npx"
args = ["-y", "junobuild-mcp-server"]

OpenCode

Config file:

Scope

Location

User

~/.opencode/opencode.json (Linux/macOS)

Workspace

opencode.json (project root)

{
  "mcpServers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Factory Droid

CLI:

droid mcp add junobuild npx -y junobuild-mcp-server

Config file:

Scope

Location

User

~/.factory/mcp.json

Project

.factory/mcp.json

{
  "mcpServers": {
    "junobuild": {
      "type": "stdio",
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Antigravity

Uses a Powers system with custom configuration.

Config file:

Scope

Location

Workspace

.antigravity/powers/ or project config

Add the MCP server configuration to your Power's mcp.json:

{
  "mcpServers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Note: See Antigravity MCP documentation for full Power setup.

Cursor

Config file:

Scope

Location

User

~/.cursor/mcp.json

Project

.cursor/mcp.json

{
  "mcpServers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Amp Code

CLI:

amp mcp add junobuild -- npx -y junobuild-mcp-server

Config file:

Scope

Location

User

~/.config/amp/settings.json (macOS/Linux)

Workspace

.amp/settings.json

{
  "amp.mcpServers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Note: Workspace MCP servers require approval via amp mcp approve <server-name>.

VSCode

Config file:

Scope

Location

User

~/.config/Code/User/mcp.json (Linux)

Workspace

.vscode/mcp.json

{
  "servers": {
    "junobuild": {
      "type": "stdio",
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Windsurf

Config file:

Scope

Location

User

~/.codeium/windsurf/mcp_config.json

{
  "mcpServers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Kiro

Config file:

Scope

Location

User

~/.kiro/settings/mcp.json

Workspace

.kiro/settings/mcp.json

{
  "mcpServers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Kilo Code

Config file:

Scope

Location

User

~/.config/Kilo Code/User/mcp.json

Project

.vscode/mcp.json

{
  "servers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Cline

Config file:

Scope

Location

User

cline_mcp_settings.json (in config dir)

{
  "mcpServers": {
    "junobuild": {
      "command": "npx",
      "args": ["-y", "junobuild-mcp-server"]
    }
  }
}

Authenticate the Juno CLI

The server wraps @junobuild/cli, which must be installed and authenticated:

npm i -g @junobuild/cli
juno login

For non-interactive environments (CI, headless), set the JUNO_TOKEN environment variable instead of running juno login. Tools that touch Juno state additionally accept mode and profile parameters to select an environment and identity per call.

Environment Variables

For non-interactive environments (CI, headless), authenticate using environment variables:

export JUNO_TOKEN="your-juno-token"

Server Tuning

Override defaults to tune resource limits without rebuilding. Values must be positive integers; invalid values fall back to defaults.

Variable

Default

Description

JUNO_MCP_CHAR_LIMIT

25000

Max characters returned in a single tool response (truncates beyond)

JUNO_MCP_TIMEOUT

120000

Default subprocess timeout in milliseconds

JUNO_MCP_NETWORK_TIMEOUT

300000

Timeout for network-bound operations (deploy, publish, upgrade) in ms

JUNO_MCP_DEBUG

false

When true, logs internal errors to stderr (silent catches, notifications)

Note: The juno_create_project tool does NOT use the interactive create-juno CLI. Instead it:

  1. Scaffolds a Vite project (React, Next.js, Svelte, Angular, or Vue)

  2. Creates a juno.config.ts file

This allows fully non-interactive project creation.

Documentation Access

The juno_docs tool fetches documentation directly from the GitHub repo, with responses cached for 1 hour:

juno_docs({ topic: "build_datastore" })        → Datastore guide
juno_docs({ topic: "build_authentication" })   → Authentication overview
juno_docs({ topic: "reference_cli" })        → CLI reference
juno_docs({ topic: "guides_local_development" }) → Local development guide

Topic keys use underscore naming matching folder hierarchy: build_<feature>, reference_cli_<command>, guides_<framework>. Full enumeration of all 159 topics lives in src/schemas/docs.ts (TOPICS map).

Tools

Domain

Tools

Identity

juno_version, juno_run, juno_status, juno_auth_status

Config

juno_config_init, juno_config_apply, juno_create_project

Hosting

juno_hosting_deploy, juno_hosting_clear, juno_hosting_prune

Functions

juno_functions_build, juno_functions_eject, juno_functions_publish, juno_functions_upgrade

Changes

juno_changes_list, juno_changes_apply, juno_changes_reject

Docs

juno_docs

Key Parameters

Several tools support optional parameters for enhanced reliability and UX:

Parameter

Type

Tools

Description

retry

boolean

deploy, publish, upgrade

Automatically retry on transient network failures (up to 3 attempts with exponential backoff: 1s → 2s → 4s)

progress

boolean

deploy, publish, upgrade

Stream real-time progress updates during long-running operations (build status + upload batch progress)

streamLogs

boolean

deploy, publish, upgrade

Stream raw stdout/stderr lines as MCP notifications/message events. Independent from progress

writeFile

boolean

juno_config_init

Write the config file directly to disk instead of returning text for preview

Prerequisites

  • Node.js >= 18

  • @junobuild/cli >= 0.15.0 — installed and authenticated (not needed for juno_version or juno_docs). Minimum version enforced on first call via checkCliVersion (src/constants.ts MIN_CLI_VERSION). Bypass with JUNO_SKIP_VERSION_CHECK=true.

  • Juno project with juno.config.ts/js/json (for config/hosting operations)

Development

npm run build           # Compile TypeScript to dist/
npm run dev             # Watch mode (development)
npm run start           # Run compiled dist/index.js
npm run clean           # Remove dist/
npm test                # Run unit tests
npm run test:coverage   # Run tests with coverage report (v8 provider)

Coverage thresholds

The suite enforces the following minimum coverage (configured in vitest.config.ts):

  • Lines: 80%

  • Statements: 80%

  • Functions: 80%

  • Branches: 75%

Coverage reports are written to coverage/ (html, lcov, json, plus text summary).

Publishing

npm run changeset    # Create a changeset (version bump + changelog entry)
npm run version      # Apply changesets → bump version
npm run release      # Publish to npm

Architecture

Key design decisions are documented as ADRs in docs/adr/:

License

MIT

Install Server
A
license - permissive license
A
quality
B
maintenance

Maintenance

Maintainers
Response time
Release cycle
Releases (12mo)
Commit activity

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/nami2111/junobuild-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server