MCP server for Foreman host management and infrastructure automation
Project description
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
Support
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file foreman_mcp_server-0.4.0.tar.gz.
File metadata
- Download URL: foreman_mcp_server-0.4.0.tar.gz
- Upload date:
- Size: 9.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a4de5497fa8ef8dd9019c1cb73e6c6ab57eb713ca2c77775453533c6f8f4fd77
|
|
| MD5 |
7ed626b93b6aa71ef21a28d6c02f37e2
|
|
| BLAKE2b-256 |
447692dc089656a7857f2ce87684b6f94e2f328194ee5544f3111efa73b88ef4
|
Provenance
The following attestation bundles were made for foreman_mcp_server-0.4.0.tar.gz:
Publisher:
publish.yml on InfraMCP/foreman-mcp-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
foreman_mcp_server-0.4.0.tar.gz -
Subject digest:
a4de5497fa8ef8dd9019c1cb73e6c6ab57eb713ca2c77775453533c6f8f4fd77 - Sigstore transparency entry: 582063340
- Sigstore integration time:
-
Permalink:
InfraMCP/foreman-mcp-server@ea0908dd9413501395b913e686bdeca463c027d7 -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/InfraMCP
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ea0908dd9413501395b913e686bdeca463c027d7 -
Trigger Event:
release
-
Statement type:
File details
Details for the file foreman_mcp_server-0.4.0-py3-none-any.whl.
File metadata
- Download URL: foreman_mcp_server-0.4.0-py3-none-any.whl
- Upload date:
- Size: 7.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eda360148539700daac0ba9963f5def80f5b691df2ca641779a99f12055f7a71
|
|
| MD5 |
d117c4637411c12e58b31a7a3450b76d
|
|
| BLAKE2b-256 |
14d0e344a22325807524a58d3acae9b6974702d17ef83702d1838ff35d982040
|
Provenance
The following attestation bundles were made for foreman_mcp_server-0.4.0-py3-none-any.whl:
Publisher:
publish.yml on InfraMCP/foreman-mcp-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
foreman_mcp_server-0.4.0-py3-none-any.whl -
Subject digest:
eda360148539700daac0ba9963f5def80f5b691df2ca641779a99f12055f7a71 - Sigstore transparency entry: 582063350
- Sigstore integration time:
-
Permalink:
InfraMCP/foreman-mcp-server@ea0908dd9413501395b913e686bdeca463c027d7 -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/InfraMCP
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ea0908dd9413501395b913e686bdeca463c027d7 -
Trigger Event:
release
-
Statement type: