Metadata-Version: 2.4
Name: glpic
Version: 99.0.202510021331
Summary: GLPI client
Author-email: Karim Boumedhel <karimboumedhel@gmail.com>
License: ASL
Project-URL: Homepage, http://github.com/karmab/glpic
Description-Content-Type: text/markdown
Requires-Dist: fastmcp
Requires-Dist: prettytable

This repo contains code for a MCP interacting with GLPI API to allow consuming it from any LLM.
Additionally a lightweight client is available

| Available tools   |
|-------------------|
|create_reservation |
|delete_reservation |
|info_computer      |
|info_reservation   |
|get_user           |
|list_computers     |
|list_reservations  |
|list_users         |
|update_computer    |
|update_reservation |

# Requirements

- Available glpi instance
- Valid user and API token

# Installation

You can either run as a container or install dependencies locally

```
pip3 install glpic
```

# Using MCP

## STDIO

Include the following configuration snippet In VSCode or Claude Desktop:

```json
"mcpServers": {
    "glpi": {
        "command": "python3",
        "args": ["/path/to/glpic/src/glpic/mcp_server.py", "--stdio"],
        "env": {
            "GLPI_URL": "https://server/apirest.php",
            "GLPI_USER": "myuser",
            "GLPI_TOKEN": "mytoken"
            }
        }
    }
```

## Streamable HTTP

For Streamable HTTP, first start the server in a terminal:

```
glpimcp
```

or via a container (with additional env variables to avoid defining headers on client side)

```
podman run -p 8000:8000 -d --name glpi --entrypoint=/usr/local/bin/glpimcp quay.io/karmab/glpic
```

You can also set env variables prior to launching or in the container to avoid defining headers on client side). For instance

```
podman run -p 8000:8000 -d --name glpi -e GLPI_URL=https://glpiserver/apirest.php -e GLPI_USER=myser -e GLPI_TOKEN=mytoken --entrypoint=/usr/local/bin/glpimcp quay.io/karmab/glpic
```

You can then point to the server from your client with a modified snippet and specifying credentials via headers if needed

```json
"mcpServers": {
         "glpi": {
             "command": "/usr/local/bin/npx",
             "args": ["mcp-remote", "http://your_server:8000/mcp", "--allow-http",
             "--header", "GLPI_URL: https://glpiserver/apirest.php",
             "--header", "GLPI_USER: myuser",
             "--header", "GLPI_TOKEN: mytoken"]
        }
    }
```

For Claude Code, you can add the mcp directly from command line:

```
claude mcp add --transport http glpi http://glpiserver:8000/mcp -H "GLPI_URL: https://myserver/apirest.php" -H "GLPI_USER: myuser" -H "GLPI_TOKEN: mytoken"
```

# Using client

Store your creds in any env file such as [glpic.env.sample](glpic.env.sample) and set data accordingly. You can then use `glpic` and access similar functions
