InfraMCP/foreman-mcp-server
3.2
If you are the rightful owner of foreman-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.
Foreman MCP Server is a tool designed for managing Foreman hosts and automating infrastructure tasks.
Tools
5
Resources
0
Prompts
0
Foreman MCP Server
MCP server for Foreman host management and infrastructure automation.
Features
- List and search hosts from Foreman
- Get detailed host information
- Search by location, OS, and environment
- Generic configuration via environment variables
Installation
From PyPI (Recommended)
pip install foreman-mcp-server
From Source
git clone https://github.com/rorymcmahon/foreman-mcp-server.git
cd foreman-mcp-server
pip install -e .
## Configuration
Set the following environment variables:
- `FOREMAN_URL`: Base URL of your Foreman instance (e.g., `https://foreman.example.com`)
- `FOREMAN_USERNAME`: Foreman username
- `FOREMAN_PASSWORD`: **Personal Access Token** (not your web login password - create this in User Administration → Personal Access Tokens)
- `FOREMAN_VERIFY_SSL`: Whether to verify SSL certificates (default: `true`)
### Required Permissions
The user account needs the following minimum permissions to use all MCP server tools:
| Resource Type | Permission | Purpose |
|---------------|------------|---------|
| Host | `view_hosts` | List and search hosts, get host details and status |
| Organization | `view_organizations` | List organizations |
| Location | `view_locations` | List locations |
| Hostgroup | `view_hostgroups` | List and search by hostgroups |
| Subnet | `view_subnets` | List subnets and get subnet details |
| Domain | `view_domains` | List domains and get domain details |
| SmartProxy | `view_smart_proxies` | List smart proxies and get proxy details |
### Recommended Roles
Instead of assigning individual permissions, you can use these built-in roles:
| Role | Description | Recommended For |
|------|-------------|-----------------|
| **Viewer** | Read-only access to most Foreman resources | General monitoring and inventory queries |
| **Ansible Tower Inventory Reader** | Specific permissions for inventory access | Automated systems integration |
| **Organization admin** | Full access within assigned organizations | Organization-specific administration |
**Note**: The "Viewer" role provides the most appropriate permissions for this MCP server's read-only operations.
## MCP Configuration
Add to your MCP client configuration:
```json
{
"foreman-mcp-server": {
"command": "foreman-mcp-server",
"env": {
"FOREMAN_URL": "https://foreman.example.com",
"FOREMAN_USERNAME": "your-username",
"FOREMAN_PASSWORD": "your-password",
"FOREMAN_VERIFY_SSL": "true"
}
}
}
Available Tools
Host Management
list_hosts(search, per_page, page)
- List hosts with optional searchget_host(host_id)
- Get detailed host informationget_host_status(host_id)
- Get status information for a specific host
Host Search Functions
search_hosts_by_location(location, per_page)
- Search by locationsearch_hosts_by_os(os_name, per_page)
- Search by operating systemsearch_hosts_by_environment(environment, per_page)
- Search by environmentsearch_hosts_by_hostgroup(hostgroup, per_page)
- Search by hostgroupsearch_hosts_by_fact(fact_name, fact_value, per_page)
- Search by custom facts
Infrastructure Information
list_organizations(per_page)
- List all organizationslist_locations(per_page)
- List all locationslist_hostgroups(per_page)
- List all hostgroupslist_subnets(per_page)
- List all subnetsget_subnet(subnet_id)
- Get detailed subnet informationlist_domains(per_page)
- List all domainsget_domain(domain_id)
- Get detailed domain informationlist_smart_proxies(per_page)
- List all smart proxiesget_smart_proxy(proxy_id)
- Get detailed smart proxy information
OS Management
list_operatingsystems(per_page)
- List all operating systemsget_operatingsystem(os_id)
- Get detailed operating system informationlist_architectures(per_page)
- List all architecturesget_architecture(arch_id)
- Get detailed architecture informationlist_media(per_page)
- List all installation mediaget_media(media_id)
- Get detailed installation media information
Content Management
list_content_views(per_page)
- List all content viewsget_content_view(cv_id)
- Get detailed content view informationlist_repositories(per_page)
- List all repositoriesget_repository(repo_id)
- Get detailed repository informationlist_lifecycle_environments(per_page)
- List all lifecycle environmentsget_lifecycle_environment(env_id)
- Get detailed lifecycle environment information
Development
pip install -e ".[dev]"
pytest