2017 © Pedro Peláez
 

silverstripe-vendormodule totp-authenticator

Enable 2FA authentication with TOTP

image

elliot-sawyer/totp-authenticator

Enable 2FA authentication with TOTP

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

The README.md

Code Coverage Scrutinizer Code Quality, (*1)

SilverStripe TOTP (Time-based One Time Password) Authenticator

This is a time-based token authenticator for SilverStripe. It allows users with apps such as Google Authenticator or Authy to generate a code to be used for logging into a SilverStripe installation. Backup codes are also available to the user, in case their second factor is lost, stolen, or otherwise unavailable., (*2)

This extends and builds from Firesphere's MFABootstrap module, and has been tested with a vanilla installation of CWP 2.0 and SilverStripe 4.1.1, (*3)

Supported Authenticators

It is difficult to support an exhaustive list of authenticator apps, but for the purposes of an initial release the following authenticators are supported., (*4)

  • Google Authenticator
  • Authy

If you know of any others that can be added to this list, raise a pull request along with any code and unit tests you've added to ensure support., (*5)

Installation

composer require elliot-sawyer/totp-authenticator, (*6)

Configuration

Add the following to config.yml, (*7)

SilverStripe\Security\Member:
  extensions:
    - ElliotSawyer\TOTPAuthenticator\MemberExtension

SilverStripe\Core\Injector\Injector:
  SilverStripe\Security\Security:
    properties:
      Authenticators:
        totpauthenticator: %$ElliotSawyer\TOTPAuthenticator\TOTPAuthenticator

Algorithms

Google Authenticator and Authy only support tokens generated with SHA-1. Other authenticators MAY implement SHA-256 or SHA-512 as outlined in RFC6238. You may use the Config API to adjust this algorithm if you need to support a specific TOTP authenticator, (*8)

ElliotSawyer\TOTPAuthenticator\TOTPAuthenticator:
  algorithm: 'sha512'

Usage

  1. Login to CMS as usual, taking care to use the "default" authenticator. Visit the Security admin and select your user. Ignore the TOTPSecret field for now. Tick the "MFA Enabled" and “Reset MFA codes” and save the Member.
  2. Take note of your backup tokens, as they can be used to log into your account if the authenticator is lost, stolen, or otherwise unavailable. These are stored encrypted in the database and are not recoverable. They must be reset if lost.
  3. Return to Main tab and reveal the “Second Factor Token Secret. Scan the QR code with Google Authenticator or Authy. Your website name ( as defined by Site title) and your username are visible at the end of Google Authenticator.
  4. Visit https://yoursite.local/Security/login/totpauthenticator to log in. You will be prompted for your second factor access code.

TODO

Please raise issues and feature requests at https://github.com/elliot-sawyer/totp-authenticator/issues, (*9)

The Versions

04/06 2018

dev-features/lang-en

dev-features/lang-en

Enable 2FA authentication with TOTP

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by elliot sawyer

authentication security module silverstripe 2-factor

04/06 2018

dev-features/configurable-algorithm

dev-features/configurable-algorithm

Enable 2FA authentication with TOTP

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by elliot sawyer

authentication security module silverstripe 2-factor

04/06 2018

dev-master

9999999-dev

Enable 2FA authentication with TOTP

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by elliot sawyer

authentication security module silverstripe 2-factor

16/02 2018

0.0.2

0.0.2.0

Enable 2FA authentication with TOTP

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by elliot sawyer

authentication security module silverstripe 2-factor

16/02 2018

0.0.1

0.0.1.0

Enable 2FA authentication with TOTP

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by elliot sawyer

authentication security module silverstripe 2-factor