236 lines
8.2 KiB
Markdown
236 lines
8.2 KiB
Markdown
# TLD Enumerations
|
|
Lists of every [IANA TLD](http://data.iana.org/TLD/tlds-alpha-by-domain.txt) in various formats. The lists may be continuously updated using the [included utility](#updating-the-tld-lists) that pulls the latest data from IANA.
|
|
|
|
* [CSV Format](./tlds.csv)
|
|
* [All Format Files](#tld-list-formats)
|
|
* [Updating the Format Files](#updating-the-tld-format-files)
|
|
* [Node Usage](#node-usage)
|
|
* [PHP Usage](#php-usage)
|
|
|
|
## Usage
|
|
Because the lists are provided in universial CSV and JSON formats, they can be easily utilitized in most programming environments.
|
|
Additionally, for convenience, some native programming language formats have also been provided.
|
|
* [Node Usage](#node-usage)
|
|
* [PHP Usage](#php-usage)
|
|
|
|
### Node Usage
|
|
* use npm to add the `tld-enum` package to your project
|
|
```sh
|
|
$ npm install tld-enum --save
|
|
```
|
|
|
|
* add the module to your source
|
|
|
|
```js
|
|
const tldEnum = require('tld-enum');
|
|
```
|
|
|
|
* access the list by using the `tldEnum.tldList` array
|
|
|
|
```js
|
|
const tldEnum = require('tld-enum');
|
|
tldEnum.list; //an array with every IANA TLD
|
|
```
|
|
|
|
The following example...
|
|
```js
|
|
const tldEnum = require('tld-enum');
|
|
|
|
console.log("There are " + tldEnum.list.length + " IANA TLDs");
|
|
|
|
let tldCheck;
|
|
|
|
tldCheck = "com";
|
|
console.log("Is '" + tldCheck + "' a real TLD?");
|
|
if (tldEnum.list.indexOf(tldCheck.toLowerCase()) != -1) {
|
|
console.log(" yes");
|
|
} else {
|
|
console.log(" no");
|
|
}
|
|
|
|
tldCheck = "somethingWeird";
|
|
console.log("Is '" + tldCheck + "' a real TLD?");
|
|
if (tldEnum.list.indexOf(tldCheck.toLowerCase()) != -1) {
|
|
console.log(" yes");
|
|
} else {
|
|
console.log(" no");
|
|
}
|
|
```
|
|
|
|
Should produce the following output...
|
|
```txt
|
|
There are 1577 IANA TLDs
|
|
Is 'com' a real TLD?
|
|
yes
|
|
Is 'somethingWeird' a real TLD?
|
|
no
|
|
```
|
|
|
|
#### More Node Examples
|
|
* [js-demo.js](/examples/js-demo.js) Demo using the simple array of every TLD in JavaScript.
|
|
* [js-desc-demo.js](/examples/js-desc-demo.js) Demo using the TLD description hashmap in JavaScript.
|
|
* [js-type-demo.js](/examples/js-type-demo.js) Demo using the TLD type hashmap in JavaScript.
|
|
* [js-info-demo.js](/examples/js-info-demo.js) Demo using the array of TLD info hashmaps in JavaScript.
|
|
|
|
### PHP Usage
|
|
* use composer to add the `katmore/tld-enum` package to your project
|
|
```sh
|
|
$ composer require katmore/tld-enum
|
|
```
|
|
|
|
* access the list by using the `\TldList::TLD_LIST` class constant array
|
|
|
|
```php
|
|
<?php
|
|
print_r(\TldList::TLD_LIST); //an array with every IANA TLD
|
|
```
|
|
|
|
The following example...
|
|
```php
|
|
<?php
|
|
use TldEnum\TldList;
|
|
|
|
echo "There are " . count(TldList::TLD_LIST) . " IANA TLDs\n";
|
|
|
|
$tldCheck = "com";
|
|
echo "Is '$tldCheck' a real TLD?\n";
|
|
if (in_array(strtolower($tldCheck), TldList::TLD_LIST)) {
|
|
echo " yes\n";
|
|
} else {
|
|
echo " no\n";
|
|
}
|
|
|
|
$tldCheck = "somethingWeird";
|
|
echo "Is '$tldCheck' a real TLD?\n";
|
|
if (in_array(strtolower($tldCheck), TldList::TLD_LIST)) {
|
|
echo " yes\n";
|
|
} else {
|
|
echo " no\n";
|
|
}
|
|
```
|
|
|
|
Should produce the following output...
|
|
```txt
|
|
There are 1577 IANA TLDs
|
|
Is 'com' a real TLD?
|
|
yes
|
|
Is 'somethingWeird' a real TLD?
|
|
no
|
|
```
|
|
|
|
#### More PHP Examples
|
|
* [php-demo.php](/examples/php-demo.php) Demo using the simple array of every TLD in PHP.
|
|
* [php-TldDesc-demo.php](/examples/php-TldDesc-demo.php) Demo using the TLD description hashmap in PHP.
|
|
* [php-TldType-demo.php](/examples/php-TldType-demo.php) Demo using the TLD type hashmap in PHP.
|
|
* [php-TldInfo-demo.php](/examples/php-TldInfo-demo.php) Demo using the array of TLD info hashmaps in PHP.
|
|
|
|
## TLD List Formats
|
|
* **CSV**: [tlds.csv](/tlds.csv)
|
|
|
|
A CSV file providing a row for every IANA TLD with the following three columns: *domain* (TLD), *description*, and *type*.
|
|
|
|
* **PHP**
|
|
* [TldList.php](/formats/php/TldEnum/TldList.php)
|
|
|
|
A PHP source file providing a class constant array comprised of every IANA TLD.
|
|
|
|
* [TldDesc.php](/formats/php/TldEnum/TldDesc.php)
|
|
|
|
A PHP source file providing a class constant assoc array with a key for every IANA TLD and the corresponding TLD's "description" as the value.
|
|
|
|
* [TldType.php](/formats/php/TldEnum/TldType.php)
|
|
|
|
A PHP source file providing a class constant assoc array with a key for every IANA TLD and the corresponding TLD's "type" as the value.
|
|
|
|
* [TldInfo.php](/formats/php/TldEnum/TldInfo.php)
|
|
|
|
A PHP source file providing a class constant array of "info" assoc array elements of every IANA TLD.
|
|
|
|
* **JSON**
|
|
* [tld-list.json](/formats/json/tld-list.json)
|
|
|
|
A JSON formatted array comprised of every IANA TLD.
|
|
|
|
* [tld-desc.json](/formats/json/tld-desc.json)
|
|
|
|
A JSON formatted object with a property for every IANA TLD and the corresponding TLD's "description" as the value.
|
|
|
|
* [tld-type.json](/formats/json/tld-type.json)
|
|
|
|
A JSON formatted object with a property for every IANA TLD and the corresponding TLD's "type" as the value.
|
|
|
|
* [tld-info.json](/formats/json/tld-info.json)
|
|
|
|
A JSON formatted array of "info" object elements of every IANA TLD.
|
|
|
|
* **JavaScript**
|
|
* [list.js](/formats/js/tld-enum/list.json)
|
|
|
|
An export module with an array comprised of every IANA TLD.
|
|
|
|
* [desc.js](/formats/js/tld-enum/desc.json)
|
|
|
|
An export module with an object containing a property for every IANA TLD and the corresponding TLD's "description" as the value.
|
|
|
|
* [type.js](/formats/js/tld-enum/type.json)
|
|
|
|
An export module with an object containing a property for every IANA TLD and the corresponding TLD's "type" as the value.
|
|
|
|
* [info.js](/formats/js/tld-enum/info.json)
|
|
|
|
An export module with an array comprised of "info" object elements of every IANA TLD.
|
|
|
|
## Updating the TLD format files
|
|
All [TLD List Formats](#tld-list-formats) can be updated with the latest data from IANA by using the [**TLD Update Utility**](/bin/update-formats.sh).
|
|
|
|
```sh
|
|
$ bin/update-formats.sh
|
|
```
|
|
|
|
### TLD Update Utility Prerequisites
|
|
* Node.js version 8.11 or higher.
|
|
* (Optional) PHP command-line version 7.2 or higher, to create the [PHP format class file](#tld-list-formats).
|
|
|
|
### TLD Update Utility Usage
|
|
```txt
|
|
usage:
|
|
update-formats.sh [-h] | [-q][--skip-php]
|
|
|
|
options:
|
|
-h,--help: Print a help message and exit.
|
|
-q,--quiet: Print less messages.
|
|
--force-php: Creating the PHP format file is mandatory.
|
|
--skip-php: Always skip creating the PHP format file
|
|
```
|
|
|
|
### TLD Update Helpers
|
|
Internally, the *TLD Update Utility* uses multiple *"helper" scripts* to generate the full set of native format lists.
|
|
These individual *"helper" scripts* should not be directly executed except for development and troubleshooting purposes.
|
|
|
|
## Legal
|
|
The source code in this project is based on a fork of certain source code originally from the [incognico/list-of-top-level-domains](https://github.com/incognico/list-of-top-level-domains) project, as retrieved on 2017-12-04, which was published to the public domain.
|
|
|
|
### Copyright
|
|
TLD Enumerations - https://github.com/katmore/tld-enum
|
|
|
|
The following copyright notice applies to all resources in this project unless specifically noted otherwise:
|
|
|
|
Copyright (c) 2017-2018 Doug Bird. All Rights Reserved.
|
|
|
|
### Public Domain Resources
|
|
The following resources of this project are hereby released into the public domain:
|
|
* [tlds.csv](/tlds.csv)
|
|
* [formats/js/tld-enum.js](/formats/js/tld-enum.js)
|
|
* [formats/json/tld-list.json](/formats/json/tld-list.json)
|
|
* [formats/php/TldEnum/TldEnum.php](/formats/php/TldEnum/TldEnum.php)
|
|
* [assets/tld-desc.csv](/assets/tld-desc.csv)
|
|
|
|
### License
|
|
All resources in the 'TLD Enumerations' project are copyrighted free software unless specifically noted otherwise.
|
|
|
|
You may redistribute and modify it under either the terms and conditions of the
|
|
"The MIT License (MIT)"; or the terms and conditions of the "GPL v3 License".
|
|
See [LICENSE](/LICENSE) and [GPLv3](/GPLv3).
|
|
|
|
These licensing conditions do not apply to any resources that have been released into the public domain; which are listed in the [**"Public Domain Resources"**](/README.md#public-domain-resources) section of the 'TLD Enumerations' project's [README](/README.md) document.
|