beastbytes/token

Token management library to generate and validate tokens

dev-master 2025-03-24 20:41 UTC

This package is auto-updated.

Last update: 2025-03-24 20:41:50 UTC


README

BeastBytes Token creates, manages, and validates time limited tokens.

Tokens can be used for a variety of purposes, such as:

  • Account verification
  • Email confirmation
  • Password reset

Requirements

  • PHP 8.1 or higher.

Installation

This package is installed when installing one of the token storage packages:

To install the package directly:

composer require beastbytes/token

or add the following to the 'require' section composer.json:

"beastbytes/token": "^1.0"

Implementation

Token makes no assumptions about the token format or the token storage. Token generation is performed by a TokenFactoryInterface instance (BeastBytes Token UUID4 creates UUID V4 tokens), and storage is performed by a TokenStorageInterface instance (BeastBytes Token PHP and BeastBytes Token Db provide storage implementations for PHP files and databases respectively).

TokenManager

TokenManager provides a simple interface for creating, retrieving, and deleting tokens; abstracting away the storage implementation.

Configuration

To use with Yii's dependency injection container, see the configuration section of the token storage and factory packages.

Token Types

Token types define the purpose of a token and its duration; token types are application specific and must be defined by the application. Token types are defined using an int backed enum that implements TokenTypeInterface; the enum name is the token type and the int value is the token duration in minutes. Each token type must have a unique duration.

Example TokenType enum:

enum TokenType: int implements TokenTypeInterface
{
    use TokenTypeTrait; // implements TokenTypeInterface
    
    case changePassword = 30;
    case confirmEmail = 15;
}

Usage

Take the case of a user account verification process. Once the user has registered their account, the application will raise an event that sends an email to the user; the email will contain a link that will verify that the user created the account.

Event handler

$token = $tokenManager->add(TokenType::verifyAccount, $currentUser->getId());
$email->send($currentUser, $token);

Verification action

On clicking the link in the email, the user is redirected to a page, and so action, that verifies the token; the token is typically a URL parameter.

public function actionVerifyAccount(
    #[RouteArgument('token')] string $tokenValue,
    TokenManager $tokenManager,
): ResponseInterface
{
    $token = $tokenManager->get($tokenValue);    
    
    if ($token instanceof Token) {    
        if ($token->isValid(TokenType::verifyAccount)) {
            $tokenManager->delete($token);
            
            $userId = $token->getUserId();
            // enable the user account
            
            // set success flash message
            return $this->redirect('/login');
        }
    
        // determine why the token is invalid
        $expired = $token->isExpired();
        if ($expired) {
            $tokenManager->delete($token);
            // set token expired flash message
        } else {    
            if (!$token->isType(TokenType::verifyAccount)) {
                // set wrong token type flash message
            }
        }
    } else {
        // set token does not exist flash message
    }
    
    return $this->redirect('/');      
}