2016-09-10 01:41:21 +03:00
|
|
|
<?php
|
|
|
|
|
2016-09-10 16:13:55 +03:00
|
|
|
namespace bkrukowski\TransparentEmail;
|
2016-09-10 01:41:21 +03:00
|
|
|
|
2016-09-16 02:13:48 +03:00
|
|
|
use bkrukowski\TransparentEmail\Services\AppsGoogleCom;
|
2016-09-10 16:13:55 +03:00
|
|
|
use bkrukowski\TransparentEmail\Services\GmailCom;
|
|
|
|
use bkrukowski\TransparentEmail\Services\OutlookCom;
|
|
|
|
use bkrukowski\TransparentEmail\Services\ServiceInterface;
|
|
|
|
use bkrukowski\TransparentEmail\Services\TlenPl;
|
|
|
|
use bkrukowski\TransparentEmail\Services\Www33MailCom;
|
|
|
|
use bkrukowski\TransparentEmail\Services\YahooCom;
|
2016-09-10 01:41:21 +03:00
|
|
|
|
2016-09-10 16:13:55 +03:00
|
|
|
class TransparentEmail
|
2016-09-10 01:41:21 +03:00
|
|
|
{
|
2016-09-10 11:50:57 +03:00
|
|
|
const SERVICE_GMAIL_COM = GmailCom::class;
|
|
|
|
const SERVICE_TLEN_PL = TlenPl::class;
|
|
|
|
const SERVICE_WWW_33MAIL_COM = Www33MailCom::class;
|
2016-09-10 13:15:37 +03:00
|
|
|
const SERVICE_OUTLOOK_COM = OutlookCom::class;
|
2016-09-10 14:33:57 +03:00
|
|
|
const SERVICE_YAHOO_COM = YahooCom::class;
|
2016-09-16 02:13:48 +03:00
|
|
|
const SERVICE_APPS_GOOGLE_COM = AppsGoogleCom::class;
|
2016-09-10 01:41:21 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Constant ALL_SERVICES can contain different values depends on API version
|
|
|
|
*/
|
|
|
|
const ALL_SERVICES = [
|
|
|
|
self::SERVICE_GMAIL_COM,
|
|
|
|
self::SERVICE_TLEN_PL,
|
|
|
|
self::SERVICE_WWW_33MAIL_COM,
|
2016-09-10 13:15:37 +03:00
|
|
|
self::SERVICE_OUTLOOK_COM,
|
2016-09-10 14:33:57 +03:00
|
|
|
self::SERVICE_YAHOO_COM,
|
2016-09-16 02:13:48 +03:00
|
|
|
self::SERVICE_APPS_GOOGLE_COM,
|
2016-09-10 01:41:21 +03:00
|
|
|
];
|
|
|
|
|
|
|
|
private $services;
|
|
|
|
|
2016-09-10 02:39:01 +03:00
|
|
|
private $caseSensitiveLocalPart;
|
|
|
|
|
|
|
|
public function __construct(array $services = self::ALL_SERVICES, bool $caseSensitiveLocalPart = false)
|
2016-09-10 01:41:21 +03:00
|
|
|
{
|
|
|
|
$this->services = $services;
|
2016-09-10 02:39:01 +03:00
|
|
|
$this->caseSensitiveLocalPart = $caseSensitiveLocalPart;
|
2016-09-10 01:41:21 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $email
|
|
|
|
* @return string
|
|
|
|
* @throws InvalidEmailException
|
|
|
|
*/
|
|
|
|
public function getPrimaryEmail(string $email)
|
|
|
|
{
|
|
|
|
$this->validateEmailAddress($email);
|
2016-09-10 02:39:01 +03:00
|
|
|
if (!$this->caseSensitiveLocalPart) {
|
|
|
|
$email = strtolower($email);
|
|
|
|
}
|
|
|
|
$domain = strtolower(explode('@', $email)[1]);
|
2016-09-10 01:41:21 +03:00
|
|
|
$result = $email;
|
|
|
|
|
|
|
|
foreach ($this->services as $serviceClass) {
|
|
|
|
/** @var ServiceInterface $service */
|
|
|
|
$service = new $serviceClass();
|
|
|
|
if ($service->isDomainSupported($domain)) {
|
|
|
|
$result = $service->getPrimaryEmail($result);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $email
|
|
|
|
* @throws InvalidEmailException
|
|
|
|
*/
|
|
|
|
private function validateEmailAddress(string $email)
|
|
|
|
{
|
|
|
|
if (filter_var($email, FILTER_VALIDATE_EMAIL) === false) {
|
|
|
|
throw new InvalidEmailException("Invalid email '{$email}'!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|