BeyondTrust EPM MCP Server

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.

Category
Visit Server

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 API
  • mcp - Model Context Protocol SDK
  • pefile - PE file parser for file inspection

3. Get Your EPM API Credentials

From your BeyondTrust EPM console:

  1. Navigate to Configuration โ†’ API Registration
  2. Create a new API client
  3. 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

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 repo
  • YOUR-SUBDOMAIN โ†’ Your EPM subdomain
  • your-client-id-here โ†’ Your API client ID
  • your-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 policies
  • get_policy_details - Get detailed policy information
  • list_policy_application_groups - List applications in a policy
  • create_policy_application - Add applications to policies

File Inspection

  • inspect_file_for_policy - Extract file metadata safely

Computer Management

  • list_computers - List managed computers
  • get_computer_details - Get computer details
  • authorize_computers - Authorize computers
  • assign_computers_to_group - Assign computers to groups

Group Management

  • list_groups - List computer groups
  • create_group - Create new groups

User Management

  • list_users - List EPM users
  • create_user - Create new users

Monitoring & Auditing

  • get_activity_audits - Get audit logs
  • search_events - Search EPM events
  • list_authorization_requests - List authorization requests
  • get_authorization_request_details - Get request details

Admin Access Requests

  • list_admin_access_requests - List admin access requests
  • get_admin_access_request_details - Get request details
  • create_admin_access_request - Create new requests
  • approve_admin_access_request - Approve requests
  • deny_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 URL
  • BT_EPM_CLIENT_ID - API client ID
  • BT_EPM_CLIENT_SECRET - API client secret

Customization

Edit bt_epm_mcpv1.py to customize:

  • OUTPUT_DIR (line 17) - Change output directory
  • timeout=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:

  1. Verify the path is correct
  2. Ensure all three env vars are set
  3. No typos in variable names
  4. 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:

  1. Verify credentials in EPM console
  2. Check Base URL format (must include https://)
  3. 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:

  1. Check absolute path in config is correct
  2. Verify uv is in your PATH
  3. Check Claude Desktop logs:
    • Windows: %APPDATA%\Claude\logs\
    • macOS: ~/Library/Logs/Claude/
    • Linux: ~/.config/Claude/logs/

๐Ÿ“š Additional Resources


๐Ÿค Contributing

Contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch
  3. Test your changes
  4. Submit a pull request

๐Ÿ“ License

[Add your license here]


๐Ÿ’ก Tips & Best Practices

Policy Creation

  1. Inspect files first: Use inspect_file_for_policy to get accurate metadata
  2. Use publisher matching: More flexible than hash matching for updates
  3. Test with small groups: Verify policies before wide deployment

File Inspection

  1. Always use absolute paths: Avoid path resolution issues
  2. Review extracted properties: Not all files have all metadata
  3. Combine criteria: Use publisher + product name for best results

Security

  1. Protect API credentials: Never commit config files with real credentials
  2. Use least privilege: Create API clients with minimum required permissions
  3. Review audit logs: Monitor MCP server actions in EPM audit logs

๐Ÿ†˜ Support

For issues or questions:

  1. Check the Troubleshooting section
  2. Review the documentation files in this repo
  3. Check BeyondTrust EPM API documentation
  4. 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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

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.

Official
Featured