Semgrep Mcp サーバー
概要
MCPとは何ですか?
MCP(Multi-Component Platform)は、セキュリティ脆弱性を特定するためにコードをスキャンするためにSemgrepを利用するように設計されたサーバーです。これは、開発者やセキュリティ専門家にとって強力なツールであり、開発プロセスの初期段階で潜在的なセキュリティ問題を検出することによって、コードベースの整合性と安全性を確保することを可能にします。
MCPの特徴
- セキュリティスキャン:MCPはSemgrepの機能を活用して、さまざまなセキュリティ脆弱性のためにコードをスキャンし、チームが安全なコーディングプラクティスを維持できるようにします。
- ユーザーフレンドリーなインターフェース:プラットフォームは直感的なインターフェースを提供し、スキャンプロセスを簡素化し、すべてのスキルレベルのユーザーがアクセスできるようにします。
- CI/CDとの統合:MCPは継続的インテグレーションおよび継続的デプロイメント(CI/CD)パイプラインに統合でき、開発ワークフローの一部として自動化されたセキュリティチェックを可能にします。
- カスタマイズ可能なルール:ユーザーは特定のセキュリティ要件に合わせたカスタムルールを定義でき、スキャンプロセスの効果を高めます。
- リアルタイムフィードバック:プラットフォームはコードの脆弱性に関する即時のフィードバックを提供し、開発者が問題に迅速に対処できるようにします。
MCPの使い方
- 環境を設定する:まず、サーバーまたはローカルマシンにMCPをインストールします。ドキュメントに記載されたインストール手順に従ってください。
- プロジェクトを構成する:MCP内に新しいプロジェクトを作成し、使用しているプログラミング言語やフレームワークを含む必要な設定を構成します。
- スキャンルールを定義する:組み込みのルールを利用するか、組織のセキュリティポリシーを反映したカスタムルールを作成します。
- スキャンを実行する:コードベースのスキャンを開始します。MCPはコードを分析し、定義されたルールに基づいて脆弱性を特定します。
- 結果を確認する:スキャンが完了したら、検出された脆弱性を理解するために結果を確認します。プラットフォームは各問題に関する詳細情報を提供します。
- 脆弱性を修正する:コード内の特定された脆弱性に対処します。MCPが提供するフィードバックを使用して修正作業を進めます。
- CI/CDに統合する:継続的なセキュリティ保証のために、MCPをCI/CDパイプラインに統合し、コード変更ごとにスキャンを自動化します。
よくある質問
MCPはどのプログラミング言語をサポートしていますか?
MCPは、Python、JavaScript、Java、Goなどを含む幅広いプログラミング言語をサポートしています。サポートされている言語の完全なリストについては、ドキュメントを確認してください。
MCPはオープンソースですか?
はい、MCPはオープンソースプロジェクトであり、ユーザーがその開発に貢献し、ニーズに応じてカスタマイズすることができます。
MCPで見つけた脆弱性を報告するにはどうすればよいですか?
MCP自体に脆弱性を発見した場合は、GitHubのプロジェクトのイシュートラッカーを通じて報告してください。メンテナが問題に迅速に対処できるように、詳細な情報を提供してください。
商業プロジェクトにMCPを使用できますか?
もちろんです!MCPは個人用および商業用の両方に設計されており、開発者や組織にとって多用途なツールです。
MCPに関する詳細情報はどこで見つけられますか?
詳細情報については、公式MCPウェブサイト mcp.semgrep.ai を訪れるか、ドキュメントや更新情報のためにGitHubリポジトリを確認してください。
詳細
Semgrep MCP Server
A Model Context Protocol (MCP) server for using Semgrep to scan code for security vulnerabilities. Secure your vibe coding! 😅
Model Context Protocol (MCP) is a standardized API for LLMs, Agents, and IDEs like Cursor, VS Code, Windsurf, or anything that supports MCP, to get specialized help, get context, and harness the power of tools. Semgrep is a fast, deterministic static analysis tool that semantically understands many languages and comes with over 5,000 rules. 🛠️
[!NOTE] This beta project is under active development. We would love your feedback, bug reports, feature requests, and code. Join the
#mcp
community Slack channel!
Contents
- Semgrep MCP Server
Getting started
Run the Python package as a CLI command using uv
:
uvx semgrep-mcp # see --help for more options
Or, run as a Docker container:
docker run -i --rm ghcr.io/semgrep/mcp -t stdio
Cursor
Example mcp.json
{
"mcpServers": {
"semgrep": {
"command": "uvx",
"args": ["semgrep-mcp"],
"env": {
"SEMGREP_APP_TOKEN": "<token>"
}
}
}
}
Add an instruction to your .cursor/rules
to use automatically:
Always scan code generated using Semgrep for security vulnerabilities
ChatGPT
- Go to the Connector Settings page (direct link)
- Name the connection
Semgrep
- Set MCP Server URL to
https://mcp.semgrep.ai/sse
- Set Authentication to
No authentication
- Check the I trust this application checkbox
- Click Create
See more details at the official docs.
Hosted Server
[!WARNING] mcp.semgrep.ai is an experimental server that may break unexpectedly. It will rapidly gain new functionality.🚀
Cursor
- Cmd + Shift + J to open Cursor Settings
- Select MCP Tools
- Click New MCP Server.
{
"mcpServers": {
"semgrep": {
"type": "streamable-http",
"url": "https://mcp.semgrep.ai/mcp"
}
}
}
Demo
<a href="https://www.loom.com/share/8535d72e4cfc4e1eb1e03ea223a702df"> <img style="max-width:300px;" src="https://cdn.loom.com/sessions/thumbnails/8535d72e4cfc4e1eb1e03ea223a702df-1047fabea7261abb-full-play.gif"> </a>
API
Tools
Enable LLMs to perform actions, make deterministic computations, and interact with external services.
Scan Code
security_check
: Scan code for security vulnerabilitiessemgrep_scan
: Scan code files for security vulnerabilities with a given config stringsemgrep_scan_with_custom_rule
: Scan code files using a custom Semgrep rule
Understand Code
get_abstract_syntax_tree
: Output the Abstract Syntax Tree (AST) of code
Cloud Platform (login and Semgrep token required)
semgrep_findings
: Fetch Semgrep findings from the Semgrep AppSec Platform API
Meta
supported_languages
: Return the list of languages Semgrep supportssemgrep_rule_schema
: Fetches the latest semgrep rule JSON Schema
Prompts
Reusable prompts to standardize common LLM interactions.
write_custom_semgrep_rule
: Return a prompt to help write a Semgrep rule
Resources
Expose data and content to LLMs
semgrep://rule/schema
: Specification of the Semgrep rule YAML syntax using JSON schemasemgrep://rule/{rule_id}/yaml
: Full Semgrep rule in YAML format from the Semgrep registry
Usage
This Python package is published to PyPI as semgrep-mcp and can be installed and run with pip, pipx, uv, poetry, or any Python package manager.
$ pipx install semgrep-mcp
$ semgrep-mcp --help
Usage: semgrep-mcp [OPTIONS]
Entry point for the MCP server
Supports both stdio and sse transports. For stdio, it will read from stdin
and write to stdout. For sse, it will start an HTTP server on port 8000.
Options:
-v, --version Show version and exit.
-t, --transport [stdio|sse] Transport protocol to use (stdio or sse)
-h, --help Show this message and exit.
Standard Input/Output (stdio)
The stdio transport enables communication through standard input and output streams. This is particularly useful for local integrations and command-line tools. See the spec for more details.
Python
semgrep-mcp
By default, the Python package will run in stdio
mode. Because it's using the standard input and output streams, it will look like the tool is hanging without any output, but this is expected.
Docker
This server is published to Github's Container Registry (ghcr.io/semgrep/mcp)
docker run -i --rm ghcr.io/semgrep/mcp -t stdio
By default, the Docker container is in SSE
mode, so you will have to include -t stdio
after the image name and run with -i
to run in interactive mode.
Streamable HTTP
Streamable HTTP enables streaming responses over JSON RPC via HTTP POST requests. See the spec for more details.
By default, the server listens on 127.0.0.1:8000/mcp for client connections. To change any of this, set FASTMCP_* environment variables. The server must be running for clients to connect to it.
Python
semgrep-mcp -t streamable-http
By default, the Python package will run in stdio
mode, so you will have to include -t streamable-http
.
Docker
docker run -p 8000:0000 ghcr.io/semgrep/mcp
Server-sent events (SSE)
[!WARNING] The MCP communiity considers this a legacy transport portcol and is really intended for backwards compatibility. Streamable HTTP is the recommended replacement.
SSE transport enables server-to-client streaming with Server-Send Events for client-to-server and server-to-client communication. See the spec for more details.
By default, the server listens on 127.0.0.1:8000/sse for client connections. To change any of this, set FASTMCP_* environment variables. The server must be running for clients to connect to it.
Python
semgrep-mcp -t sse
By default, the Python package will run in stdio
mode, so you will have to include -t sse
.
Docker
docker run -p 8000:0000 ghcr.io/semgrep/mcp -t sse
Semgrep AppSec Platform
Optionally, to connect to Semgrep AppSec Platform:
- Login or sign up
- Generate a token from Settings
- Add the token to your environment variables:
-
CLI (
export SEMGREP_APP_TOKEN=<token>
) -
Docker (
docker run -e SEMGREP_APP_TOKEN=<token>
) -
MCP config JSON
-
"env": {
"SEMGREP_APP_TOKEN": "<token>"
}
[!TIP] Please reach out for support if needed. ☎️
Integrations
Cursor IDE
Add the following JSON block to your ~/.cursor/mcp.json
global or .cursor/mcp.json
project-specific configuration file:
{
"mcpServers": {
"semgrep": {
"command": "uvx",
"args": ["semgrep-mcp"]
}
}
}
See cursor docs for more info.
VS Code / Copilot
Click the install buttons at the top of this README for the quickest installation.
Manual Configuration
Add the following JSON block to your User Settings (JSON) file in VS Code. You can do this by pressing Ctrl + Shift + P
and typing Preferences: Open User Settings (JSON)
.
{
"mcp": {
"servers": {
"semgrep": {
"command": "uvx",
"args": ["semgrep-mcp"]
}
}
}
}
Optionally, you can add it to a file called .vscode/mcp.json
in your workspace:
{
"servers": {
"semgrep": {
"command": "uvx",
"args": ["semgrep-mcp"]
}
}
}
Using Docker
{
"mcp": {
"servers": {
"semgrep": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"ghcr.io/semgrep/mcp",
"-t",
"stdio"
]
}
}
}
}
See VS Code docs for more info.
Windsurf
Add the following JSON block to your ~/.codeium/windsurf/mcp_config.json
file:
{
"mcpServers": {
"semgrep": {
"command": "uvx",
"args": ["semgrep-mcp"]
}
}
}
See Windsurf docs for more info.
Claude Desktop
Here is a short video showing Claude Desktop using this server to write a custom rule.
Add the following JSON block to your claude_desktop_config.json
file:
{
"mcpServers": {
"semgrep": {
"command": "uvx",
"args": ["semgrep-mcp"]
}
}
}
See Anthropic docs for more info.
Claude Code
claude mcp add semgrep uvx semgrep-mcp
See Claude Code docs for more info.
OpenAI
See the offical docs:
Agents SDK
async with MCPServerStdio(
params={
"command": "uvx",
"args": ["semgrep-mcp"],
}
) as server:
tools = await server.list_tools()
See OpenAI Agents SDK docs for more info.
Custom clients
Example Python SSE client
See a full example in examples/sse_client.py
from mcp.client.session import ClientSession
from mcp.client.sse import sse_client
async def main():
async with sse_client("http://localhost:8000/sse") as (read_stream, write_stream):
async with ClientSession(read_stream, write_stream) as session:
await session.initialize()
results = await session.call_tool(
"semgrep_scan",
{
"code_files": [
{
"filename": "hello_world.py",
"content": "def hello(): print('Hello, World!')",
}
]
},
)
print(results)
[!TIP] Some client libraries want the
URL
: http://localhost:8000/sse and others only want theHOST
:localhost:8000
. Try out theURL
in a web browser to confirm the server is running, and there are no network issues.
See official SDK docs for more info.
Contributing, community, and running from source
[!NOTE] We love your feedback, bug reports, feature requests, and code. Join the
#mcp
community Slack channel!
See CONTRIBUTING.md for more info and details on how to run from the MCP server from source code.
Similar tools 🔍
- semgrep-vscode - Official VS Code extension
- semgrep-intellij - IntelliJ plugin
Community projects 🌟
- semgrep-rules - The official collection of Semgrep rules
- mcp-server-semgrep - Original inspiration written by Szowesgad and stefanskiasan
MCP server registries
<a href="https://glama.ai/mcp/servers/@semgrep/mcp"> <img width="380" height="200" src="https://glama.ai/mcp/servers/4iqti5mgde/badge" alt="Semgrep Server MCP server" /> </a>Made with ❤️ by the Semgrep Team
サーバー設定
{
"mcpServers": {
"mcp": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"ghcr.io/metorial/mcp-container--semgrep--mcp--mcp",
"semgrep-mcp"
],
"env": {
"SEMGREP_APP_TOKEN": "semgrep-app-token"
}
}
}
}