atournayre / confirmation-bundle
Confirmation bundle
Installs: 3 445
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=8.1
- doctrine/doctrine-bundle: ^2.7
- doctrine/orm: ^2.11
- symfony/config: 6.2.*
- symfony/dependency-injection: 6.2.*
- symfony/form: 6.2.*
- symfony/http-foundation: 6.2.*
- symfony/routing: 6.2.*
- symfony/uid: 6.2.*
- symfony/yaml: 6.2.*
- twig/twig: ^3.4
Requires (Dev)
- symfony/phpunit-bridge: 6.2.*
This package is auto-updated.
Last update: 2024-11-13 16:17:23 UTC
README
This bundle provide confirmation for entities.
Install
Composer
composer require atournayre/confirmation-bundle
Bundles
// config/bundles.php return [ // ... Atournayre\Bundle\ConfirmationBundle\AtournayreConfirmationBundle::class => ['all' => true], // ... ];
Configuration
Create file and copy content below.
# config/packages/atournayre_confirmation.yaml atournayre_confirmation: providers: # Example for an email provider # email: App\Provider\YourEmailProvider # Others providers can be anything : sms, pigeon...
Routing
Create file and copy content below.
# config/routes/atournayre_confirmation.yaml atournayre_confirmation: resource: "@AtournayreConfirmationBundle/Resources/config/routing.yaml"
Services
# config/services.yaml services: _instanceof: Atournayre\Bundle\ConfirmationBundle\Provider\AbstractProvider: tags: ['atournayre.confirmation_bundle.tag.provider'] Atournayre\Bundle\ConfirmationBundle\Controller\: resource: ../vendor/atournayre/confirmation-bundle/src/Controller public: true tags: ['controller.service_arguments'] Symfony\Component\DependencyInjection\ContainerInterface: '@service_container' Atournayre\Bundle\ConfirmationBundle\Service\ConfirmationCodeService: class: Atournayre\Bundle\ConfirmationBundle\Service\ConfirmationCodeService arguments: $container: '@service_container' Atournayre\Bundle\ConfirmationBundle\Repository\ConfirmationCodeRepository: class: Atournayre\Bundle\ConfirmationBundle\Repository\ConfirmationCodeRepository Atournayre\Bundle\ConfirmationBundle\Config\LoaderConfig: class: Atournayre\Bundle\ConfirmationBundle\Config\LoaderConfig Atournayre\Bundle\ConfirmationBundle\Service\GenerateConfirmationService: class: Atournayre\Bundle\ConfirmationBundle\Service\GenerateConfirmationService # Providers needs to be public App\Provider\YourCustomProvider: class: App\Provider\YourCustomProvider public: true
Usage
Configure entity
- Entity needs to implement
Atournayre\Bundle\ConfirmationBundle\Contracts\ConfirmableInterface
. - Add
Atournayre\Bundle\ConfirmationBundle\Traits\ConfirmableTrait
to your entity.
Create a provider
For each entity/mapping, you must :
- Create a provider
- It must extend from
Atournayre\Bundle\ConfirmationBundle\Provider\AbstractProvider
- You need to implement abstract methods
- You can override public methods
NOTE
It's discouraged to override
updateEntity()
.Prefer using
updateAfterConfirmation()
inside the entity to update it after confirmation (example: update status from 'pending' to 'valid').
Generate confirmation code
When you want to generate a confirmation code, just use Atournayre\Bundle\ConfirmationBundle\Service\GenerateConfirmationService
, call the __invoke()
method.
Following actions will be performed :
- A confirmation code will be generated
- Entity will be tagged as "unconfirmed"
- The recipient will be notified.
Tip : If you use both id and uuid in your entity, you can specify the id to use as 3rd parameter.
As code are required for verification purpose, the service only send it and don't return it.
Verify confirmation code
Verification can be performed using 2 ways :
- Direct link
- Form
Direct link
Using app_confirmation_code_with_code
route, the user only needs to follow the link and entity will be validated.
Form
Using app_confirmation_code
route, the user needs to fill-in a form with the code provided to him (via notification) so the entity could be validated.
Templating
It is possible to override any template thanks to Symfony.
Contributing
Of course, open source is fueled by everyone's ability to give just a little bit of their time for the greater good. If you'd like to see a feature or add some of your own happy words, awesome! Tou can request it - but creating a pull request is an even better way to get things done.
Either way, please feel comfortable submitting issues or pull requests: all contributions and questions are warmly appreciated :).