fivesqrd / una
该软件包最新版本(v0.2.2)没有可用的许可信息。
简单的PHP库,用于存储和发送OTP/2FA
v0.2.2
2020-02-17 06:00 UTC
Requires
- php: >=7.0.0
Requires (Dev)
- fivesqrd/bego: ^0.20.0
README
简单的PHP库,用于存储和发送OTP/2FA
创建OTP令牌
Use Una\Adapter;
/* Initialise the factory class with some defaults */
$factory = new Una\Factory([
'storage' => Adapter\Storage\BegoAdapter::instance([
'table' => 'My-Table',
'aws' => [
'region' => 'eu-west-1',
'credentials' => [
'key' => 'mykey',
'secret' => 'mysecret',
]
],
]),
'randomiser' => new Adapter\Randomiser\Numeric([
'length' => 5
]),
'hasher' => new Adapter\Hash\Password()
]);
/* Create a fresh token */
$token = $factory->create()
->ttl(86400)
->notify(function($secret) {
mail();
});
echo $token->raw();
echo $token->hashed();
指定令牌的有效载荷
$token = $factory->create()
->payload($userId)
->ttl(86400)
->notify(function($secret) {
mail();
});
具有复杂有效载荷的令牌
$token = $factory->create()
->payload([
'userId' => $userId,
'time' => time()
])
->ttl(86400)
->notify(function($secret) {
mail();
});
指定密钥
$token = $factory->create(12345)
->notify(function($secret) {
mail();
});
echo $token->raw(); //12345
echo $token->hashed();
指定自定义随机生成器。自定义生成器实现Una\Adapter\Randomisable接口。
use Una\Adapter\Randomiser\AlphaNumeric;
$token = $factory->create()
->randomise(new AlphaNumeric())
->notify(function($secret) {
mail();
});
echo $token->raw(); //random alphanumeric value
echo $token->hashed();
覆盖默认的ttl
use Una\Adapter\Randomiser\AlphaNumeric;
$token = $factory->create()
->ttl(86400) //24 hours
->notify(function($secret) {
mail();
});
echo $token->raw(); //random alphanumeric value
echo $token->hashed();
验证OTP令牌
try {
$tokens = $factory->fetch($userId, 'My-App');
/* Verify input against any valid tokens issued */
$tokens->verify($input);
/* Successful, invalidate all tokens immediately */
$tokens->invalidate();
return true;
} catch (Una\Exception\Storage)
return 'a usefull message';
} catch (Una\Exception\Notfound)
return 'a usefull message';
} catch (Una\Exception\Mismatch)
return 'a usefull message';
} catch (Una\Exception\TokenExpired)
return 'a usefull message';
}