2017 © Pedro Peláez
 

library larainvite

Laravel Invitation package, existing users can invite others by email

image

junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  • Monday, July 2, 2018
  • by junaidnasir
  • Repository
  • 3 Watchers
  • 70 Stars
  • 6,233 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 16 Forks
  • 1 Open issues
  • 12 Versions
  • 23 % Grown

The README.md

Larainvite

Larainvite is a Laravel package that allows existing users to invite others via email., (*1)

It generates a one-time invitation code that can be sent as an invite link, and keeps track of the invitation status., (*2)

Latest Stable Version License Total Downloads Monthly Downloads, (*3)

  • v12 supports Laravel 12
  • v7 supports Laravel 11
  • v6 supports Laravel 10
  • v5 supports Laravel 9
  • v4 supports Laravel 8
  • v3 supports Laravel 5.8+, Laravel 6.0 and Laravel 7.0
  • v2 supports Laravel 5.0 to 5.8
  • v1 supports Laravel 4.*

Installation

Begin by installing the package through Composer. Run the following command in your terminal:, (*4)

composer require junaidnasir/larainvite

add the package service provider in the providers array in config/app.php:, (*5)

Junaidnasir\Larainvite\LaraInviteServiceProvider::class

you may add the facade access in the aliases array:, (*6)

'Invite'  => Junaidnasir\Larainvite\Facades\Invite::class

publish the migration and config file:, (*7)

php artisan vendor:publish --provider="Junaidnasir\Larainvite\LaraInviteServiceProvider"

migrate to create user_invitation table, (*8)

php artisan migrate

edit your User model to include larainviteTrait, (*9)

use Junaidnasir\Larainvite\InviteTrait;
class user ... {
    use InviteTrait;
}

Usage

You can use facade accessor to retrieve the package controller. Examples:, (*10)

$user = Auth::user();
//Invite::invite(EMAIL, REFERRAL_ID); 
$refCode = Invite::invite('email@address.com', $user->id);
//or 
//Invite::invite(EMAIL, REFERRAL_ID, EXPIRATION); 
$refCode = Invite::invite('email@address.com', $user->id, '2016-12-31 10:00:00');
//or
//Invite::invite(EMAIL, REFERRAL_ID, EXPIRATION, BEFORE_SAVE_CALLBACK); 
$refCode = Invite::invite($to, Auth::user()->id, Carbon::now()->addYear(1),
                      function(/* InvitationModel, see Configurations */ $invitation) use ($someValue) {
      $invitation->someParam = $someValue;
});

now create routes with refCode, when user access that route you can use following methods, (*11)

// Get route
$code = Request::input('code');
if( Invite::isValid($code))
{
    $invitation = Invite::get($code); //retrieve invitation modal
    $invited_email = $invitation->email;
    $referral_user = $invitation->user;

    // show signup form
} else {
    $status = Invite::status($code);
    // show error or show simple signup form
}

```php // Post route $code = Request::input('code'); $email = Request::input('signup_email'); if( Invite::isAllowed($code,$email) ){ // Register this user Invite::consume($code); } else { // either refCode is inavalid, or provided email was not invited against this refCode }, (*12)

with help of new trait you have access to invitations sent by user
```php
$user= User::find(1);
$invitations = $user->invitations;
$count = $user->invitations()->count();

Events

larainvite fires several events, (*13)

  • Junaidnasir\Larainvite\Events\Invited
  • Junaidnasir\Larainvite\Events\InvitationConsumed
  • Junaidnasir\Larainvite\Events\InvitedCanceled
  • Junaidnasir\Larainvite\Events\Expired

all of these events incloses invitation modal so you can listen to these events. include listener in EventServiceProvider.php, (*14)

use Junaidnasir\Larainvite\Events\Invited;
use App\Listeners\SendUserInvitationNotification;

protected $listen = [
    Invited::class => [
        SendUserInvitationNotification::class,
    ],
];

userInvite.php, (*15)

public function handle($invitation)
{
    \Mail::queue('invitations.emailBody', $invitation, function ($m) use ($invitation) {
            $m->from('From Address', 'Your App Name');
            $m->to($invitation->email);
            $m->subject("You have been invited by ". $invitation->user->name);
        });
}

Configurations

in config/larainvite.php you can set default expiration time in hours from current time., (*16)

'expires' => 48

you can also change user model to be used, in larainvite.php, (*17)

'UserModel' => 'App\User'

you can also change invitation model to be used, in larainvite.php, (*18)

'InvitationModel' => 'App\Invitation'

The Versions

02/07 2018

dev-master

9999999-dev https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

15/08 2017

v0.1.10

0.1.10.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

16/06 2017

v0.1.9

0.1.9.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

19/04 2017

v0.1.8

0.1.8.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

11/04 2016

v0.1.7

0.1.7.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

11/04 2016

v0.1.6

0.1.6.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

11/04 2016

v0.1.5

0.1.5.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

05/04 2016

v0.1.4

0.1.4.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

30/03 2016

v0.1.3

0.1.3.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

30/03 2016

v0.1.2

0.1.2.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

29/03 2016

v0.1.1

0.1.1.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite

29/03 2016

0.1.0

0.1.0.0 https://github.com/junaidnasir/larainvite

Laravel Invitation package, existing users can invite others by email

  Sources   Download

MIT

The Requires

 

The Development Requires

by Junaid Nasir

laravel invitations invite