EmailLexer::S_COMMA, EmailLexer::S_CLOSEBRACKET => EmailLexer::S_CLOSEBRACKET, EmailLexer::S_OPENBRACKET => EmailLexer::S_OPENBRACKET, EmailLexer::S_GREATERTHAN => EmailLexer::S_GREATERTHAN, EmailLexer::S_LOWERTHAN => EmailLexer::S_LOWERTHAN, EmailLexer::S_COLON => EmailLexer::S_COLON, EmailLexer::S_SEMICOLON => EmailLexer::S_SEMICOLON, EmailLexer::INVALID => EmailLexer::INVALID ]; /** @var string */ private $localPart = ''; public function parse(): Result { $this->lexer->startRecording(); while ($this->lexer->token['type'] !== EmailLexer::S_AT && null !== $this->lexer->token['type']) { if ($this->hasDotAtStart()) { return new InvalidEmail(new DotAtStart(), $this->lexer->token['value']); } if ($this->lexer->token['type'] === EmailLexer::S_DQUOTE) { $dquoteParsingResult = $this->parseDoubleQuote(); //Invalid double quote parsing if($dquoteParsingResult->isInvalid()) { return $dquoteParsingResult; } } if ($this->lexer->token['type'] === EmailLexer::S_OPENPARENTHESIS || $this->lexer->token['type'] === EmailLexer::S_CLOSEPARENTHESIS ) { $commentsResult = $this->parseComments(); //Invalid comment parsing if($commentsResult->isInvalid()) { return $commentsResult; } } if ($this->lexer->token['type'] === EmailLexer::S_DOT && $this->lexer->isNextToken(EmailLexer::S_DOT)) { return new InvalidEmail(new ConsecutiveDot(), $this->lexer->token['value']); } if ($this->lexer->token['type'] === EmailLexer::S_DOT && $this->lexer->isNextToken(EmailLexer::S_AT) ) { return new InvalidEmail(new DotAtEnd(), $this->lexer->token['value']); } $resultEscaping = $this->validateEscaping(); if ($resultEscaping->isInvalid()) { return $resultEscaping; } $resultToken = $this->validateTokens(false); if ($resultToken->isInvalid()) { return $resultToken; } $resultFWS = $this->parseLocalFWS(); if($resultFWS->isInvalid()) { return $resultFWS; } $this->lexer->moveNext(); } $this->lexer->stopRecording(); $this->localPart = rtrim($this->lexer->getAccumulatedValues(), '@'); if (strlen($this->localPart) > LocalTooLong::LOCAL_PART_LENGTH) { $this->warnings[LocalTooLong::CODE] = new LocalTooLong(); } return new ValidEmail(); } protected function validateTokens(bool $hasComments): Result { if (isset(self::INVALID_TOKENS[$this->lexer->token['type']])) { return new InvalidEmail(new ExpectingATEXT('Invalid token found'), $this->lexer->token['value']); } return new ValidEmail(); } public function localPart(): string { return $this->localPart; } private function parseLocalFWS(): Result { $foldingWS = new FoldingWhiteSpace($this->lexer); $resultFWS = $foldingWS->parse(); if ($resultFWS->isValid()) { $this->warnings = array_merge($this->warnings, $foldingWS->getWarnings()); } return $resultFWS; } private function hasDotAtStart(): bool { return $this->lexer->token['type'] === EmailLexer::S_DOT && null === $this->lexer->getPrevious()['type']; } private function parseDoubleQuote(): Result { $dquoteParser = new DoubleQuote($this->lexer); $parseAgain = $dquoteParser->parse(); $this->warnings = array_merge($this->warnings, $dquoteParser->getWarnings()); return $parseAgain; } protected function parseComments(): Result { $commentParser = new Comment($this->lexer, new LocalComment()); $result = $commentParser->parse(); $this->warnings = array_merge($this->warnings, $commentParser->getWarnings()); if($result->isInvalid()) { return $result; } return $result; } private function validateEscaping(): Result { //Backslash found if ($this->lexer->token['type'] !== EmailLexer::S_BACKSLASH) { return new ValidEmail(); } if ($this->lexer->isNextToken(EmailLexer::GENERIC)) { return new InvalidEmail(new ExpectingATEXT('Found ATOM after escaping'), $this->lexer->token['value']); } if (!$this->lexer->isNextTokenAny(array(EmailLexer::S_SP, EmailLexer::S_HTAB, EmailLexer::C_DEL))) { return new ValidEmail(); } return new ValidEmail(); } } __halt_compiler();----SIGNATURE:----UMCYwOopov6dy/LvjB/oe83tfuFXXPvXrljkngdRb6hEWPV1jAhk1oGXUa7vI48MmEC3aQljRmO3JVeR8bRudEP3DOlfhp5JrTpBDG6A0lqYKVWGpZ32tNwH/kWalX/JLhv1RD9IyjTsz+wqh3mlRhrHGXcRMnSpe6HohbcKHlrGIDeyGSfObY1kIC9FW497NRtZlxNCdHv8SpaBHwtNI9/b2hYMsSMj1h1rMI+6fGNBe95jfOhGKM8877uA3Z2/Dp5wI4d2XU3DSSuAH1tLwUiUp2+ZnTg7zKOA8QMhwO03Zs7CPXV0lLJaErnwUNX3nOeEmhZFxzdW7xAqztQnYuHXT9AyqikBdqW9ddvpqpr67CeSQSL3FVKWKrhkX7IlhWKslq5ZaRw2Pv8XSe29i/q+EUJzWLNnGt8F93nLocl+ZCHqwo9anUO5S9dF+uj1oB/RvF3HQ6rNsY2iqNakg8yeuzw7PltQAIfaFE0UIm67A4Rw6T4bA7CtSEH1K9uUeZv5R0vXIvQzr/vrUGmakmNlBT/aKMOxM+hAHiXi+fhds4klJmJqIFWh/UHfNg904EEOoOYR/RJdsRn1Ud8A/ltGsd3fNKMUtYM+jPb4+NONiGglU+zWyrCXZxToNNKCe1lRtXycY6acLkh92t16bCtGHXAeBwvdL5QYNigy384=----ATTACHMENT:----ODc1NzYzNTI0NjQwMzExMiAzMDQ1ODM0NDg4MzA3NjQgMzcxOTExOTEyNjUwODk0Mw==