Australian Prudential Regulation Authority
This MCP server provides plain-English access to Australian Prudential Regulation Authority (APRA) statistics, covering banking, superannuation, and insurance data for every prudentially-regulated entity in Australia, quarter by quarter.
Core Tools:
search_datasets: Fuzzy-search the curated catalog by keyword (e.g., "bank capital", "superannuation", "insurance premium").list_curated: Enumerate all 7 available curated dataset IDs.describe_dataset: Get metadata including filterable dimensions, returnable measures, units, period coverage, source URLs, and framework break information.get_data: Query observations with dimension filters, measure selection, date ranges (YYYY-MM-DD, YYYY-Qx, YYYY), and output formats (records, series, or CSV).latest: Retrieve the most recent observation per measure — ideal for current snapshots like "What's CBA's current CET1 ratio?"top_n: Rank entities by a measure and return the top or bottom N rows — e.g., "Top 10 banks by total capital" or "5 super funds with the most members."
Available Datasets:
ID | Description |
| Per-bank CET1, Tier 1, Total capital, and RWA |
| Per-bank RWA by risk type (credit, operational, market, IRRBB) |
| Fund-by-fund members, benefits, and demographics |
| Post-AASB17 general insurance (Sep 2023 → latest) |
| Pre-AASB17 general insurance archive (Dec 2002 → Jun 2023) |
| Post-AASB17 life insurance (Sep 2023 → latest) |
| Pre-AASB17 life insurance archive (Jun 2008 → Jun 2023) |
Notable Features:
Insurance datasets are split at the AASB-17 reporting break (Q3 2023) to prevent accidental splicing of incomparable data.
A 3-tier URL resolution system (live scrape → bundled manifest → YAML default) ensures data freshness even if APRA's landing page changes.
State/territory filters accept multiple formats (codes, names, ISO codes, postcodes) via the
aus-identitylibrary.
apra-mcp
MCP server for Australian Prudential Regulation Authority statistics. Plain-English access to per-bank capital ratios, fund-by-fund superannuation, and post-AASB17 life + general insurance — every prudentially-regulated entity in Australia, every quarter, from a single uvx command.
"What's CBA's CET1 ratio?"
"Which super fund has the most members?"
"Top 10 banks by total capital, latest quarter"
"Gross written premium for the general insurance industry, post-AASB17"
"Largest life insurance product groups by claims"Sister to abs-mcp, rba-mcp, ato-mcp, and au-weather-mcp.
Install
uvx --upgrade apra-mcpClaude Desktop
{
"mcpServers": {
"apra": { "command": "uvx", "args": ["--upgrade", "apra-mcp"] }
}
}Claude Code
claude mcp add apra --command uvx --args -- --upgrade apra-mcpWhat it exposes
Six tools, all plain-English in, structured out:
Tool | Purpose |
| Fuzzy-search the curated catalog by keyword |
| List a dataset's filterable dimensions and returnable measures |
| Query with |
| Last observation per measure (shortcut) |
| Rank rows by a measure, return top (or bottom) N |
| Enumerate the curated dataset IDs |
Every response is the same shape — dataset_id, dataset_name, query, period, unit, row_count, records, apra_url, download_url, framework (insurance only), attribution, stale flag, server_version — across every curated dataset.
Curated datasets (7 in v0.1)
ID | What it is | Period |
| Per-bank CET1 / Tier 1 / Total capital + RWA | latest quarter snapshot |
| Per-bank RWA by risk type (credit / operational / market / IRRBB) | latest quarter snapshot |
| Fund-by-fund members, benefits, demographics | latest quarter snapshot |
| Long-format general insurance (post-AASB17, ~24k rows × 10 quarters) | Sep 2023 → latest |
| General insurance archive (pre-AASB17) | Dec 2002 → Jun 2023 |
| Long-format life insurance (post-AASB17, ~10k rows × 10 quarters) | Sep 2023 → latest |
| Life insurance archive (pre-AASB17) | Jun 2008 → Jun 2023 |
Snapshot vs time-series. ADI and Super datasets ship the most recent reporting quarter only (APRA refreshes the file each quarter). The four insurance datasets are long time series in a single file. Pass
start_period/end_periodas ISO dates (2025-12-31), bare years (2024), year-months (2025-06), or quarter shorthand (2025-Q4) — all normalised internally.
Cross-source compatibility. The
state_territoryfilter onINSURANCE_GENERALaccepts canonical state codes ("NSW"), full names ("New South Wales"), case-insensitive variants ("nsw"), ISO 3166-2 ("AU-NSW"), and 4-digit postcodes ("2000"→ New South Wales). Powered byaus-identity— the same input format works across abs-mcp, ato-mcp, apra-mcp, aihw-mcp, and asic-mcp.
Reliability — 3-tier URL resolution
APRA publishes XLSX at date-versioned paths that change every quarter. apra-mcp resolves them through three tiers:
Live scrape — fetch the canonical APRA landing page (with ETag conditional-GET so refreshes between releases cost zero bytes), regex-extract the .xlsx href matching the dataset's filename pattern, pick the latest-dated match. Cached 6h.
Bundled seed manifest — when the live scrape fails, fall back to
data/seed_urls.jsonshipped in the wheel. CI refreshes the manifest daily. The response is flaggedstale: truewith an honest reason.YAML default — last-resort URL from the curated YAML.
Net effect: a fresh uvx apra-mcp always gets the current quarter; a 3-month-old install still works because the seed manifest is refreshed and --upgrade pulls a new wheel.
Framework break (insurance only)
APRA changed the reporting framework on 1 July 2023 (AASB 17 Insurance Contracts + capital framework revision). Pre- and post-break data are not directly comparable — APRA's own guidance is explicit. apra-mcp ships paired datasets:
INSURANCE_GENERAL(post-AASB17) +INSURANCE_GENERAL_HISTORICAL(pre-AASB17)LIFE_INSURANCE(post-AASB17) +LIFE_INSURANCE_HISTORICAL(pre-AASB17)
Every response on an insurance dataset includes a framework block surfacing the break + a historical_dataset cross-reference, so agents see the warning before splicing series.
Attribution
Data sourced from the Australian Prudential Regulation Authority. Licensed under Creative Commons Attribution 3.0 Australia (CC BY 3.0 AU). apra-mcp is MIT-licensed; APRA's data carries the upstream CC-BY 3.0 AU licence, echoed in every response's attribution field.
Sister MCPs (Australian Public Data portfolio)
abs-mcp — Australian Bureau of Statistics (CPI, unemployment, ERP, building approvals)
rba-mcp — Reserve Bank of Australia (cash rate, lending stats, exchange rates)
ato-mcp — Australian Taxation Office (tax stats, ACNC charities)
apra-mcp — this one. Banks, super, insurance.
aihw-mcp — Australian Institute of Health and Welfare
asic-mcp — Australian Securities and Investments Commission (company registers)
aemo-mcp — Australian Energy Market Operator (NEM dispatch, spot prices, generation)
au-weather-mcp — Open-Meteo (Bureau of Meteorology aggregator)
wgea-mcp — Workplace Gender Equality Agency
aus-identity — Postcode / state / ABN normalisation helper used by all sisters
Development
git clone https://github.com/Bigred97/apra-mcp.git
cd apra-mcp
uv venv
uv pip install -e ".[dev]"
pytest # unit tests
pytest -m live # integration tests against apra.gov.auIssues and contributions welcome: github.com/Bigred97/apra-mcp/issues.
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Bigred97/apra-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server