helgesverre / domain-availability
A PHP library for checking if a domain name is registered or not
Installs: 14 763
Dependents: 1
Suggesters: 0
Security: 0
Stars: 265
Watchers: 25
Forks: 137
Open Issues: 1
Requires
- php: >=7.0
- jeremykendall/php-domain-parser: ^5.5
Requires (Dev)
- phpunit/phpunit: ^4|^5
README
A PHP library used to check domain name availability.
READ THIS, SERIOUSLY:
This is not a reliable way to check for domain availability on a large or even a medium scale, this will not handle your "webhosting business" or anything that requires a high level of data accuracy, if you need something like that, please use WhoAPI or Namecheap's API.
And no, I did not build nor do i support the WordPress plugin that is being sold on CodeCanyon which uses this package under the hood.
Install
$ composer require --dev helgesverre/domain-availability
or
{
"require": {
"helgesverre/domain-availability": "~1.5.0"
}
}
Usage
<?php require './vendor/autoload.php'; use Helge\Loader\JsonLoader; use Helge\Client\SimpleWhoisClient; use Helge\Service\DomainAvailability; $whoisClient = new SimpleWhoisClient(); $dataLoader = new JsonLoader("path/to/servers.json"); $service = new DomainAvailability($whoisClient, $dataLoader); if ($service->isAvailable("helgesverre.com")) { echo "Domain is available"; } else { echo "Domain is already taken!"; }
or look at example.php for a more real world example.
Notes
The WHOIS server list is incomplete and some data is missing. The most popular TLDs are working, though, and I will update these as I can. I suggest making your own list of whois servers and their "not found"-responses so you know which TLD is available. For a full list of TLDs and WHOIS servers please go to the IANA website.
To check what they return when a domain is not found, you simply have to manually query the servers and check.
Supported Domain Extensions
These are the domain extensions that are supported by this script.
.com, .net, .org, .co.uk, .io, .computer, .ac, .academy, .actor, .ae, .aero, .af, .ag,
.agency, .ai, .am, .archi, .arpa, .as, .asia, .associates, .at, .au, .aw, .ax, .az, .bar,
.bargains, .bayern, .be, .berlin, .bg, .bi, .bike, .biz, .bj, .blackfriday, .bn, .boutique, .build,
.builders, .bw, .by, .ca, .cab, .camera, .camp, .capital, .cards, .careers, .cat, .catering,
.cc, .center, .ceo, .cf, .ch, .cheap, .christmas, .ci, .cl, .cleaning, .clothing, .club,
.cn, .co, .codes, .coffee, .college, .cologne, .community, .company, .construction,
.contractors, .cooking, .cool, .coop, .country, .cruises, .cx, .cz, .dating, .de,
.democrat, .desi, .diamonds, .directory, .dk, .dm, .domains, .dz, .ec, .edu, .education,
.ee, .email, .engineering, .enterprises, .equipment, .es, .estate, .eu, .eus, .events,
.expert, .exposed, .farm, .feedback, .fi, .fish, .fishing, .flights, .florist, .fo,
.foo, .foundation, .fr, .frogans, .futbol, .ga, .gal, .gd, .gg, .gi, .gift, .gl, .glass,
.gop, .gov, .gq, .graphics, .gripe, .gs, .guitars, .guru, .gy, .haus, .hk, .hn, .holiday,
.horse, .house, .hr, .ht, .hu, .id, .ie, .il, .im, .immobilien, .in, .industries,
.institute, .int, .international, .iq, .ir, .is, .it, .je, .jobs, .jp, .kaufen, .ke,
.kg, .ki, .kitchen, .kiwi, .koeln, .kr, .kz, .la, .land, .lease, .li, .lighting, .limo,
.link, .london, .lt, .lu, .luxury, .lv, .ly, .ma, .management, .mango, .marketing, .md,
.me, .media, .menu, .mg, .miami, .mk, .ml, .mn, .mo, .mobi, .moda, .monash, .mp, .ms,
.mu, .museum, .mx, .my, .na, .name, .nc, .nf, .ng, .ninja, .nl, .no, .nu, .nz, .om,
.onl, .paris, .partners, .parts, .pe, .pf, .photo, .photography, .photos, .pics,
.pictures, .pl, .plumbing, .pm, .post, .pr, .pro, .productions, .properties, .pt,
.pub, .pw, .qa, .quebec, .re, .recipes, .reisen, .rentals, .repair, .report, .rest,
.reviews, .rich, .ro, .rocks, .rodeo, .rs, .ru, .ruhr, .sa, .saarland, .sb, .sc, .se,
.services, .sexy, .sg, .sh, .shoes, .si, .singles, .sk, .sm, .sn, .so, .social, .solar,
.solutions, .soy, .st, .su, .supplies, .supply, .support, .sx, .sy, .systems, .tattoo,
.tc, .technology, .tel, .tf, .th, .tienda, .tips, .tk, .tl, .tm, .tn, .to, .today,
.tools, .town, .toys, .tr, .training, .travel, .tv, .tw, .tz, .ua, .ug, .uk, .university,
.us, .uy, .black, .blue, .info, .kim, .pink, .red, .shiksha, .uz, .vacations, .vc, .ve,
.vegas, .ventures, .vg, .viajes, .villas, .vision, .vodka, .voting, .voyage, .vu, .wang,
.watch, .wed, .wf, .wien, .wiki, .works, .ws, .xxx, .xyz, .yt, .za, .zm, .zone,
Unsupported Domain Extensions
Due to the fact that a lot of the domain extensions listed on the IANA website do not contain any information on which WHOIS server to use when querying for the domain information, the following domain extensions are not available (yet):
.dj, .do, .eg, .eh, .er, .et, .fj, .fk, .fm, .gallery, .gb, .ge, .gf, .gh, .gm, .gn, .gp,
.gr, .gt, .gu, .gw, .hm, .jetzt, .jm, .jo, .kh, .km, .kn, .kp, .kred, .kw, .ky, .lb,
.lk, .lr, .ls, .mc, .mf, .mh, .mil, .mm, .moe, .mq, .mr, .mt, .mv, .mw, .mz, .nagoya, .ne,
.neustar, .ni, .np, .nr, .nyc, .okinawa, .pa, .pg, .ph, .pk, .pn, .ps, .py, .qpon, .ren,
.rw, .sd, .sj, .sl, .sohu, .sr, .ss, .sv, .sz, .td, .tg, .tj, .tokyo, .tp, .trade, .tt,
.um, .uno, .va, .vi, .vi, .vn, .webcam, .ye, .yokohoma, .ryukyu, .meet, .vote, .lc,
.voto, .wed, .zw
If you know the whois server for any of these please feel free to create an issue with an update.
Credits
- Research and code by Helge Sverre
- Domain Parser by Jeremy Kendall
Notes
If you are getting the error:
Fatal error: Call to undefined function Pdp\idn_to_ascii()
Be sure to enable the php extension called intl
as the domain parsing extension requires it!
If certain domain extensions are always or very often returning an unexpected value, please create an issue instead of emailing me in broken english. In your issue provide me with the following:
- Your webhost
- Link to your website where the error is happening
- The extension and domain you are trying to check availability for
Keep in mind that this library queries the WHOIS servers directly and if you "spam" them with requests, you will get temporary banned and that will cause the library to say the domain always is taken.
License
The MIT License (MIT). Please see License File for more information.