Download the PHP package bfg/puller without Composer
On this page you can find all versions of the php package bfg/puller. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package puller
Puller (Long Pull)
Install
composer require bfg/puller
In a nutshell
This package is intended for cases when you need a minimum real time, but to raise the WebSocket too expensive or meaningless. The essence of the package is the simplest Long Pull, which is easy to install and configure. It added control over the user's tabs, which allows us to control the status of all the user tabs and send commands to all the user tabs at all, to all browsers. So, we have an excellent opportunity to follow the online meter and a real-time list of users.
Redis
Be careful, the package uses the default caching system by default,
with the driver that is listed there, but if you switch the caching
driver to redis
, then you will feel a significant increase in speed
and get a better and accurate task distribution system and online.
To do this, you should have the extension
Redis
forphp
.
Usage
In order to start using, you need to make a couple of simple things:
-
Make sure that in your
public/vendor
folder publishedpuller/puller.js
. He had to appear immediately after installing the package, as it broads publications in thelaravel-assets
group. If this did not happen and you did not appear there, publish it manually: -
Connect the script in your document:
-
Prepare your own document event listener:
- Submit the Puller command:
Further, in the browser, in the developer console, you will see the reaction.
Advanced puller
If you want the main processing and data from receiving data on the side of the task recipient, you must use that advanced
Pullers
, since thehandle
method is always performed on the recipient side.
Generate worker:
After that, you will have a class worker:
app/Pulls/MyTestPull.php
What will be described in the Handle method will be performed on the client
side when the task is performed. And the fact that this method will return,
will be sent as the details of the event. The event name will be generated
automatically or you can specify the protected ?string $name = "my_name";
property.
Prepare your own document event listener:
The name of the class-based event will be generated in
snake_case
,MyTestPull
will turn into amy_test_pull
.
Submit the Puller worker:
Further, in the browser, in the developer console, you will see the reaction.
Another example with the designer
app/Pulls/SayHelloPull.php
"stream" Dispatch to everyone tabs of selected user
Current authorized user So will always be installed by default, it is simply indicated by an example of a user transmission, you can pass as a model there and the identifier.
"flux" Dispatch to everyone online user
"flow" Dispatch to current tab (if exists)
"totab" Dispatch to selected tab
Create class with dot
Well be generated
dark_mode.toggle
name
Puller events
UserOnlineEvent
An event that triggers if the user appeared online.
UserOfflineEvent
The event that triggers in the case when the user is lost.
TestListenNewTab
An event that triggers in the case when the user opens a new tab.
Attention! If you reboot a tab, offline and online events will not work, since in fact you stay online if you need an event for each page load, understand that every time you restart the page it is believed that you create a new tab.
TestListenNewTab
The event that triggers in the case when the user closes the tab.
Puller facade
Get current process tab (read from header 'Puller-KeepAlive')
Create new anonymous task
Create new anonymous task with channel
Number of users online
List of users online
Is online user
List of user identifiers online
Short Event listener setters
Model watching
You can use helpers for listeners of model events.
The report will be sent to the user the identifier of which is called in this column that you indicated in the property
$owner_field
(may be an array with a list of several columns).
Move Zone
The area of liability movement, if the zone will be released inside the zone, the zone will fix it and posts the call to the mass control queue, and the general call may already delegate the type of shipment. Thus, we have mass control over tasks.
JavaScript
You have a globally registered Puller
object that is intended for external control.
Messaging
Messages
- this is a mechanism for performing tasks in a stream that distributes tasks to the current execution request and on the connections.
In order to use the messaging mechanism you should know the minimum data type specification.
What is a message on backend?
Message is a signed request for an event.
What to transmit the names of the events and
at the same time not to transmit its full
range of names, the system is looking for
nesting in any space that is compiled depending
on your security guard, the default is web
So your nesting prefix will be the next WebMessage
And all created and declared Events and will cause them
consistently if there will be several events in one name.
Event search occurs on the following pattern:
Send name:
my-event
ormy
;Called Event:
*
\WebMessage\MyEventSend name:
actions:my-event
oractions:my
;Called Event:
*
\WebMessageActions\MyEvent
*
- Maybe any value.
All events Puller
send from such an event will be inserted in
response to the request and the task will be distributed to what
a service station can be processed now and what needs to be
sent to others.
All transmitted values in the message will be added as a form to request.
View all events that can handle a message:
Plugins
Livewire support
https://github.com/bfg-s/puller-livewire
Alpine support
https://github.com/bfg-s/puller-alpine
Changelog
Please see CHANGELOG for more information what has changed recently.
Security
If you discover any security-related issues, please email [email protected] instead of using the issue tracker.
License
The MIT License (MIT). Please see License File for more information.