API — Malaysia (MY)

16 states, 160 districts, 1,859 subdistricts.

Endpoints

GET /api/v1/countries/my.json
Full dataset — all levels, all records
GET /api/v1/my/state.json
All 16 states (Negeri)
GET /api/v1/my/district.json
All 160 districts (Daerah)
GET /api/v1/my/mukim.json
All 1,859 subdistricts (Mukim)
GET /api/v1/my/state/{slug}.json
Single state with children
Example: /api/v1/my/state/johor-01.json

Quick Start

JavaScript

fetch('https://openadmindata.org/api/v1/countries/my.json')
  .then(r => r.json())
  .then(data => {
    const levels = data.meta.levels.map(l => l.name_en);
    console.log('Malaysia:', levels.join(' → '));
    
    console.log(data.data.state.length, 'states');
  });

Python

import requests
data = requests.get('https://openadmindata.org/api/v1/countries/my.json').json()
states = data['data']['state']
print(f"Malaysia: {len(states)} states")

cURL

curl -s https://openadmindata.org/api/v1/my/state.json | jq '.count'

Schema

Each entity record contains:

FieldTypeDescription
idstringUnique identifier
name_localstringName in local script
name_enstringEnglish / romanized name
slugstringURL-safe slug
latnumberLatitude (WGS84)
lonnumberLongitude (WGS84)
parent_idstring?Parent entity ID (null for top level)
parent_name_localstring?Parent name in local script
parent_name_enstring?Parent English name
postal_codestring?Postal code (deepest level only, where available)