kevupton/referrals

Referral System for laravel

Installs: 408

Dependents: 0

Suggesters: 0

Security: 0

Stars: 6

Watchers: 1

Forks: 2

Open Issues: 0

Type:extension

1.2.5 2018-05-06 04:38 UTC

README

Laravel bare-bones implementation of a referral queue system. Currently the main functionality this package provides is the manipulation and creation of the referral queue.

How it works

This referral system is based of queue jumping. The idea being that when someone signs up they are placed into a queue. Then whenever someone registers, they jump X places in the queue. The idea behind the queue itself is that it is to slowly grow over a period of time, to simulate users signing up, and hence a demand. Or a queue to jump.

Config File

This file handles everything to do with the queue itself. A commend on each field is there explaining what each does.

<?php

return array(

    //prefix to each of the tables in the database
    'database_prefix' => 'ref_',

    //how many uses to pretend we have at the start.
    'start_at' => 1548,

    //the number of positions jumped when a referral is made.
    'jump_count' => 10,

    //How often to add an extra fake referral
    'addmore' => [
        'interval' => 3600, //the time between each insert
        'amount' => 1 //the amount to insert
    ]
);

The Jobs

This packages uses the Laravel Queue to manage the sign-up queue. It is broken into 2 key jobs. The first being AddMore and the second being MoveInQueue.

AddMore

This class handles adding more empty/fake subscribers to the queue itself. To use this class all you have to do is call it once. Once it has run the first time it will continuously keep adding itself back to the queue, with the interval time specified in referrals.addmore.interval. Every time it runs it adds referrals.addmore.amount subscribers to the queue.

Calling the job: $this->dispatch(new AddMore());

MoveInQueue

This class is responsible for moving a ReferQueue item to new position. It will move the queued_item to the new position and readjusting all the queued people in between.

Calling the job:

//just get the refer queue with id 200
$refer_queue = ReferQueue::find(200);

//get the new position
$new_pos = $ref_queue - ref_jumps();
if ($new_pos < 0) $new_pos = 0;

$this->dispatch(new MoveInQueue($refer_queue, $new_pos));

The Models

ReferQueue

This model represents a queued item. The refer_queue table is the pending queue for the system. So whenever someone refers someone this is the queue that they jump. The user_id in this class refers to the actual subscriber. So you just have to choose the id to use for this value, whether it is on the users table by default or a custom subscribers table; it will just refer to the primary key of whichever table you use.