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 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.

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

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.

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 MIT-licensed repositories:

  • zangetsu02/fatturazione-elettronica-aruba
  • andreafalzetti/node-fatturazione-elettronica-aruba
  • mnbro/listmonk-mcp-bridge

No code was copied verbatim in this initial implementation. Preserve MIT notices if future changes adapt source code.

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.1.0.tar.gz (119.0 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.1.0.tar.gz.

File metadata

File hashes

Hashes for aruba_fatturazione_elettronica_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 86240059087c9bc228c54886eebd4d957c3dd5e847c35e098c7e050a7e26d585
MD5 45f0e35b2b8c771fc091c6384c9a1548
BLAKE2b-256 269f58187c115e1ff598bd7906ace445894f6bd96feb16e6b7bcc8c66bd9cf73

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for aruba_fatturazione_elettronica_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c283179e76704313fdcd61fd98c5ec874a885749e5c2e9efe23181211c686bae
MD5 f93fcd989d9618e1bb9f17b5f70ddbfe
BLAKE2b-256 3c4a776510c6a6cdd4b38af4c21c20a9e71f79f8dfe2a7ab836ab935307406fb

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