PlainSignal MCP Server
This is a Model Context Protocol (MCP) server implementation for PlainSignal analytics data. It provides tools for retrieving analytics reports and metrics through the MCP protocol.
Setup
Installation
From npm (recommended)
From source
Clone this repository
Install dependencies:
This project uses ES modules instead of CommonJS. Make sure you're using a Node.js version that supports ES modules (Node.js 14+).
Related MCP server: AppSignal MCP Server
Usage
When installed from npm
When using from source
Run the server with your access token:
You can also specify a custom API base URL:
Or use the short format:
Alternatively, set the access token and API base URL as environment variables and use the test script:
By default, the server connects to https://app.plainsignal.com/api/v1.
MCP Server configs
Claude Desktop
Add this snippet to your claude_desktop_config.json:
Available Tools
The server provides the following tools:
getReport
Retrieves an analytics report for a specified domain and time period.
Parameters:
organizationID: Organization IDdomainID: Domain IDperiodFrom: Report start datetime in RFC3339 formatperiodTo: Report end datetime in RFC3339 formatperiodSelection: Period type (m: month, y: year, d: day)aggregationWindow: Data aggregation window (h: hour, d: day)filters: (Optional) List of filters as key-value pairs
getSubReport
Retrieves detailed metrics for a specific aspect of analytics data.
Parameters:
organizationID: Organization IDdomainID: Domain IDperiodFrom: Report start datetime in RFC3339 formatperiodTo: Report end datetime in RFC3339 formatperiodSelection: Period type (m: month, y: year, d: day)aggregationWindow: Data aggregation window (h: hour, d: day)subReportType: Type of report (1: page, 2: entry page, etc.)filters: (Optional) List of filters as key-values pairspagination: (Optional) Pagination controls with limit and offset
API Reference
This server communicates with the PlainSignal API. By default, it connects to https://app.plainsignal.com/api/v1, but you can configure the API endpoint in several ways:
Use the
--api-base-urlcommand line option:node src/index.js --token <your_token> --api-base-url https://app.plainsignal.com/api/v1Set the
API_BASE_URLenvironment variable:export API_BASE_URL=https://app.plainsignal.com/api/v1Pass a custom API base URL to the constructor when instantiating the server programmatically:
const server = new PlainSignalStdioServer(token, 'https://app.plainsignal.com/api/v1');
For Developers
The server is implemented using the MCP SDK and communicates over STDIO.
Examples
An example client is provided to demonstrate how to use the MCP server:
Or run the resources example client:
The example client demonstrates:
Connecting to the MCP server
Listing available tools
Calling the
getReporttool with sample parametersProcessing and displaying the results
The resources example client demonstrates:
Connecting to the MCP server
Listing available resources
Reading the
listDomainsresourceProcessing and displaying the results
License
This project is licensed under the MIT License - see the LICENSE file for details.