mirage-security/knowbe4-mcp-server
If you are the rightful owner of knowbe4-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
A Model Context Protocol (MCP) server for the KnowBe4 Reporting REST API, enabling AI assistants to interact with KnowBe4 security awareness training platform data.
KnowBe4 MCP Server
A Model Context Protocol (MCP) server for the KnowBe4 Reporting REST API. This server enables AI assistants to interact with your KnowBe4 security awareness training platform data.
Created by Mirage Security
Features
This MCP server provides access to all KnowBe4 Reporting API endpoints:
Account
- Get account and subscription data
- Get account risk score history
Users
- List all users (with filtering by status, group)
- Get specific user details
- Get users in a specific group
- Get user risk score history
Groups
- List all groups
- Get specific group details
- Get group risk score history
Phishing
- Get phishing campaigns
- Get phishing security tests (PSTs)
- Get PST recipient results
- Get specific recipient details
Training
- Get store purchases
- Get policies
- Get training campaigns
- Get training enrollments
Prerequisites
- Node.js 18 or higher
- A KnowBe4 account with Platinum or Diamond subscription
- KnowBe4 API key (available in your Account Settings)
Installation
- Clone or download this repository
- Install dependencies:
npm install
- Build the TypeScript code:
npm run build
Configuration
Getting Your API Key
- Log in to your KnowBe4 console
- Navigate to Account Settings
- Find the API section
- Copy your API key or generate a new one if needed
Important: Keep your API key secure and do not share it publicly.
Environment Variables
The server requires the following environment variables:
KNOWBE4_API_KEY
(required): Your KnowBe4 API keyKNOWBE4_REGION
(optional): Your server region -us
,eu
,ca
,uk
, orde
(default:us
)
Determine your region based on your KnowBe4 login URL:
- US:
training.knowbe4.com
→ useus
- EU:
eu.knowbe4.com
→ useeu
- CA:
ca.knowbe4.com
→ useca
- UK:
uk.knowbe4.com
→ useuk
- DE:
de.knowbe4.com
→ usede
Usage with Claude Desktop
Add this server to your Claude Desktop configuration file:
macOS
Edit: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows
Edit: %APPDATA%\Claude\claude_desktop_config.json
Add the following configuration:
{
"mcpServers": {
"knowbe4": {
"command": "node",
"args": ["/absolute/path/to/knowbe4-mcp-server/build/src/index.js"],
"env": {
"KNOWBE4_API_KEY": "your-api-key-here",
"KNOWBE4_REGION": "us"
}
}
}
}
Replace:
/absolute/path/to/knowbe4-mcp-server
with the actual path to this projectyour-api-key-here
with your actual KnowBe4 API keyus
with your region if different
Available Tools
Once configured, Claude will have access to these tools:
Account Tools
get_account
- Get account and subscription informationget_account_risk_score_history
- Get historical risk scores
User Tools
get_users
- List all users with optional filtersget_user
- Get specific user by IDget_group_members
- Get users in a groupget_user_risk_score_history
- Get user risk score history
Group Tools
get_groups
- List all groupsget_group
- Get specific groupget_group_risk_score_history
- Get group risk score history
Phishing Tools
get_phishing_campaigns
- List all phishing campaignsget_phishing_campaign
- Get phishing campaign detailsget_phishing_security_tests
- List all PSTsget_campaign_security_tests
- Get PSTs from specific campaignget_phishing_security_test
- Get specific PSTget_pst_recipients
- Get recipient results for PSTget_pst_recipient
- Get specific recipient result
Training Tools
get_store_purchases
- List store purchasesget_store_purchase
- Get specific store purchaseget_policies
- List policiesget_policy
- Get specific policyget_training_campaigns
- List training campaignsget_training_campaign
- Get specific training campaignget_training_enrollments
- List training enrollmentsget_training_enrollment
- Get specific enrollment
Example Prompts
Once configured, you can ask Claude things like:
- "What is my organization's current risk score?"
- "Show me all active users in my account"
- "Get the results from phishing security test ID 12345"
- "List all training campaigns"
- "Show me users with the highest phish-prone percentage"
- "Get all groups and their current risk scores"
API Rate Limits
KnowBe4 API has the following limits:
- 2,000 requests per day plus the number of licensed users
- Maximum 4 requests per second
- Burst limit of 50 requests per minute
Pagination
Most list endpoints support pagination with these parameters:
page
- Page number (default: 1)per_page
- Results per page (default: 100, max: 500)
The server automatically handles these parameters for you.
Development
Watch Mode
Run TypeScript compiler in watch mode:
npm run watch
Testing
The project includes comprehensive integration tests using Node.js built-in test runner.
Run all tests:
KNOWBE4_API_KEY=your-key npm test
Run tests in watch mode:
KNOWBE4_API_KEY=your-key npm run test:watch
Test Coverage:
- 30 integration tests across 5 endpoint categories
- Account endpoints (3 tests)
- User endpoints (5 tests)
- Group endpoints (5 tests)
- Phishing endpoints (8 tests)
- Training endpoints (9 tests)
Tests make real API calls and validate response structure and data. See for detailed testing documentation.
Security Notes
- Never commit your API key to version control
- Store your API key securely
- Use environment variables for configuration
- KnowBe4 API keys provide access to sensitive security training data
- Anonymous accounts cannot retrieve anonymized data
Troubleshooting
"KNOWBE4_API_KEY environment variable is required"
Make sure you've set the KNOWBE4_API_KEY
in your Claude Desktop config.
"401 Unauthorized"
Your API key is incorrect or expired. Generate a new one in KnowBe4 Account Settings.
"404 Not Found"
Check that you're using the correct region for your account.
"429 Too Many Requests"
You've exceeded the rate limit. Wait before making more requests.
About
This MCP server was created by Mirage Security to enable seamless integration between AI assistants and the KnowBe4 security awareness training platform.
License
MIT