2017 © Pedro Peláez
 

library totp

Time-based One-time Password implementation for Nette framework

image

holabs/totp

Time-based One-time Password implementation for Nette framework

  • Monday, June 4, 2018
  • by holantomas
  • Repository
  • 1 Watchers
  • 0 Stars
  • 3 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

Holabs/TOTP

Implementation of RobThree/TwoFactorAuth for Nette Framework., (*1)

Installation

Requirements: - php 5.6+ - nette/application - nette/di - robthree/twofactorauth, (*2)

composer require holabs/totp

Configuration

extensions:
    holabs.totp: Holabs\TOTP\Bridges\Nette\TOTPExtension


holabs.totp:
    issuer: "AsIs"          # Will be displayed in the app as issuer name
    digits: 6               # The number of digits the resulting codes will be
    period: 30              # The number of seconds a code will be valid
    bits: 160               # The number of bits for encryption [recommended 80 or 160]
    discrepancy: 1          # The number of periods used to equal code from app
    algorythm: "sha1"       # The algorithm used [sha1, sha256, sha512, md5]
    qr:
        label: 'holabs'     # Required label for app
        provider: NULL      # QR-code provider [@see \RobThree\Auth\Providers\Qr\IQRCodeProvider]
    rng:
        provider: NULL      # Pseodo-random string provider [@see \RobThree\Auth\Providers\Rng\IRNGProvider]
    time:
        provider: NULL      # Time provider [@see \RobThree\Auth\Providers\Time\ITimeProvider]

You can choose your providers or use predefined., (*3)

Using

Your SignPresenter now can looks like this:, (*4)

<?php 

use Holabs\TOTP;
use Nette\Application\UI\Form;
use Nette\Utils\ArrayHash;

/**
 * @author       Tomáš Holan <mail@tomasholan.eu>
 * @package      holabs/totp
 * @copyright    Copyright © 2016, Tomáš Holan [www.tomasholan.cz]
 */
class SignPresenter extends BasePresenter
{

    /** @var TOTP @inject */
    public $totp;


    public function actionDefault() {
        if (!isset($_SESSION['totp'])) {
            // Store in Database or file is better
            // Every time you generate secret, your use have to delete old and add new in APP
            $_SESSION['totp'] = $this->totp->generateSecret();
        }

        $secret = $_SESSION['totp'];

        $this->template->qr = $this->totp->getQRUrl($secret);
        $this->template->secret = chunk_split($secret, 4, ' ');
        $this->template->status = '';
    }


    /**
     * Sign-up form factory.
     * @return Form
     */
    protected function createComponentSecondFactor()
    {
        $form = new Form();

        $form->addText('code', 'Code', 6)
            ->setRequired('Code is required');
        $form->addSubmit('submit', 'Send');

        $form->onSuccess[] = function ($form, ArrayHash $values) {
            if ($this->totp->verify($_SESSION['totp'], $values->code)) {
                $this->template->status = 'Code OK';
            } else {
                $this->template->status = 'Bad code';
            }
        };

        return $form;
    }
}
{block content}


Register by read QR

Or type code into APP, (*5)

{$secret}

Enter security code, (*6)

{control secondFactor}

{$status}, (*7)

The Versions

04/06 2018

dev-master

9999999-dev

Time-based One-time Password implementation for Nette framework

  Sources   Download

GPL-3.0 BSD-3-Clause GPL-2.0

The Requires

 

nette authenticator totp

04/06 2018

v0.1.0

0.1.0.0

Time-based One-time Password implementation for Nette framework

  Sources   Download

GPL-3.0 BSD-3-Clause GPL-2.0

The Requires

 

nette authenticator totp