skitlabs/bayeux-client 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

skitlabs/bayeux-client

Composer 安装命令:

composer require skitlabs/bayeux-client

包简介

README 文档

README

This package provides a limited Bayeux client. Subscribe to any number of channels, wait for messages, dispatch a callback, rinse and repeat.

Installation

This package is installed through composer;

$  composer install skitlabs/bayeux-client

Requirements

  • PHP 8.1
  • Compatible HTTP-client (guzzlehttp/guzzle: ^7.4 or illuminate/http: ^9.8)

Usage

  1. Create a client by setting up a (HTTP) transport, and an Authentication provider.
  2. Subscribe to any number of channels
  3. Call start, and wait for the messages to roll in
<?php declare(strict_types=1);

require_once './vendor/autoload.php';

$bayeux = new \Skitlabs\Bayeux\Client\Bayeux(
    new \Skitlabs\Bayeux\Transport\TransportGuzzle(
        'https://organization.my.salesforce.com/cometd/54.0/',
        new \Skitlabs\Bayeux\Authentication\AuthenticationOAuthTokenGuzzle(
            'https://organization.my.salesforce.com',
            'clientId',
            'clientSecret',
            'username',
            'password',
        ),
    ),
);

$bayeux->subscribe('/data/ChangeEvents', static function (array $message) : void {
    var_dump($message);
})->start();

Logging

If you want to log all out- and incoming messages, wrap the Transport in the included TransportLogging-decorator.

<?php declare(strict_types=1);

require_once './vendor/autoload.php';

/** @var \Skitlabs\Bayeux\Transport\Transport $transport */
/** @var \Psr\Log\LoggerInterface $logging */

\Skitlabs\Bayeux\Transport\Decorator\TransportLogging::decorate($transport, $logging)

Laravel

Using Laravel, and don't want to depend on Guzzle directly?
Simply replace \Skitlabs\Bayeux\Transport\TransportGuzzle with \Skitlabs\Bayeux\Transport\TransportLaravelHttp and \Skitlabs\Bayeux\Authentication\AuthenticationOAuthTokenGuzzle with \Skitlabs\Bayeux\Authentication\AuthenticationOAuthTokenLaravelHttp.

Blocking

Note that, once start has been called, the script will continuously loop; until disconnected by the remote server. This means that the entire process is waiting for messages, and further execution is halted.

It is strongly recommended running start in a separate thread.

Resuming after disconnects

Once a disconnect occurs, script execution will continue beyond start. This client will never attempt to reconnect.
If you wish to automatically restart after a disconnect, consider setting up a watchman/supervisord process.

统计信息

  • 总下载量: 3.29k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: proprietary
  • 更新时间: 2022-04-14

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固