ThinkPLC-MCP
Interface with SIEMENS PLC S7-1500/1200 using their JSON-RPC 2.0 API, exposing PLC functionalities as MCP tools for programmatic interaction.
ThinkPLC-MCP
ThinkPLC-MCP is a server designed to interface with SIEMENS PLC S7-1500/1200 using their JSON-RPC 2.0 API. It exposes API functionalities as MCP tools, enabling AI assistants and other MCP-compatible clients to interact with the PLC programmatically.
π§ Features
- Connects to a SIEMENS PLC API (Webserver) endpoint
- Provides MCP tools for:
- β
User authentication (
login,logout,ChangePassword-user) - β
Check PLC connectivity (
ping) - β
Retrieve user permissions via
Api-GetPermissionsafter login - β
Get API version with
Api-Version - β
List available API methods using
Api-Browse - β
Retrieve structure information with
Api-GetQuantityStructures - β
Get password security policies with
Api-GetPasswordPolicy - β
Browse tags and metadata using
PlcProgram-Browse - β
Read single variables via
PlcProgram-Read - β
Write Boolean, Number, or String tags with
PlcProgram-Write-* - β
Read the current CPU operating mode with
Plc-ReadOperatingMode - β
Request a change of operating mode using
Plc-RequestChangeOperatingMode - β
Read the CPU system time (
Plc-ReadSystemTime) - β
Set the CPU system time (
Plc-SetSystemTime) - β
Read available project languages (
Project-ReadLanguages) - β
Browse active alarms (
Alarms-Browse) - β
Acknowledge alarms (
Alarms-Acknowledge) - β
Browse diagnostic buffer entries (
DiagnosticBuffer-Browse)
- β
User authentication (
- π Optional: automatic service account login with token refresh
βοΈ Prerequisites
- Node.js (v18.x or later recommended)
- npm (comes bundled with Node.js)
- Access to a running SIEMENS PLC API (Webserver)
βοΈ Configuration
This server uses a config.js file written in ES Module syntax.
Example config.js:
export const config = {
URL: "https://<PLC-IP-Address>/api/jsonrpc", // required
userName: "your-username", // optional
pwr: "your-password", // optional
};
π Getting Started
- Navigate to the project folder:
cd your-project-directory
- Install dependencies:
npm install
-
Edit config.js as shown above.
-
Start the server
node start
π₯οΈ Connecting with Claude Desktop
To use this MCP server with Claude AI (desktop version):
-
Find or create the claude_desktop_config.json file (typically in the Claude app config folder).
-
Add or update the following:
{
"mcpServers": {
"ThinkPLC-MCP": {
"command": "npx",
"args": ["mcp-remote", "http://localhost:5000/mcp"]
}
}
}
- Ensure @modelcontextprotocol/tools is installed:
npm install -g @modelcontextprotocol/tools
Related Servers
OpenRoute MCP
πΊοΈ MCP server to help plan routes using OpenRouteService.org, for activities such as hiking or mountain biking.
Payman API
Integrates with Payman AI's payment APIs to manage payees, payments, and balances using natural language.
Overseerr
Interact with the Overseerr API to manage movie and TV show requests.
Chess UCI
Connect to UCI-compatible chess engines like Stockfish to play and analyze games. Requires a local chess engine binary.
Weather
Provides real-time weather information for any location.
SignalK MCP Server
Provides AI agents with read-only access to SignalK marine data systems, enabling queries of vessel navigation data, AIS targets, and system alarms.
Polymarket
An MCP tool for interacting with the Polymarket prediction market platform.
MCP Cookie Server
Provides positive reinforcement to LLMs by awarding 'cookies' as treats.
MCP.science
A collection of open-source MCP servers designed for scientific research applications.
MB's Personal MCP Server
A personal server for MB Crosier providing biography, contact information, and social links.