Source: https://en.wikipedia.org/wiki/Mobile_country_code
The ITU-T Recommendation E.212 defines mobile country codes as well as mobile network codes. The mobile country code consists of 3 decimal digits and the mobile network code consists of 2 or 3 decimal digits (for example: MNC of 001 is not the same as MNC of 01). The first digit of the mobile country code identifies the geographic region as follows (the digits 1 and 8 are not used):
- 0- Test networks
- 2- Europe
- 3- North America and the Caribbean
- 4- Asia and the Middle East
- 5- Oceania
- 6- Africa
- 7- South and Central America
- 9- World-wide (Satellite, Air - aboard aircraft, Maritime - aboard ships, Antarctica)
A mobile country code (MCC) is used in combination with a mobile network code (MNC) (also known as a "MCC / MNC tuple" or "PLMN Code") to uniquely identify a mobile network operator (carrier) using the GSM (including GSM-R), UMTS, and LTE public land mobile networks (PLMN). (source: Wikipedia)
$ npm install mcc-mnc-list
This file contains all the records fetched from the Wikipedia page.
Structure of a single record:
{
  "plmn": <String> - mcc-mnc tuple unique network identifier
  "nibbledPlmn": <String> - PLMN encoded according to 3GPP TS 24.008 (section 10.5.1.13)
  "mcc": <String> - mobile country code
  "mnc": <String> - mobile network code
  "region": <String> - 'Europe / Africa / Oceania / etc'
  "type": <String> - geographic region ( see regions.json )
  "countryName": <String> - country name
  "countryCode": <String> - ISO 3166-1 country code
  "lat": <String> - latitude of the country centroid
  "long": <String> - longitude of the country centroid
  "brand": <String|null>
  "operator": <String|null>
  "status": <String> - status code ( see status-codes.json )
  "bands": <String|null>
  "notes": <String|null>
}List ( Array ) of all the different Status Codes from MCC/MNC list.
Returns the full record list
Returns the status code list
Returns the regions list
Returns a filtered record list. filters is an object.
// get all the Operational mobile networks
let filters = { statusCode: 'Operational' }
// get all the Operational mobile networks in Europe
let filters = { statusCode: 'Operational', region: 'Europe' }
// get all the records from Hungary
let filters = { mcc: '216' }
// get a specific network item ( specified with two keys )
let filters = { mcc: '216', mnc: '30' }
// get a specific network item ( specified with a plmn code )
let filters = { plmn: '21630' }
// get all the Operational mobile networks from Hungary
let filters = { statusCode: 'Operational', mcc: '216' }
// get all the Operational mobile networks from US countryCode
let filters = { statusCode: 'Operational', countryCode: 'US' }
// get all the records
let filters = {}const mcc_mnc_list = require('mcc-mnc-list');
let records = mcc_mnc_list.all();
let statusCodes = mcc_mnc_list.statusCodes();
console.log(records.length);
// 2189
console.log(statusCodes.length);
// 12
console.log(mcc_mnc_list.filter({ plmn: '21630' }));
// [{  plmn: '21630',
//     nibbledPlmn: '12F603',
//     mcc: '216',
//     mnc: '30',
//     region: 'Europe',
//     type: 'National',
//     countryName: 'Hungary',
//     countryCode: 'HU',
//     lat: '47',
//     long: '20',
//     brand: 'T-Mobile',
//     operator: 'Magyar Telekom Plc',
//     status: 'Operational',
//     bands:
//      'GSM 900 / GSM 1800 / UMTS 2100 / LTE 800 / LTE 1800 / LTE 2600',
//     notes:
//      'Former WESTEL, Westel 900; MNC has the same numerical value as the area code' 
// }]mcc-mnc-list is licensed under the MIT Open Source license. For more information, see the LICENSE file in this repository.