MCP server for FreeIPA identity management
Project description
FreeIPA MCP Server
MCP server for FreeIPA identity management instances. Tools are dynamically registered from FreeIPA's schema API, exposing ~290 commands covering users, groups, hosts, DNS, HBAC, sudo rules, certificates, services, trusts, vaults, and more.
The server uses CodeMode for efficient LLM interaction, collapsing ~290 individual tools into 3 meta-tools (get_tags, search, get_schemas) that let AI assistants discover and call commands on demand rather than loading all tools into context at once.
Both MCP (stdio) and REST API (Swagger UI) interfaces are available, sharing the same underlying FreeIPA client.
Configuration
Authentication: FreeIPA supports two authentication methods:
- Password — username/password with session cookies (simpler, good for development)
- Kerberos — keytab-based authentication (recommended for production, no passwords stored)
Option 1: config.json (Password Auth)
cp config.json.example config.json
# Edit config.json with your credentials
{
"host": "ipa.example.com",
"auth_method": "password",
"username": "api-user",
"password": "changeme",
"verify_ssl": true,
"ca_cert_path": "/etc/ipa/ca.crt"
}
Option 1b: config.json (Kerberos Auth)
{
"host": "ipa.example.com",
"auth_method": "kerberos",
"principal": "mcp-api",
"keytab_path": "/root/mcp-api.keytab",
"verify_ssl": true,
"ca_cert_path": "/etc/ipa/ipa-ca.cert"
}
The server runs kinit -kt <keytab_path> <principal> automatically. No password needed.
Option 2: Environment Variables
# Password auth
export FREEIPA_HOST="ipa.example.com"
export FREEIPA_AUTH_METHOD="password"
export FREEIPA_USERNAME="api-user"
export FREEIPA_PASSWORD="api-password"
export FREEIPA_VERIFY_SSL="true"
export FREEIPA_CA_CERT_PATH="/etc/ipa/ca.crt"
# Or Kerberos auth
export FREEIPA_HOST="ipa.example.com"
export FREEIPA_AUTH_METHOD="kerberos"
export FREEIPA_PRINCIPAL="mcp-api"
export FREEIPA_KEYTAB_PATH="/root/mcp-api.keytab"
export FREEIPA_VERIFY_SSL="true"
export FREEIPA_CA_CERT_PATH="/etc/ipa/ipa-ca.cert"
CA Certificate Setup
FreeIPA servers typically use a self-signed CA. To connect with SSL verification enabled:
-
Copy the IPA CA certificate from the FreeIPA server:
scp root@ipa.example.com:/etc/ipa/ca.crt /usr/local/share/ca-certificates/ipa-ca.crt
-
Set
ca_cert_pathin config.json orFREEIPA_CA_CERT_PATHto the local path.
Alternatively, set verify_ssl to false for development environments (not recommended for production).
Installation
Option 1: Using uv (Recommended)
uv is a fast Python package manager. Install it first:
# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
# Windows
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
No additional installation needed - uvx will handle dependencies automatically.
Option 2: Using pip
pip install bibliocommons-mcp-freeipa
# or for development
pip install -e ".[dev]"
AI Client Setup
VS Code (with MCP Extension)
- Install an MCP-compatible extension in VS Code
- Open VS Code Settings (JSON):
Cmd+Shift+P→ "Preferences: Open User Settings (JSON)" - Add the server configuration:
{
"mcp.servers": {
"freeipa": {
"command": "uvx",
"args": ["--from", "/absolute/path/to/freeipa", "bibliocommons-mcp-freeipa"]
}
}
}
Alternative: Using python directly
{
"mcp.servers": {
"freeipa": {
"command": "python",
"args": ["-m", "bibliocommons_mcp_freeipa"]
}
}
}
Claude Desktop
-
Open Claude Desktop configuration:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
- macOS:
-
Add the server configuration:
{
"mcpServers": {
"freeipa": {
"command": "uvx",
"args": ["--from", "/absolute/path/to/freeipa", "bibliocommons-mcp-freeipa"]
}
}
}
Alternative: Using python directly
{
"mcpServers": {
"freeipa": {
"command": "python",
"args": ["-m", "bibliocommons_mcp_freeipa"]
}
}
}
Kiro IDE
- Open Kiro IDE settings
- Navigate to MCP Servers configuration
- Add the server:
{
"mcpServers": {
"freeipa": {
"command": "uvx",
"args": ["--from", "/absolute/path/to/freeipa", "bibliocommons-mcp-freeipa"]
}
}
}
Alternative: Using python directly
{
"mcpServers": {
"freeipa": {
"command": "python",
"args": ["-m", "bibliocommons_mcp_freeipa"]
}
}
}
Kiro CLI
-
Create or edit the MCP configuration file:
- User level:
~/.kiro/settings/mcp.json - Project level:
<project-root>/.kiro/settings/mcp.json
- User level:
-
Add the server configuration:
{
"mcpServers": {
"freeipa": {
"command": "uvx",
"args": ["--from", "/absolute/path/to/freeipa", "bibliocommons-mcp-freeipa"]
}
}
}
Alternative: Using python directly
{
"mcpServers": {
"freeipa": {
"command": "python",
"args": ["-m", "bibliocommons_mcp_freeipa"]
}
}
}
Configuration Notes
- Replace
/absolute/path/to/freeipa/with the actual path to your server directory - Using
uvx(default): Automatically manages dependencies in isolated environments (likenpxfor Node.js) - Using
python(alternative): Requirespip install bibliocommons-mcp-freeipafirst - After adding the configuration, restart your AI client for changes to take effect
For other AI clients (Amazon Q, GitHub Copilot, Cline, Zed, Cursor), see docs/ai-clients.md.
Docker
# Pull from Docker Hub (private)
docker pull bibliocommons/mcp-freeipa:latest
# Run in stdio mode
docker run -i --rm \
-v /path/to/config.json:/config.json:ro \
bibliocommons/mcp-freeipa:latest \
--config /config.json
# Run in HTTP mode
docker run -d --rm \
-v /path/to/config.json:/config.json:ro \
-p 8000:8000 \
bibliocommons/mcp-freeipa:latest \
--config /config.json --transport http --port 8000
# Run in expanded mode
docker run -i --rm \
-v /path/to/config.json:/config.json:ro \
bibliocommons/mcp-freeipa:latest \
--config /config.json --expanded
Web UI with Swagger
A REST API with interactive Swagger documentation is available:
python -m bibliocommons_mcp_freeipa.webui
Access the Swagger UI at: http://localhost:8000/docs
The Web UI provides:
- Interactive API documentation
- Try-it-out functionality for all endpoints
- OpenAPI/Swagger specification
- REST API access to all FreeIPA commands
Standalone MCP Server
python -m bibliocommons_mcp_freeipa
CLI Flags
| Flag | Env Var | Description |
|---|---|---|
--config PATH |
FREEIPA_CONFIG |
Path to config.json |
--read-only |
FREEIPA_READ_ONLY |
Exclude destructive tools |
--expanded |
FREEIPA_EXPANDED |
Register all tools individually instead of gateway mode |
--transport stdio|http |
FREEIPA_TRANSPORT |
Transport mode (default: stdio) |
--port PORT |
FREEIPA_PORT |
HTTP port (default: 8000) |
--version |
— | Show version and exit |
Gateway Mode (Default)
By default, the server exposes 2 tools instead of ~290 individual tools:
| Tool | Purpose |
|---|---|
freeipa_api |
Execute any FreeIPA action by name with a params dict |
freeipa_help |
Search available actions, parameters, and descriptions |
The AI assistant calls freeipa_help to discover available actions, then calls freeipa_api(action="user_find", params={"uid": "jdoe"}) to execute them.
To register all individual tools, use --expanded:
python -m bibliocommons_mcp_freeipa --expanded
Tool Domains
Tools are dynamically registered from the FreeIPA schema. The exact count depends on your FreeIPA version and installed plugins. Typical domains include:
| Domain | Prefix | Approx. Commands | Examples |
|---|---|---|---|
| Users | user_ |
~19 | user_add, user_find, user_mod, user_show |
| Groups | group_ |
~9 | group_add, group_find, group_add_member |
| Hosts | host_ |
~22 | host_add, host_find, host_show |
| DNS | dns |
~28 | dnszone_add, dnsrecord_add, dnsrecord_find |
| HBAC | hbac |
~20 | hbacrule_add, hbacrule_add_user, hbactest |
| Sudo | sudo |
~25 | sudorule_add, sudorule_add_user, sudocmd_add |
| Certificates | cert_ |
~17 | cert_request, cert_show, cert_revoke |
| Services | service_ |
~22 | service_add, service_find, service_show |
| Trusts | trust_ |
~16 | trust_add, trust_find, trust_show |
| Vaults | vault_ |
~16 | vault_add, vault_archive, vault_retrieve |
| Password Policy | pwpolicy_ |
~5 | pwpolicy_add, pwpolicy_mod, pwpolicy_show |
| Kerberos | krbtpolicy_ |
~3 | krbtpolicy_mod, krbtpolicy_show |
| SELinux | selinux |
~5 | selinuxusermap_add, selinuxusermap_find |
| Automount | automount |
~15 | automountlocation_add, automountmap_add |
| Other | various | ~70+ | config_mod, ping, whoami, batch |
Schema Caching
On startup, the server fetches the full command schema from FreeIPA's schema API endpoint. This schema defines all available commands, their parameters, types, and documentation.
The schema is cached locally in schema_cache.json. If the live fetch fails (e.g., FreeIPA is temporarily unreachable), the server falls back to the cached version.
To refresh the cache after a FreeIPA upgrade or plugin change:
rm schema_cache.json
# Restart the server - it will fetch and cache the new schema
Security Notes
- Dedicated API user: Create a FreeIPA user specifically for API access with only the permissions needed. Avoid using
adminin production. - CA certificate: Configure
ca_cert_pathto point to your IPA CA certificate rather than disabling SSL verification. - Session handling: The client authenticates via password and maintains a session cookie. If the session expires (401), it re-authenticates automatically.
- Never commit config.json: The
.gitignoreexcludesconfig.json. Useconfig.json.exampleas a template and keep credentials out of version control.
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 bibliocommons_mcp_freeipa-1.2.0.tar.gz.
File metadata
- Download URL: bibliocommons_mcp_freeipa-1.2.0.tar.gz
- Upload date:
- Size: 23.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3059bc8c36de02879e0dbd85e886092471c3704687e2e798373f75f04e39bc50
|
|
| MD5 |
5b31259a6662f5ed1f4dfe36c6a2f99b
|
|
| BLAKE2b-256 |
251b072914fdb6ea673f06857767b1f2743f66db3deedaa06341d709c98b31a1
|
File details
Details for the file bibliocommons_mcp_freeipa-1.2.0-py3-none-any.whl.
File metadata
- Download URL: bibliocommons_mcp_freeipa-1.2.0-py3-none-any.whl
- Upload date:
- Size: 13.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
47229d00d1d49f4927bf523ce8a368240644144fe65870d790a777fcde5e85ca
|
|
| MD5 |
0302ee516d939691037b60b902d6287e
|
|
| BLAKE2b-256 |
b40da126d56265caaa2755dd17fdee6f4b6ddacfc6c9bd3dc62636df73aad5d5
|