2017 © Pedro Peláez
 

library phplib

The Pushman.dfl.mn PHP Library

image

pushman/phplib

The Pushman.dfl.mn PHP Library

  • Tuesday, March 1, 2016
  • by Duffleman
  • Repository
  • 4 Watchers
  • 20 Stars
  • 416 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 3 Forks
  • 1 Open issues
  • 8 Versions
  • 0 % Grown

The README.md

pushman_php

The Pushman PHP Library, (*1)

Latest Stable Version Total Downloads Latest Unstable Version License, (*2)

Installation

composer require pushman/phplib

Usage

use Pushman\PHPLib\Pushman;
$pushman = new Pushman('private-key-goes-here');

$response = $pushman->push('kittens_are_cute', 'public', ['foo' => 'asdasdasdasd']);

As of version 2.1.0 in Pushman, you can push to multiple channels by feeding an array into the channels variable., (*3)

use Pushman\PHPLib\Pushman;
$pushman = new Pushman('private-key-goes-here');

$response = $pushman->push('kittens_are_cute', ['public', 'auth'], ['foo' => 'asdasdasdasd']);

On your own pushman instance:, (*4)

use Pushman\PHPLib\Pushman;
$pushman = new Pushman('private-key-goes-here, ['url' => 'http://pushman.yoursite.com']);

$response = $pushman->push('kittens_are_cute', 'public', ['foo' => 'asdasdasdasd']);

$response will always return a JSON payload with status and message along with any other relevant information about your event., (*5)

Extending Laravel

You can also extend Laravels event() functionality by including the Pushman ServiceProvider in your config/app.php file. Add the service provider Pushman\PHPLib\PushmanServiceProvider in your app.php file and then in your .env file, add the following keys:, (*6)

PUSHMAN_PRIVATE=60_char_private_token_here
PUSHMAN_URL=http://pushman.yoursite.com

Later in your config/broadcasting.php file, add in under connections the Pushman settings:, (*7)

'pushman' => [
    'driver'  => 'pushman',
    'private' => env('PUSHMAN_PRIVATE'),
    'url'     => env('PUSHMAN_URL'),
],

From that point onwards, you can use php artisan make:event {Name} to make a Laravel Event, inside that event implement ShouldBroadcast, and in your broadcastOn function, return an array of channels you want to broadcast on., (*8)

Example

php artisan make:event UserCreated - Called when a user is created., (*9)

$user = new User([
    'name' => 'James Duffleman',
    'email' => 'george@duffleman.co.uk',
    'password' => bcrypt('aPassword')
]);

event(new UserCreated($user));
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;

class UserCreated extends Event implements ShouldBroadcast {

    public $user;

    public function __construct($user)
    {
        $this->user = $user;
    }

    public function broadcastOn()
    {
        return ['public'];
    }
}

Getting Information

Because Pushman can generate your public token every 60 minutes, updating your clients should be an automatic process. You can use the following code to grab the public token of any channel., (*10)

use Pushman\PHPLib\Pushman;
$pushman = new Pushman('private-key-goes-here');

$response = $pushman->token('public');
$token = $response['token'];

And you can load all channel information by the channels() and channel() method., (*11)

use Pushman\PHPLib\Pushman;
$pushman = new Pushman('private-key-goes-here');

$response = $pushman->channel('auth');
$max_connections = $response['max_connections'];

$response = $pushman->channels();
foreach($response as $channel) {
    echo("Found channel {$channel['name']}.\n");
}

Todo for Future Versions

  • Add endpoint support for /api/subcribers.
  • Add some sort of trait/interface so you can append it to your existing user model and broadcast out easily to that specific user.

The Versions

01/03 2016

dev-master

9999999-dev

The Pushman.dfl.mn PHP Library

  Sources   Download

MIT

The Requires

 

by George Miller

07/06 2015

2.4

2.4.0.0

The Pushman.dfl.mn PHP Library

  Sources   Download

MIT

The Requires

 

The Development Requires

by George Miller

28/05 2015

2.3

2.3.0.0

The Pushman.dfl.mn PHP Library

  Sources   Download

MIT

The Requires

 

The Development Requires

by George Miller

25/05 2015

2.2

2.2.0.0

The Pushman.dfl.mn PHP Library

  Sources   Download

MIT

The Requires

 

The Development Requires

by George Miller

20/05 2015

2.1.1

2.1.1.0

The Pushman.dfl.mn PHP Library

  Sources   Download

MIT

The Requires

 

by George Miller

20/05 2015

2.1.0

2.1.0.0

The Pushman.dfl.mn PHP Library

  Sources   Download

MIT

The Requires

 

by George Miller

18/05 2015

2.0.0

2.0.0.0

The Pushman.dfl.mn PHP Library

  Sources   Download

MIT

The Requires

 

by George Miller

13/05 2015

1.0.0

1.0.0.0

The Pushman.dfl.mn PHP Library

  Sources   Download

MIT

The Requires

 

by George Miller