Skip to main content

Read-only MCP server for Aruba Fatturazione Elettronica API

Project description

Aruba Fatturazione Elettronica MCP Read-only

PyPI version Python versions License CI Container Ruff mypy Coverage GitHub release Downloads

Documentation: https://mnbro.github.io/aruba-fatturazione-elettronica-mcp/

This MCP server exposes read-only Aruba Fatturazione Elettronica API operations. It does not send invoices, upload files, accept or reject invoices, update resources, delete resources, or expose business POST/PUT/PATCH/DELETE operations.

Authentication uses POST /auth/signin because Aruba requires it for signin and refresh token lifecycle. Those POST requests are internal auth operations only.

The server also includes LLM-friendly read-only tools for invoice context, FatturaPA XML parsing, SDI notification explanations, VAT summaries, duplicate/anomaly checks, safe redaction and an optional local SQLite invoice index. The index writes only to the configured local database path and never modifies Aruba.

Badges for PyPI, release, downloads and Codecov become active after the first publication/release and Codecov setup.

License

This project is licensed under the PolyForm Internal Use License 1.0.0.

You may use and modify it for your own internal business operations, including commercial internal use. You may not redistribute it, resell it, sublicense it, or offer it as a productized service to third parties.

Install

uv sync
cp .env.example .env

Set ARUBA_ENV=demo first unless you have a specific reason to start in production.

Run

uv run aruba-fatturazione-elettronica-mcp

python -m aruba_fatturazione_elettronica_mcp is also supported.

Docker

The Debian slim based container image is published to GitHub Container Registry:

docker run --rm -i \
  --env ARUBA_ENV=demo \
  --env ARUBA_USERNAME \
  --env ARUBA_PASSWORD \
  ghcr.io/mnbro/aruba-fatturazione-elettronica-mcp:latest

See the Docker documentation for MCP client configuration and local index volume setup.

MCP client config

{
  "mcpServers": {
    "aruba-fatturazione-elettronica-readonly": {
      "command": "uvx",
      "args": ["aruba-fatturazione-elettronica-mcp"],
      "env": {
        "ARUBA_ENV": "demo",
        "ARUBA_USERNAME": "...",
        "ARUBA_PASSWORD": "..."
      }
    }
  }
}

API parity table

Aruba section Aruba endpoint MCP tool Implemented Sensitive read Binary
Auth GET /auth/userInfo aruba_get_user_info yes no no
Auth GET /auth/multicedenti aruba_list_multicedenti yes no no
Auth GET /auth/multicedenti/{id} aruba_get_multicedente_by_id yes no no
Sent invoices GET /services/invoice/out/findByUsername aruba_find_sent_invoices yes no no
Sent invoices GET /services/invoice/out/getByFilename aruba_get_sent_invoice_by_filename yes conditional no
Sent invoices GET /services/invoice/out/getZipByFilename aruba_get_sent_invoice_zip_by_filename yes yes yes
Sent invoices GET /services/invoice/out/{invoiceId} aruba_get_sent_invoice_by_id yes conditional no
Sent invoices GET /services/invoice/out/getByIdSdi aruba_get_sent_invoice_by_sdi_id yes conditional no
Sent invoices GET /services/invoice/out/pdd aruba_get_sent_invoice_pdd yes yes yes
Received invoices GET /services/invoice/in/findByUsername aruba_find_received_invoices yes no no
Received invoices GET /services/invoice/in/getByFilename aruba_get_received_invoice_by_filename yes conditional no
Received invoices GET /services/invoice/in/getZipByFilename aruba_get_received_invoice_zip_by_filename yes yes yes
Received invoices GET /services/invoice/in/{invoiceId} aruba_get_received_invoice_by_id yes conditional no
Received invoices GET /services/invoice/in/getByIdSdi aruba_get_received_invoice_by_sdi_id yes conditional no
Received invoices GET /services/invoice/in/getInvoiceWithUnsignedFile aruba_get_received_invoice_unsigned_file yes yes no
Received invoices GET /services/invoice/in/pdd aruba_get_received_invoice_pdd yes yes yes
Sent notifications GET /services/notification/out/getByFilename aruba_get_sent_notification_by_filename yes yes no
Sent notifications GET /services/notification/out/getByInvoiceFilename aruba_get_sent_notifications_by_invoice_filename yes yes no
Sent notifications GET /services/notification/out/{invoiceId} aruba_get_sent_notifications_by_invoice_id yes yes no
Received notifications GET /services/notification/in/getByFilename aruba_get_received_notification_by_filename yes yes no
Received notifications GET /services/notification/in/getByInvoiceFilename aruba_get_received_notifications_by_invoice_filename yes yes no
Received notifications GET /services/notification/in/{invoiceId} aruba_get_received_notifications_by_invoice_id yes yes no
Customer result GET /services/invoice/in/sendEsitoCommittente/{filename} aruba_get_customer_result_status yes no no

Security notes

Some responses can contain fiscal XML, PDF, ZIP or Base64 payloads with sensitive tax data. Credentials are read only from environment variables. Tokens, passwords, Base64, XML, PDF, ZIP and likely VAT/fiscal codes are redacted from logs.

Use dedicated credentials where possible, not shared admin accounts. Verify contractually that Aruba Web Services/API access is enabled for your account. Start with ARUBA_ENV=demo.

Attribution

Inspired by these projects:

  • zangetsu02/fatturazione-elettronica-aruba
  • andreafalzetti/node-fatturazione-elettronica-aruba

No code was copied verbatim in this implementation. Preserve original notices if future changes adapt source code from third-party projects.

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

aruba_fatturazione_elettronica_mcp-0.3.0.tar.gz (140.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file aruba_fatturazione_elettronica_mcp-0.3.0.tar.gz.

File metadata

File hashes

Hashes for aruba_fatturazione_elettronica_mcp-0.3.0.tar.gz
Algorithm Hash digest
SHA256 1559ae64a53ad2f4447e904f3e2531d46ebc8c7540f400a021ad134c3981e114
MD5 ac01c05fa3bced35746630ba53112de2
BLAKE2b-256 e2c5340a019256c1b3eb16257dbf638648076bb0e2547f5f2f879d6ec225a6b7

See more details on using hashes here.

File details

Details for the file aruba_fatturazione_elettronica_mcp-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for aruba_fatturazione_elettronica_mcp-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 10955075fa27e7472647129769bda23a3cfddbcbb48041d89cd23e99b7fe01ff
MD5 d119547c20a51ea97e3b21c43c69bbd5
BLAKE2b-256 9c0dd38766b4f9221cb00db1fa1617a27d51bbe7e3cb48f535596091a64658cd

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page