cethyworks / invitation-bundle
Provides a way to secure routes behind a special 'invitation code only' security firewall.
Installs: 205
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=5.6.17
- symfony/config: ^3.3
- symfony/dependency-injection: ^3.3
- symfony/http-kernel: ^3.3
- symfony/routing: ^3.3
- symfony/security: ^3.3
- symfony/security-bundle: ^3.3
- symfony/security-guard: ^3.3
Requires (Dev)
- doctrine/common: ^2.7
- doctrine/doctrine-bundle: ^1.6.8
- phpunit/phpunit: ^4.8
- symfony/expression-language: ^3.3
This package is not auto-updated.
Last update: 2024-11-16 15:56:06 UTC
README
Provides a way to secure routes behind a special "invitation code only" security firewall.
Install
1. Composer require
$ composer require cethyworks/invitation-bundle
2. Register bundles
// AppKernel.php
class AppKernel extends Kernel
{
public function registerBundles()
{
$bundles = [
// ...
new Cethyworks\InvitationBundle\CethyworksInvitationBundle(),
];
// ...
How to use
Invitation codes in memory
1. Update security.yml
to add the invitation provider, invitations and firewall :
security:
# ...
providers:
in_memory_invitation_provider:
invitation_memory:
invitations:
- { code: foo }
- { code: bar }
# ...
firewalls:
# ...
invitation:
pattern: ^/invite-only-url
provider: in_memory_invitation_provider
guard:
authenticator:
cethyworks_invitation.authenticator
anonymous: false
# ...
4. Go to /invite-only-url?code=foo
. That's it.
To use emails with in memory provider :
1. Update config.yml
:
cethyworks_invitation:
invitation_class: Cethyworks\InvitationBundle\Model\Invitation
2. Update security.yml
:
security:
# ...
providers:
in_memory_invitation_provider:
invitation_memory:
invitations:
- { code: foo, email: foo@email.foo }
- { code: bar, email: bar@email.bar }
# ...
Invitation codes in database
1. Extends Cethyworks\InvitationBundle\Model\Invitation
to persit it :
<?php
namespace AppBundle\Entity;
use Cethyworks\InvitationBundle\Model\GenerateCodeTrait;
use Cethyworks\InvitationBundle\Model\Invitation as BaseInvitation;
use Doctrine\ORM\Mapping as ORM;
/**
* Invitation
*
* @ORM\Table()
* @ORM\Entity()
*/
class Invitation extends BaseInvitation
{
// optional, provides a shortcut to generate random code
use GenerateCodeTrait;
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* Invitation constructor.
*/
public function __construct()
{
$this->generateCode();
}
}
2. Update config.yml
with the new Invitation
class :
cethyworks_invitation:
invitation_class: AppBundle\Entity\Invitation
3. Update security.yml
to add the invitation provider and firewall :
security:
# ...
providers:
cethyworks_invitation_entity_provider:
invitation_entity: ~
# entity_property: 'code'
# repository_method: 'findOneBy'
# manager_name: null
# ...
firewalls:
# ...
invitation:
pattern: ^/invite-only-url
provider: cethyworks_invitation_entity_provider
guard:
authenticator:
cethyworks_invitation.authenticator
anonymous: false
# ...
4. Go to /invite-only-url?code=some_code
. That's it.
Todo
- handle failure (redirection ?)
- showcase repository
- plugins :
- attach invitation to user
- form to manually set invitation code
- consumeable
- send invitation