Skip to main content

MCP server for the Maltese legislation portal (legislation.mt) - consolidated Maltese law with ELI identifiers and verifiable citations.

Project description

mt-eli-mcp

An MCP server for the Maltese legislation portal legislation.mt, the official source of consolidated Maltese law. It fetches document metadata and full text, with verifiable citations.

Part of the MateMatic eu-legal-mcp production line - after PL, DE, AT, ES, FI, IE, NL, SE, FR, LU, DK, CZ, HR, LT, SK and RO. Same citation contract, legislation.mt source. Malta is ELI-native; each page carries schema.org/ELI JSON-LD.

Scope. This MVP fetches a document's metadata (from JSON-LD) and full text by ELI coordinate (chapters, the Constitution, subsidiary legislation, Acts, Legal Notices). There is no free-text search; address documents by their ELI coordinate. Languages: English (eng) and Maltese (mlt). Every response carries a dataset_note.

Text comes from PDF. Malta publishes the consolidated text only as PDF. mt_get_text downloads the official PDF and extracts the text with pypdf; layout-dependent artefacts are possible. Every text response carries a text_note.

The tools

Tool What it does
mt_get_act Metadata for a document by ELI coordinate (JSON-LD).
mt_get_text Full text by ELI coordinate (extracted from the official PDF).

ELI coordinates (eli): cap/586 (Chapter), const (Constitution), sl/586.01 (subsidiary legislation), act/2018/20 (Act), ln/2018/123 (Legal Notice).

Every response carries the contract: eli_uri (the legislation.mt URL, e.g. https://legislation.mt/eli/cap/586/eng), human_readable_citation (e.g. Data Protection Act (Cap. 586)), and source_url.

Install

Run it with no install step (once published to PyPI):

uvx mt-eli-mcp

Or from source:

cd mt-eli-mcp
pip install -e .

Configure (Claude Code / any MCP client)

{
  "mcpServers": {
    "mt-eli-mcp": { "command": "mt-eli-mcp" }
  }
}

Environment:

  • MT_ELI_BASE_URL - default https://legislation.mt
  • MT_ELI_CACHE_DIR - default ~/.matematic/cache/mt-eli
  • MT_ELI_AUDIT_DIR - default ~/.matematic/audit

No API key. legislation.mt is open data.

Governance

  • Public data only - read-only against legislation.mt; no client data leaves the machine.
  • Audit log - every tool call appends one JSON line to ~/.matematic/audit/mt-eli-mcp.jsonl.
  • Vendor-neutral - talks only to legislation.mt; no LLM provider, no telemetry.
  • Verifiable citations - every response is independently checkable via source_url.

See CONSTITUTION.md and DISCOVERY.md.

Tests

pip install -e ".[dev]"
pytest tests/test_instructions_drift.py tests/test_parse.py -v   # offline
pytest tests/test_smoke.py -v                                    # hits live legislation.mt

Licence

Apache-2.0. © Matematic Solutions / Wieslaw Mazur.

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

mt_eli_mcp-0.1.1.tar.gz (34.7 kB view details)

Uploaded Source

Built Distribution

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

mt_eli_mcp-0.1.1-py3-none-any.whl (16.9 kB view details)

Uploaded Python 3

File details

Details for the file mt_eli_mcp-0.1.1.tar.gz.

File metadata

  • Download URL: mt_eli_mcp-0.1.1.tar.gz
  • Upload date:
  • Size: 34.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mt_eli_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 05a0a3d913ee52674b0085fb86f3b17fd8d249130290ca07b038c25cbd35891d
MD5 6d4ab86feb26b52ee6ddc81203a37609
BLAKE2b-256 63433fca50d00545d6f2aab6e41916e87a00a079c4d53019391181e7fb24002c

See more details on using hashes here.

File details

Details for the file mt_eli_mcp-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: mt_eli_mcp-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 16.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mt_eli_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6c9261f04f1ebda84df06ff8d1b3a6ef505075a1e09ae692ce5b81d2bfc3f1a3
MD5 5c75a9ad19326c09069784859977078c
BLAKE2b-256 4147a03eec32dfb59c0cefd63446e10fedd1713776ac1642ee336160b8994f43

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