[StringHelper::class, 'trim']]); $required = new validators\RequiredValidator(); $required->message = E::EMAIL_REQUIRED; $length = new validators\StringValidator(); $length->max = 255; $length->tooLong = E::EMAIL_TOO_LONG; $email = new validators\EmailValidator(); $email->checkDNS = true; $email->enableIDN = true; $email->message = E::EMAIL_INVALID; $tempmail = new TempmailValidator(); $tempmail->message = E::EMAIL_IS_TEMPMAIL; $blacklist = new class extends Validator { public $hosts = [ 'seznam.cz', ]; protected function validateValue($value): ?array { $host = explode('@', $value)[1]; if (in_array($host, $this->hosts, true)) { return [E::EMAIL_HOST_IS_NOT_ALLOWED, []]; } return null; } }; $idnaDomain = new validators\FilterValidator(['filter' => function(string $value): string { [$name, $domain] = explode('@', $value); return idn_to_ascii($name, 0, INTL_IDNA_VARIANT_UTS46) . '@' . idn_to_ascii($domain, 0, INTL_IDNA_VARIANT_UTS46); }]); $unique = new validators\UniqueValidator(); $unique->message = E::EMAIL_NOT_AVAILABLE; $unique->targetClass = Account::class; $unique->targetAttribute = 'email'; if ($this->accountCallback !== null) { $unique->filter = function(QueryInterface $query): void { $query->andWhere(['NOT', ['id' => ($this->accountCallback)()]]); }; } $this->executeValidation($trim, $model, $attribute) && $this->executeValidation($required, $model, $attribute) && $this->executeValidation($length, $model, $attribute) && $this->executeValidation($email, $model, $attribute) && $this->executeValidation($tempmail, $model, $attribute) && $this->executeValidation($blacklist, $model, $attribute) && $this->executeValidation($idnaDomain, $model, $attribute) && $this->executeValidation($unique, $model, $attribute); } private function executeValidation(Validator $validator, Model $model, string $attribute): bool { $validator->validateAttribute($model, $attribute); return !$model->hasErrors($attribute); } }