BeyondTrust EPM MCP Server
Enables management of BeyondTrust Endpoint Privilege Management (EPM) through natural language, supporting policy, computer, user, group management, file inspection, audit monitoring, and admin access requests.
README
BeyondTrust EPM MCP Server
A Model Context Protocol (MCP) server for managing BeyondTrust Endpoint Privilege Management (EPM) through Claude Desktop and other MCP clients.
Features
- ๐ Policy Management: Create, read, and manage EPM policies and applications
- ๐ Computer Management: List, authorize, and organize managed endpoints
- ๐ฅ User & Group Management: Manage EPM users, roles, and computer groups
- ๐ File Inspection: Safely extract file metadata for policy creation (Windows PE files)
- ๐ Audit & Monitoring: Access activity audits, events, and authorization requests
- โ Admin Access Requests: Create, approve, and deny admin access requests
๐ Quick Start
Prerequisites
- Python 3.14 or higher
- uv package manager
- Claude Desktop (or another MCP client)
- BeyondTrust EPM instance with API credentials
Installation
1. Clone the Repository
git clone https://github.com/wesharris222/btepmmcp.git
cd btepmmcp
2. Install Dependencies
uv sync
This installs:
httpx- HTTP client for EPM APImcp- Model Context Protocol SDKpefile- PE file parser for file inspection
3. Get Your EPM API Credentials
From your BeyondTrust EPM console:
- Navigate to Configuration โ API Registration
- Create a new API client
- Copy the following values:
- Base URL:
https://[your-subdomain]-services.pm.beyondtrustcloud.com - Client ID: Your API client ID (GUID)
- Client Secret: Your API client secret
- Base URL:
4. Configure Claude Desktop
Windows: Edit %APPDATA%\Claude\claude_desktop_config.json
macOS: Edit ~/Library/Application Support/Claude/claude_desktop_config.json
Linux: Edit ~/.config/Claude/claude_desktop_config.json
Add this configuration:
{
"mcpServers": {
"beyondtrust-epm": {
"command": "uv",
"args": [
"--directory",
"C:/path/to/btepmmcp",
"run",
"bt_epm_mcpv1.py"
],
"env": {
"BT_EPM_BASE_URL": "https://YOUR-SUBDOMAIN-services.pm.beyondtrustcloud.com",
"BT_EPM_CLIENT_ID": "your-client-id-here",
"BT_EPM_CLIENT_SECRET": "your-client-secret-here"
}
}
}
}
Important: Replace the following:
C:/path/to/btepmmcpโ Actual path where you cloned the repoYOUR-SUBDOMAINโ Your EPM subdomainyour-client-id-hereโ Your API client IDyour-client-secret-hereโ Your API client secret
5. Restart Claude Desktop
Close and reopen Claude Desktop to load the MCP server.
6. Verify Installation
In Claude Desktop, try:
List all EPM policies
If configured correctly, Claude will use the MCP server to retrieve your policies!
๐ Usage Examples
Policy Management
List all policies
Show me the details for policy ID 063caa3a-a1fe-4f41-a1d3-994ad5cb0d7a
List applications in policy 063caa3a-a1fe-4f41-a1d3-994ad5cb0d7a
File Inspection (Safe - No Execution)
Inspect the file at C:\Program Files\7-Zip\7zFM.exe
Returns file properties like:
- File name, size, hashes (SHA256, SHA1)
- Publisher, product name, version
- All metadata without executing the file
Create Policy Application
Create a policy application:
- Policy ID: 063caa3a-a1fe-4f41-a1d3-994ad5cb0d7a
- Application Group ID: 5c28a0a9-c133-4f19-9378-0b12f5fe7b77
- Type: exe
- Description: 7-Zip File Manager
- Publisher: Igor Pavlov
- Product Name: 7-Zip
Computer Management
List all computers
Show unauthorized computers
Authorize computer IDs [id1, id2] and assign to group [group-id]
User Management
List all EPM users
Create a user with email john.doe@company.com and role ID [role-id]
Admin Access Requests
Create an admin access request for computer [computer-id]
Approve admin access request [request-id] by user john.doe@company.com
๐ ๏ธ Available Tools
The MCP server provides these tools (used automatically by Claude):
Policy Management
list_policies- List all policiesget_policy_details- Get detailed policy informationlist_policy_application_groups- List applications in a policycreate_policy_application- Add applications to policies
File Inspection
inspect_file_for_policy- Extract file metadata safely
Computer Management
list_computers- List managed computersget_computer_details- Get computer detailsauthorize_computers- Authorize computersassign_computers_to_group- Assign computers to groups
Group Management
list_groups- List computer groupscreate_group- Create new groups
User Management
list_users- List EPM userscreate_user- Create new users
Monitoring & Auditing
get_activity_audits- Get audit logssearch_events- Search EPM eventslist_authorization_requests- List authorization requestsget_authorization_request_details- Get request details
Admin Access Requests
list_admin_access_requests- List admin access requestsget_admin_access_request_details- Get request detailscreate_admin_access_request- Create new requestsapprove_admin_access_request- Approve requestsdeny_admin_access_request- Deny requests
๐ Security & Safety
File Inspection Safety
The inspect_file_for_policy tool is 100% safe:
โ
Never executes files - Only reads metadata
โ
Read-only operations - No file modifications
โ
Static analysis only - Parses PE structures without running code
โ
Industry-standard library - Uses trusted pefile library
โ
Cross-platform - Works on Windows, Linux, macOS
See FILE_INSPECTION_README.md for details.
API Security
- Uses OAuth 2.0 client credentials flow
- Credentials stored in Claude Desktop config (local only)
- HTTPS communication with BeyondTrust EPM API
- Token auto-refresh with expiration handling
๐ File Structure
btepmmcp/
โโโ bt_epm_mcpv1.py # Main MCP server
โโโ pyproject.toml # Python dependencies
โโโ README.md # This file
โโโ FILE_INSPECTION_README.md # File inspection guide
โโโ IMPLEMENTATION_SUMMARY.md # Technical details
โโโ QUICK_START.md # Quick reference
โโโ test_file_inspection.py # Safety tests
โโโ mcp_output/ # Query results (auto-created)
๐งช Testing
Test File Inspection
uv run python test_file_inspection.py
This verifies:
- Files are not executed
- Metadata is extracted correctly
- Hashes are calculated
- PE parsing works
Manual Testing
# Test file inspection
uv run python -c "from bt_epm_mcpv1 import inspect_file_properties; import json; print(json.dumps(inspect_file_properties('C:\\Windows\\System32\\notepad.exe'), indent=2))"
๐ Cross-Platform Support
Windows
- Full functionality
- PE file metadata extraction
- Native path support
Linux
- Full API functionality
- Can inspect Windows PE files (.exe, .dll)
- Use Linux paths:
/usr/bin/app
macOS
- Full API functionality
- Can inspect Windows PE files
- Use macOS paths:
/Applications/App.app/Contents/MacOS/app
๐ Output Files
All query results are saved to mcp_output/:
latest.json- Last query result (always overwritten)<tool>_<timestamp>.json- Archived results for each query
Example:
mcp_output/
โโโ latest.json
โโโ list_policies_2025-11-13T10-30-45-123456.json
โโโ inspect_file_for_policy_2025-11-13T10-35-22-789012.json
โโโ create_policy_application_2025-11-13T10-40-15-345678.json
โ๏ธ Configuration Options
Environment Variables
Required (set in Claude Desktop config):
BT_EPM_BASE_URL- Your EPM instance URLBT_EPM_CLIENT_ID- API client IDBT_EPM_CLIENT_SECRET- API client secret
Customization
Edit bt_epm_mcpv1.py to customize:
OUTPUT_DIR(line 17) - Change output directorytimeout=30.0(line 146) - Adjust HTTP timeout- Tool descriptions and parameters
๐ Troubleshooting
"Missing required environment variables"
Problem: Server can't find API credentials
Solution: Check your claude_desktop_config.json:
- Verify the path is correct
- Ensure all three env vars are set
- No typos in variable names
- Restart Claude Desktop after changes
"Import pefile could not be resolved"
Problem: Dependencies not installed
Solution:
cd /path/to/btepmmcp
uv sync
"File not found" when inspecting files
Problem: Relative paths or incorrect path format
Solution: Use absolute paths:
- Windows:
C:\\Program Files\\App\\app.exe(double backslashes) - Linux/Mac:
/usr/bin/app
"HTTP Error 401 Unauthorized"
Problem: Invalid API credentials
Solution:
- Verify credentials in EPM console
- Check Base URL format (must include
https://) - Ensure client has proper permissions
"HTTP Error 405 Method Not Allowed"
Problem: Incorrect API endpoint (fixed in v1)
Solution: Update to latest version:
git pull origin main
MCP Server Not Loading
Problem: Claude Desktop can't find the server
Solution:
- Check absolute path in config is correct
- Verify
uvis in your PATH - Check Claude Desktop logs:
- Windows:
%APPDATA%\Claude\logs\ - macOS:
~/Library/Logs/Claude/ - Linux:
~/.config/Claude/logs/
- Windows:
๐ Additional Resources
๐ค Contributing
Contributions are welcome! Please:
- Fork the repository
- Create a feature branch
- Test your changes
- Submit a pull request
๐ License
[Add your license here]
๐ก Tips & Best Practices
Policy Creation
- Inspect files first: Use
inspect_file_for_policyto get accurate metadata - Use publisher matching: More flexible than hash matching for updates
- Test with small groups: Verify policies before wide deployment
File Inspection
- Always use absolute paths: Avoid path resolution issues
- Review extracted properties: Not all files have all metadata
- Combine criteria: Use publisher + product name for best results
Security
- Protect API credentials: Never commit config files with real credentials
- Use least privilege: Create API clients with minimum required permissions
- Review audit logs: Monitor MCP server actions in EPM audit logs
๐ Support
For issues or questions:
- Check the Troubleshooting section
- Review the documentation files in this repo
- Check BeyondTrust EPM API documentation
- Open an issue on GitHub
โจ What's New
v1.0 (Current)
- โ
Fixed 405 error in
create_policy_application - โ Added cross-platform file inspection
- โ PE metadata extraction (publisher, version, hashes)
- โ Comprehensive documentation
- โ Safety testing suite
๐ฏ Roadmap
Future enhancements:
- [ ] Batch file inspection
- [ ] Directory scanning
- [ ] Certificate validation
- [ ] Policy templates
- [ ] Version comparison tools
- [ ] Web UI for configuration
Ready to automate your EPM management? Get started now! ๐
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.