cleaniquecoders / inviteable
Built with Laravel Standalone Package Creator
Installs: 29
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 1
Open Issues: 3
pkg:composer/cleaniquecoders/inviteable
Requires
- php: >=7.3
- cleaniquecoders/blueprint-macro: ^1.0|^2.0|^3.0|4.0
- illuminate/support: ^5.5|^5.6|^5.7|^6.0|^7.0|^8.0
Requires (Dev)
- mockery/mockery: ^1.1
- orchestra/testbench: 3.5.*|3.6.*|3.7.*|4.*|5.*|6.*
- phpunit/phpunit: ^6.5|^7.0|^8.0|^9.0
This package is auto-updated.
Last update: 2022-03-01 00:24:08 UTC
README
About Your Package
Inviteable, inspired from Laravel Auth Invitations, but in this package, not for Auth, but for anything. Yes, we mean anything! Invitation to group, to class room, to meeting. Can be anything!
Installation
- In order to install cleaniquecoders/inviteablein your Laravel project, just run the composer require command from your terminal:
$ composer require cleaniquecoders/inviteable
- Then in your config/app.phpadd the following to the providers array:
CleaniqueCoders\Inviteable\InviteableServiceProvider::class,
- Run the migration file:
$ php artisan migrate
Usage
Inviteable provide a trait \CleaniqueCoders\Inviteable\Traits\HasInviteable.
Following are the sample usage.
Setup
use CleaniqueCoders\Inviteable\Traits\HasInviteable; class User extends Authenticatable { use HasInviteable; }
Creating Invitation
$invitation = User::create([
    'email'    => 'test@test.com',
    'name'     => 'Test Name',
    'password' => bcrypt('secret'),
])
    ->invitations()
    ->create([
        'name'       => 'Invitation',
        'token'      => str_random(64),
        'invited_by' => 1,
        'is_expired' => false,
        'expired_at' => \Carbon\Carbon::now()->addHours(24),
    ]);
Once you have create the invitation, you may use the invitation with events and notifications.
Will add dispatching event on invitation created, so you can extend the use of the invitation to something else like notification.
More sample usage using routes/console.php:
use App\User; Artisan::command('invite', function() { // create a user that will invite other person $invitor = factory(User::class)->create(); // to invite who $to_invite = factory(User::class)->create(); // login using invitor auth()->loginUsingId($invitor->id); // invite user to a class $to_invite->invitations()->create([ 'name' => 'Live Coding Class', 'token' => str_random(64), 'invited_by' => auth()->user()->id, 'is_expired' => false, 'expired_at' => \Carbon\Carbon::now()->addHours(24), ]); })->describe('Inivite the fastest way via cli.');
Event and Listener
- On Invitation Created - \CleaniqueCoders\Inviteable\Events\InvitationAccepted
- On Invitation Accepted - \CleaniqueCoders\Inviteable\Events\InvitationAlreadyAccepted
- On Invitation Already Accepted - \CleaniqueCoders\Inviteable\Events\InvitationCreated
Added Listener to send out e-mail invitation:
- CleaniqueCoders\Inviteable\Listeners\Invitations- You need to configure in your- app/Providers/EventServiceProviderto have this in your app.
/** * The event listener mappings for the application. * * @var array */ protected $listen = [ '\CleaniqueCoders\Inviteable\Events\InvitationCreated' => [ '\CleaniqueCoders\Inviteable\Listeners\Invitations\SendInvitationEmail', ], ];
Middleware
Added Middleware to be use to check only active invite able to get through
'inviteable' => \CleaniqueCoders\Inviteable\Http\Middleware\Inviteable::class,
Configuration
Added config/inviteable.php to handle redirection - using route name:
<?php return [ 'redirect' => [ 'accepted_token' => 'invitation.index', 'already_accepted_token' => 'invitation.index', 'middleware' => 'invitation.access_denied' ], ];
Route
Default route php artisan route:list --name=invitation consist of
- Activation invitation - on success, you will redirect to inviteable.redirect.accepted_tokenroute. You may overwrite this. In this route also handle already accepted invitation. Do specifyinviteable.redirect.already_accepted_tokenroute name to redirect to other page.
- Access denied route - You can change the redirect by specify route name in config.redirect.middleware
Views
Run php artisan vendor:publish --tag=inviteable to publish configuration and views for Inviteable.
Test
To run the test, type vendor/bin/phpunit in your terminal.
To have codes coverage, please ensure to install PHP XDebug then run the following command:
$ vendor/bin/phpunit -v --coverage-text --colors=never --stderr
Contributions
Everyone are welcome to contribute to this package. However, it's a good practice to provide:
- The problem you solved
- Provide test
- Documentation
Without these 3, you may add extra work for the maintainer.
License
This package is open-sourced software licensed under the MIT license.