PHP Client for the NameAPI Web Service at http://www.nameapi.org/
There are functional tests (in tests/functional) that demonstrate how to use this library. The tests are run with PHPUnit.
All you need to send requests is your own api key, get it from nameapi.org.
You can download the source code and make it available to your code. Or you can check it out directly from this GitHub project. Currently there is no phar and no composer available.
The only requirement is that the php_soap extension is enabled.
At first you need one single include, the one to the nameapi service factory:
require_once('your/path/to/org/nameapi/client/services/ServiceFactory.php');
Then you need a Context that explains a bit your working environment, something like:
use org\nameapi\ontology\input\context\Context;
use org\nameapi\ontology\input\context\Priority;
use org\nameapi\client\services\ServiceFactory;
$context = Context::builder()
->apiKey('your-api-key')
->priority(Priority::REALTIME())
->build();
Then you can already create the service factory which gives you access to all nameapi services:
$serviceFactory = new ServiceFactory($context);
This code sends a simple ping to nameapi to test the connection:
$pinger = $serviceFactory->systemServices()->pinger();
$pong = $pinger->ping();
If the response is 'pong' then all is fine and you can move on to the real goodies.
All input objects come with builders or nicely documented setters. The result objects returned by the services all have fully documented getters. Many input arguments are optional - that means you can start simple, and add more as you need.
Behind the scenes this service api uses SOAP. But luckily you don't need to worry about any of the interface detail, you can just use the provided classes. The complexity of some of the objects is the reason why SOAP was chosen over REST.
Most services accept a 'Person' as input. This person contains a name, and optionally more data such as gender, birth date etc. The name can be just a single "full name" string, or it can be composed of multiple fields like given name, middle name, surname. This standardized api makes it simple to use different services in a consistent way, and is very convenient in accepting the data however you have it at hands.
Creating a simple person looks something like this:
use org\nameapi\ontology\input\entities\person\NaturalInputPerson;
use org\nameapi\ontology\input\entities\person\name\InputPersonName;
$inputPerson = NaturalInputPerson::builder()
->name(InputPersonName::westernBuilder()
->fullname( "John F. Kennedy" )
->build())
->build();
Name parsing is the process of splitting a full name into its components.
Using the $inputPerson created earlier:
$personNameParser = $this->makeServiceFactory()->parserServices()->personNameParser();
$parseResult = $personNameParser->parse($inputPerson);
var_dump($parseResult);
Name genderizing is the process of identifying the gender based on a person's name.
Using the $inputPerson created earlier:
$personGenderizer = $serviceFactory->genderizerServices()->personGenderizer();
$personGenderResult = $personGenderizer->assess($inputPerson);
echo $personGenderResult->getGender()->toString(); //will print 'MALE'
The Name Matcher compares names and name pairs to discover whether the people could possibly be one and the same person.
This service takes 2 people as input:
$personMatcher = $serviceFactory->matcherServices()->personMatcher();
$inputPerson1 = NaturalInputPerson::builder()
->name(InputPersonName::westernBuilder()
->fullname( "John F. Kennedy" )
->build())
->build();
$inputPerson2 = NaturalInputPerson::builder()
->name(InputPersonName::westernBuilder()
->fullname( "Jack Kennedy" )
->build())
->build();
$personMatcherResult = $personMatcher->match($inputPerson1, $inputPerson2);
echo $personMatcherResult->getPersonMatchType()->toString(); //will print 'MATCHING'
The Name Formatter displays personal names in the desired form. This includes the order as well as upper and lower case writing.
$personNameFormatter = $serviceFactory->formatterServices()->personNameFormatter();
$inputPerson = NaturalInputPerson::builder()
->name(InputPersonName::westernBuilder()
->fullname( "john kennedy" )
->build())
->build();
$formatterResult = $personNameFormatter->format($inputPerson, new FormatterProperties());
echo $formatterResult->getFormatted(); //will print 'John Kennedy'
The Email Name Parser extracts names out of email addresses.
$emailNameParser = $serviceFactory->emailServices()->emailNameParser();
$result = $emailNameParser->parse("john.doe@example.com");
echo $result;
The DEA-Detector checks email addresses against a list of known "trash domains" such as mailinator.com.
$deaDetector = $serviceFactory->emailServices()->disposableEmailAddressDetector();
$result = $deaDetector->isDisposable("abcdefgh@10minutemail.com");
echo $result->getDisposable(); //will print 'YES'