2017 © Pedro Peláez
 

library auth-easy

Easy Auth for User Meta Database Login Session Storage

image

apatis/auth-easy

Easy Auth for User Meta Database Login Session Storage

  • Friday, April 27, 2018
  • by apatis
  • Repository
  • 0 Watchers
  • 1 Stars
  • 24 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 5 Versions
  • 4 % Grown

The README.md

EASY AUTH

Easy Auth for User Meta Database Login Session Storage, (*1)

Small Notes

<?php
namespace ExampleApp;

use Apatis\Auth\Easy\AuthCookie;
use Apatis\Auth\Easy\SessionToken;

require __DIR__ . '/vendor/autoload.php';

/**
 * @var array $sessionDataFromDatabase meta
 * or get from (array) database->get(selector_from_database where username)
 */
$sessionDataFromDatabase = [];
$cookieExpiration        = strtotime('+1 year');
$secretKey               = 'secret';
$username                = 'username';
$password                = 'password';
$cookieName              = 'cookie_name_selector';
$sessionToken            = new SessionToken($sessionDataFromDatabase);
$authCookie              = new AuthCookie($secretKey, true);

/**
 * Token to save on session and for generated auth cookie
 */
$token = $sessionToken->create($cookieExpiration);
/**
 * Generated Cookie Values to set for cookies
 */
$cookieValue = $authCookie->generate(
    $username,
    $password,
    $cookieName,
    $token
);

if (setcookie($cookieName, $cookieValue, $cookieExpiration)) {
    // doing database save
    /**
     * Database->save(json_encode($sessionToken));
     * or just serialize t save as blob or safe value
     * Database->save(serialize($sessionToken));
     */
}

/**
 * To get Data from cookie
 */
$cookieStoredValues = isset($_COOKIE[$cookieName]) ? $_COOKIE[$cookieName] : null;
$isLogged = false;
if (is_string($cookieStoredValues)) {
    if (is_array($cookieToken = $authCookie->parse($cookieStoredValues))) {
        $generator = $authCookie->getGenerator();
        $username = $cookieToken[$generator::USERNAME_KEY];   
        // $token    = $cookieToken[$generator::TOKEN_KEY];
        // .... @see \Apatis\Auth\Easy\Generator::parse();
        // $userData = Database->getUserByUsername($username); << example
        /**
         * @var array $userData array detail 
         */
        if (!empty($userData)) {
            $tokenForSessionDB = $authCookie->validate(
                (string) $userData['username'],
                (string) $userData['password'],
                $cookieName,
                $cookieStoredValues
            );
            // $tokenForSessionDB is string
            if ($tokenForSessionDB !== false) {
                // @var bool $isLogged
                $isLogged =  $sessionToken->verify($tokenForSessionDB);
            }
        }
    }
}

if ($isLogged) {
    // do logged
}

LICENSE

MIT LICENSE, (*2)

The Versions

27/04 2018

dev-master

9999999-dev

Easy Auth for User Meta Database Login Session Storage

  Sources   Download

MIT

The Requires

  • php >=7.0
  • ext-openssl *

 

The Development Requires

27/04 2018

1.0.3

1.0.3.0

Easy Auth for User Meta Database Login Session Storage

  Sources   Download

MIT

The Requires

  • php >=7.0
  • ext-openssl *

 

The Development Requires

09/03 2018

1.0.2

1.0.2.0

Easy Auth for User Meta Database Login Session Storage

  Sources   Download

MIT

The Requires

  • php >=7.0
  • ext-openssl *

 

The Development Requires

20/02 2018

1.0.1

1.0.1.0

Easy Auth for User Meta Database Login Session Storage

  Sources   Download

MIT

The Requires

  • php >=7.0
  • ext-openssl *

 

The Development Requires

27/01 2018

1.0.0

1.0.0.0

Easy Auth for User Meta Database Login Session Storage

  Sources   Download

MIT

The Requires

  • php >=7.0
  • ext-openssl *

 

The Development Requires