alexgeno/phone-verification-bundle
最新稳定版本:v1.0.2
Composer 安装命令:
composer require alexgeno/phone-verification-bundle
包简介
A bundle for phone verification via the Symfony Notifier SMS channel. Any SMS service can be used as a sender. Redis or MongoDB can be used as a storage.
关键字:
README 文档
README
Signing in or signing up on a modern website or mobile app typically follows these steps:
- A user initiates verification by submitting a phone number
- The user receives an SMS or a call with a one-time password (OTP)
- The user completes verification by submitting the OTP
This library is built on top of alexeygeno/phone-verification-php and allows to set this up
Supported features
- Easy switching between different storages and SMS services
- Configurable length and expiration time for OTP
- Configurable rate limits
- Localization
- Usage with dependency injection and console commands
- Flex recipe for quick start
Requirements
- Symfony 6.x
- Any of the SMS services available in Symfony Notifier SMS Channel: symfony/vonage-notifier, symfony/twilio-notifier, symfony/message-bird-notifier and many more
- Any of the supported storages: snc/redis-bundle, doctrine/mongodb-odm-bundle
Installation
composer require alexgeno/phone-verification-bundle snc/redis-bundle predis/predis symfony/vonage-notifier
Note: Redis as a storage and Vonage as an SMS service are defaults in the configuration
Usage
Dependency injection
public function initiate(\AlexGeno\PhoneVerification\Manager\Initiator $manager) { $manager->initiate('+15417543010'); }
public function complete(\AlexGeno\PhoneVerification\Manager\Completer $manager) { $manager->complete('+15417543010', 1234); }
Console commands
bin/console phone-verification:initiate --to=+15417543010
bin/console phone-verification:complete --to=+15417543010 --otp=1234
Routes
curl -X POST localhost/phone-verification/initiate/+15417543010
{"ok":true,"message":"Sms has been sent. Check your Phone!"}
curl -X POST localhost/phone-verification/complete/+15417543010/1234
{"ok":true,"message":"The verification is done!"}
Configuration
The bundle will be automatically enabled and configured by a Flex recipe. In case you don't use Flex, see docs/CONFIGURATION.md on how to manually do it
Different storages and SMS services
To switch between available storages and SMS services, install the respective package and update the configuration. For example, to use Mongodb as a storage and Twilio as an SMS service:
composer require doctrine/mongodb-odm-bundle symfony/twilio-notifier
alex_geno_phone_verification: storage: driver: mongodb # ... sender: transport: twilio # ...
If the available options are not sufficient, you can add a custom storage (implementing \AlexGeno\PhoneVerification\Storage\I) or/and a sender (implementing \AlexGeno\PhoneVerification\Sender\I), and decorate the respective services (alex_geno_phone_verification.sender, alex_geno_phone_verification.storage) with them
Note: if you use Mongodb as a storage take a look at docs/MIGRATIONS.md
统计信息
- 总下载量: 68
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 7
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2023-09-14