The OTP service is designed to manage OTPs (One Time Passwords) that can be used for authentication, confirmation or any other validation requirement for a user.
Process :
- The service generate an OTP and send it to the user,
- The user receives the OTP,
- The application retrieves the OTP from the user,
- The application verifies the OTP with the service.
The OTP is sent to the user by your own OtpSender service (e-mail, SMS, etc.).
PHP 8.2
Composer
for dependencies management (PHP)
composer install
use Phant\DataStructure\Key\Ssl as SslKey;
use Phant\Otp\Service\Request as Service;
use App\OtpRepository;
use App\OtpSender;
// Config
$otpRepository = new OtpRepository();
$otpSender = new OtpSender();
$sslKey = new SslKey($privateKey, $publicKey);
// Build service
$service = new Service(
$otpRepository,
$otpSender,
$sslKey
);
// OTP context transmitted to sender
$payload = [
'email' => '[email protected]',
];
$requestToken = $service->generate(
$payload
);
use Phant\Error\NotCompliant;
// Request token obtained previously
$requestToken = '...';
// Obtain Otp from user
$otp = '123456';
try {
$payload = $service->verify(
$requestToken,
$otp
);
} catch (NotCompliant $e) {
$numberOfAttemptsRemaining = $otpService->getNumberOfRemainingAttempts(
$requestToken
);
}