mcp-jumpserver-gui-sucks

mcp-jumpserver-gui-sucks

A JumpServer 443-only MCP bridge for coding agents that exposes a CLI-first, MFA-compatible, audit-preserving path into JumpServer assets without GUI or port 2222 dependencies.

Category
Visit Server

README

mcp-jumpserver-gui-sucks

CAUTION: Operate production machines with extreme care. This MCP assumes no responsibility for production incidents caused by unsafe or incompetent model behavior.

A JumpServer 443-only MCP bridge for coding agents such as Codex and Claude. The project exposes a CLI-first, MFA-compatible, audit-preserving path into JumpServer assets without depending on port 2222 or any GUI-driven workflow in normal use.

Current Status

The main CLI and MCP chain is working against a real JumpServer instance:

  • CLI-first login with terminal-entered MFA
  • persisted durable access_key auth for REST discovery
  • persisted authenticated web-session cookies for KoKo terminal flows
  • asset, node, connect-method, and asset-access discovery
  • KoKo 443 WebSocket probing
  • one-shot remote command execution through KoKo
  • managed multi-turn terminal sessions for MCP-driven shell interaction
  • managed shell reuse for repeated command execution against the same asset/account target
  • non-blocking buffered terminal output reads for managed sessions
  • explicit managed-session command interruption with Ctrl-C
  • process-local terminal idle reaping and session-cap enforcement
  • explicit cookie-session refresh probing before terminal work
  • a line-oriented CLI shell for non-MCP interactive terminal use

The current implementation is usable, but it is not feature-complete yet. The most important known limitation is:

  • terminal access still depends on a valid cookie-backed web session, so a fully expired terminal session still requires a fresh login run with MFA

Terminal-oriented entry points now accept either the concrete JumpServer account ID/alias required by the API or a user-facing account reference such as root, test-root, or the account username. The MCP resolves that reference to the concrete per-asset account ID before opening terminal sessions or creating connection tokens.

The project does not currently aim to provide file-manager or SFTP coverage.

Tracked Project Docs

Upstream Reference Repositories

The repository keeps several untracked upstream JumpServer codebases under extern/ for protocol and behavior reference only. They are not runtime dependencies of this package.

  • extern/jumpserver: backend API, authentication, and permission-model reference
  • extern/koko: KoKo terminal gateway and WebSocket behavior reference
  • extern/luna: legacy web-terminal frontend flow reference, especially around browser-driven terminal bootstrap behavior
  • extern/lina: newer web UI and API usage-pattern reference
  • extern/client: official client-side implementation reference for adjacent access workflows

Authentication Model

The runtime intentionally uses two auth layers:

  • access_key for durable REST access
  • authenticated web-session cookies for KoKo terminal access

Do not put live session secrets, cookies, or MFA values into MCP client config files. The intended flow is:

  1. Run the CLI login command once.
  2. Complete MFA in the terminal.
  3. Let the tool persist auth state into the user-scoped application state directory.
  4. Start the MCP server from Codex or Claude.

When the live JumpServer deployment enables a login captcha challenge, the CLI login command saves the captcha image under /private/tmp/ and opens it with the system image viewer before prompting for the captcha value in the terminal.

By default, persisted auth state lives under the platform-specific user application state directory:

  • macOS example: ~/Library/Application Support/mcp-jumpserver-gui-sucks/auth-state.json

Advanced users can override the location with:

  • MCP_JUMPSERVER_GUI_SUCKS_STATE_DIR
  • MCP_JUMPSERVER_GUI_SUCKS_STATE_FILE

Install

Use the published package directly:

uvx mcp-jumpserver-gui-sucks --help

Login Before Starting MCP

uvx mcp-jumpserver-gui-sucks login \
  --base-url https://jumpserver.example.com \
  --username alice

Useful verification commands:

uvx mcp-jumpserver-gui-sucks doctor
uvx mcp-jumpserver-gui-sucks refresh-session --force

The login command persists state outside the repository. MCP client config should only describe how to find that state, not embed the secrets themselves.

MCP Configuration

The MCP server entrypoint is:

uvx mcp-jumpserver-gui-sucks serve

serve defaults to stdio, which is the correct transport for Codex and Claude desktop-style MCP clients.

Recommended Agent Terminal Workflow

When a coding agent plans to work on one machine for more than one command, the recommended workflow is:

  1. Call jms_terminal_usage_guide.
  2. Call jms_acquire_terminal_session with asset_ref and account_ref.
  3. Use jms_run_terminal_command for short command-style work.
  4. Use jms_send_terminal_input plus jms_read_terminal_output for shell-style interaction.
  5. Call jms_interrupt_terminal_session when a command needs to be stopped.
  6. Call jms_close_terminal_session when the task is complete.

This keeps one KoKo shell open per target and avoids leaving many short-lived web-shell records behind in JumpServer.

Codex (~/.codex/config.toml)

This matches the mcp_servers.* structure already used in your local ~/.codex/config.toml:

[mcp_servers.mcp-jumpserver-gui-sucks]
command = "uvx"
args = ["mcp-jumpserver-gui-sucks", "serve"]
startup_timeout_sec = 60.0
tool_timeout_sec = 600.0

[mcp_servers.mcp-jumpserver-gui-sucks.env]
MCP_JUMPSERVER_GUI_SUCKS_BASE_URL = "https://jumpserver.example.com"
MCP_JUMPSERVER_GUI_SUCKS_VERIFY_TLS = "true"
MCP_JUMPSERVER_GUI_SUCKS_TERMINAL_IDLE_TIMEOUT_SECONDS = "3600"
MCP_JUMPSERVER_GUI_SUCKS_TERMINAL_REAP_INTERVAL_SECONDS = "30"
MCP_JUMPSERVER_GUI_SUCKS_MAX_TERMINAL_SESSIONS = "8"

# Optional when the default state directory is not desired.
# MCP_JUMPSERVER_GUI_SUCKS_STATE_DIR = "/Users/alice/Library/Application Support/mcp-jumpserver-gui-sucks"
# MCP_JUMPSERVER_GUI_SUCKS_STATE_FILE = "/Users/alice/Library/Application Support/mcp-jumpserver-gui-sucks/auth-state.json"
# MCP_JUMPSERVER_GUI_SUCKS_ORG_ID = "00000000-0000-0000-0000-000000000002"

tool_timeout_sec is a Codex-side MCP client setting. If it is omitted, Codex falls back to its own default per-tool timeout. Increase it when the agent may need to keep a single jms_* call open for longer-running terminal work. For terminal commands, pair it with a larger total_timeout_seconds on the specific jms_run_terminal_command or jms_execute_in_terminal_session call when needed.

Claude (~/.claude.json)

This matches the mcpServers JSON shape already present in your local ~/.claude.json:

{
  "mcpServers": {
    "mcp-jumpserver-gui-sucks": {
      "command": "uvx",
      "args": ["mcp-jumpserver-gui-sucks", "serve"],
      "env": {
        "MCP_JUMPSERVER_GUI_SUCKS_BASE_URL": "https://jumpserver.example.com",
        "MCP_JUMPSERVER_GUI_SUCKS_VERIFY_TLS": "true",
        "MCP_JUMPSERVER_GUI_SUCKS_TERMINAL_IDLE_TIMEOUT_SECONDS": "3600",
        "MCP_JUMPSERVER_GUI_SUCKS_TERMINAL_REAP_INTERVAL_SECONDS": "30",
        "MCP_JUMPSERVER_GUI_SUCKS_MAX_TERMINAL_SESSIONS": "8"
      }
    }
  }
}

Supported Environment Variables

The current runtime reads these environment variables:

  • MCP_JUMPSERVER_GUI_SUCKS_BASE_URL
  • MCP_JUMPSERVER_GUI_SUCKS_ORG_ID
  • MCP_JUMPSERVER_GUI_SUCKS_STATE_DIR
  • MCP_JUMPSERVER_GUI_SUCKS_STATE_FILE
  • MCP_JUMPSERVER_GUI_SUCKS_VERIFY_TLS
  • MCP_JUMPSERVER_GUI_SUCKS_LOG_LEVEL
  • MCP_JUMPSERVER_GUI_SUCKS_REQUEST_TIMEOUT_SECONDS
  • MCP_JUMPSERVER_GUI_SUCKS_TERMINAL_IDLE_TIMEOUT_SECONDS
  • MCP_JUMPSERVER_GUI_SUCKS_TERMINAL_REAP_INTERVAL_SECONDS
  • MCP_JUMPSERVER_GUI_SUCKS_MAX_TERMINAL_SESSIONS

The recommended minimum MCP config is usually:

  • MCP_JUMPSERVER_GUI_SUCKS_BASE_URL
  • optionally MCP_JUMPSERVER_GUI_SUCKS_STATE_DIR or MCP_JUMPSERVER_GUI_SUCKS_STATE_FILE

PyPI Release Automation

The repository now includes publish-pypi.yml.

Its behavior is intentionally:

  • every push to main inspects pyproject.toml
  • if the package version changed and that version does not already exist on PyPI, GitHub Actions builds and publishes it
  • if the version did not change, the workflow skips publishing
  • if the version already exists on PyPI, the workflow skips publishing
  • workflow_dispatch can be used to publish the current version manually when it is not yet on PyPI

The publish job uses PyPI Trusted Publishing through GitHub OIDC. Configure PyPI to trust this repository and workflow before expecting the publish step to succeed.

Recommended PyPI trusted publisher settings:

  • owner: ArtiPyHeart
  • repository: mcp-jumpserver-gui-sucks
  • workflow file: .github/workflows/publish-pypi.yml
  • environment name: pypi

After Trusted Publishing is configured once, later pushes to main that bump project.version in pyproject.toml will publish automatically.

Current CLI Surface

  • mcp-jumpserver-gui-sucks login
  • mcp-jumpserver-gui-sucks paths
  • mcp-jumpserver-gui-sucks doctor
  • mcp-jumpserver-gui-sucks refresh-session
  • mcp-jumpserver-gui-sucks resolve-target
  • mcp-jumpserver-gui-sucks koko-probe
  • mcp-jumpserver-gui-sucks terminal-exec
  • mcp-jumpserver-gui-sucks terminal-shell
  • mcp-jumpserver-gui-sucks save-state
  • mcp-jumpserver-gui-sucks clear-state
  • mcp-jumpserver-gui-sucks serve

Current MCP Tools

  • jms_paths
  • jms_status
  • jms_terminal_usage_guide
  • jms_profile
  • jms_list_nodes
  • jms_list_assets
  • jms_get_asset
  • jms_list_connect_methods
  • jms_get_asset_access
  • jms_resolve_terminal_target
  • jms_list_connection_tokens
  • jms_create_connection_token
  • jms_expire_connection_token
  • jms_refresh_terminal_auth
  • jms_probe_koko_terminal
  • jms_acquire_terminal_session
  • jms_list_terminal_sessions
  • jms_send_terminal_input
  • jms_read_terminal_output
  • jms_run_terminal_command
  • jms_interrupt_terminal_session
  • jms_resize_terminal_session
  • jms_close_terminal_session

Operational Notes

  • Managed terminal sessions are process-local and intended to live only for the MCP server process lifetime.
  • jms_terminal_usage_guide returns the preferred terminal workflow for coding agents and should be consulted at the start of terminal-heavy work.
  • jms_acquire_terminal_session is the preferred high-level entrypoint for repeated work on one machine because it resolves the target and reuses an existing shell when possible.
  • jms_run_terminal_command is the preferred path for short command execution on an already acquired session_handle.
  • jms_send_terminal_input plus jms_read_terminal_output are the preferred path for shell-style interaction and incremental polling.
  • jms_interrupt_terminal_session is the supported way to stop a running managed-session command without throwing away the shell immediately.
  • jms_interrupt_terminal_session accepts ctrl_c and the common alias SIGINT; both normalize to the same Ctrl+C behavior.
  • The default managed shell idle timeout is 1 hour. Override it with MCP_JUMPSERVER_GUI_SUCKS_TERMINAL_IDLE_TIMEOUT_SECONDS if a different retention window is required.
  • When the MCP server process exits normally, it closes all managed KoKo shells before returning.
  • terminal-shell is line-oriented, not a full raw TTY emulator.
  • Terminal entrypoints preflight the cookie-backed web session before opening KoKo.
  • If the cookie-backed session is already invalid, terminal calls fail early with an explicit re-login requirement instead of a low-level websocket failure.
  • REST discovery can continue to work when the durable access_key remains valid, even if terminal access requires a fresh login.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured