62 Zeilen
1.7 KiB
PHP
62 Zeilen
1.7 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* This Software is the property of Data Development and is protected
|
||
|
* by copyright law - it is NOT Freeware.
|
||
|
* Any unauthorized use of this software without a valid license
|
||
|
* is a violation of the license agreement and will be prosecuted by
|
||
|
* civil and criminal law.
|
||
|
* http://www.shopmodule.com
|
||
|
*
|
||
|
* @copyright (C) D3 Data Development (Inh. Thomas Dartsch)
|
||
|
* @author D3 Data Development - Daniel Seifert <support@shopmodule.com>
|
||
|
* @link http://www.oxidmodule.com
|
||
|
*/
|
||
|
|
||
|
namespace D3\Totp\Application\Model;
|
||
|
|
||
|
use OxidEsales\Eshop\Core\DatabaseProvider;
|
||
|
use OxidEsales\Eshop\Core\Exception\DatabaseConnectionException;
|
||
|
use OxidEsales\Eshop\Core\Model\BaseModel;
|
||
|
use RandomLib\Factory;
|
||
|
use RandomLib\Generator;
|
||
|
|
||
|
class d3backupcode extends BaseModel
|
||
|
{
|
||
|
protected $_sCoreTable = 'd3totp_backupcodes';
|
||
|
|
||
|
/**
|
||
|
* @param $sUserId
|
||
|
* @return string
|
||
|
* @throws DatabaseConnectionException
|
||
|
*/
|
||
|
public function generateCode($sUserId)
|
||
|
{
|
||
|
$factory = new Factory();
|
||
|
$generator = $factory->getLowStrengthGenerator();
|
||
|
|
||
|
$sCode = $generator->generateString(6, Generator::CHAR_DIGITS);
|
||
|
$this->assign(
|
||
|
array(
|
||
|
'oxuserid' => $sUserId,
|
||
|
'backupcode' => $this->d3EncodeBC($sCode),
|
||
|
)
|
||
|
);
|
||
|
|
||
|
return $sCode;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param $code
|
||
|
* @return false|string
|
||
|
* @throws DatabaseConnectionException
|
||
|
*/
|
||
|
public function d3EncodeBC($code)
|
||
|
{
|
||
|
$oDb = DatabaseProvider::getDb();
|
||
|
$salt = $this->getUser()->getFieldData('oxpasssalt');
|
||
|
$sSelect = "SELECT BINARY MD5( CONCAT( " . $oDb->quote($code) . ", UNHEX( ".$oDb->quote($salt)." ) ) )";
|
||
|
|
||
|
return $oDb->getOne($sSelect);
|
||
|
}
|
||
|
}
|