/** * Test valid token without expiry time set * * @depends testValidTokenGenerationWithBasicFields * * @param Token $generatedToken Previously generated Token */ public function testIsValidFailOverused(Token $generatedToken) { $overusedToken = clone $generatedToken; $overusedToken->setUsesCount($generatedToken->getUsesMax() + 1); $this->assertFalse($this->tokenService->isValid($overusedToken), 'Overused Token passed validation'); }
/** * Check if the token can be used * * @param Token|null $token * * @return boolean */ public function isValid(Token $token = null) { if (!$token instanceof Token) { return false; } $currentTime = new \DateTime(); $expiryTime = $token->getExpiresAt(); return $token->isActive() && $token->getUsesCount() < $token->getUsesMax() && (!$expiryTime instanceof \DateTime || $expiryTime->getTimestamp() >= $currentTime->getTimestamp()); }