Asynchronous MQTT client for PHP based on swoole.
composer require try-to/swoole_mqtt
subscribe.php
<?php
use TrytoMqtt\Client;
require_once __DIR__ . '/vendor/autoload.php';
$options = [
    'clean_session' => false,
    'client_id' => 'demo-subscribe-123456',
    'username' => '',
    'password' => '',
];
$mqtt = new Client('127.0.0.1', 1883, $options);
$mqtt->onConnect = function ($mqtt) {
    $mqtt->subscribe('/World');
};
$mqtt->onMessage = function ($topic, $content) {
    var_dump($topic, $content);
};
$mqtt->onError = function ($exception) use ($mqtt) {
    echo "error\n";
    // $mqtt->reconnect(1000);
};
$mqtt->onClose = function () {
    echo "close\n";
};
$mqtt->connect();Run with command php subscribe.php
publish.php
<?php
use TrytoMqtt\Client;
require_once __DIR__ . '/../vendor/autoload.php';
$options = [
    'clean_session' => false,
    'client_id' => 'demo-publish-123456',
    'username' => '',
    'password' => '',
];
$mqtt = new Client('127.0.0.1', 1883, $options);
$mqtt->onConnect = function ($mqtt) {
    $mqtt->publish('/World', 'hello swoole mqtt');
};
$mqtt->onError = function ($exception) {
    echo "error\n";
};
$mqtt->onClose = function () {
    echo "close\n";
};
$mqtt->connect();Run with command php publish.php
- Client::__construct()
 - Client::connect()
 - Client::reconnect()
 - Client::publish()
 - Client::subscribe()
 - Client::unsubscribe()
 - Client::disconnect()
 - Client::close()
 - callback onConnect
 - callback onMessage
 - callback onError
 - callback onClose
 
- 
$hostService address. - 
$portport. - 
$optionsis the client connection options. Defaults:keepalive:50seconds, set to0to disableclient_id: client id, defaultswoole-mqtt-client-{$mt_rand}protocol_name:'MQTT'or 'MQIsdp'protocol_level:'MQTT'is4and 'MQIsdp' is3clean_session:true, set to false to receive QoS 1 and 2 messages while offlinereconnect_period:1second, interval between two reconnectionsconnect_timeout:30senconds, time to wait before a CONNACK is receivedusername: the username required by your broker, if anypassword: the password required by your broker, if anywill: a message that will sent by the broker automatically when the client disconnect badly. The format is:topic: the topic to publishcontent: the message to publishqos: the QoSretain: the retain flag
resubscribe: if connection is broken and reconnects, subscribed topics are automatically subscribed again (defaulttrue)bindtodefault '', used to specify the IP address that PHP will use to access the networkssldefaultfalse, it can be settrueorssl contextsee http://php.net/manual/en/context.ssl.phpdebugdefaultfalse, settrueto show debug info
 
Connect service  __construct($host, $port, $options).
Reconnect service  __construct($host, $port, $options).
Publish a message to a topic
$topicis the topic to publish to,String$messageis the message to publish,String$optionsis the options to publish with, including:qosQoS level,Number, default0retainretain flag,Boolean, defaultfalsedupmark as duplicate flag,Boolean, defaultfalse
$callback-function (\Exception $exception), fired when the QoS handling completes, or at the next tick if QoS 0. No error occurs then$exceptionwill be null.
Subscribe to a topic or topics
$topicis aStringtopic or anArraywhich has as keys the topic name and as value the QoS likearray('test1'=> 0, 'test2'=> 1)to subscribe.$optionsis the options to subscribe with, including:qosqos subscription level, default 0
$callback-function (\Exception $exception, array $granted)callback fired on suback where:exceptiona subscription error or an error that occurs when client is disconnectinggrantedis an array ofarray('topic' => 'qos', 'topic' => 'qos')where:topicis a subscribed to topicqosis the granted qos level on it
Unsubscribe from a topic or topics
$topicis aStringtopic or an array of topics to unsubscribe from$callback-function (\Exception $e), fired on unsuback. No error occurs then$exceptionwill be null..
Send DISCONNECT package to broker and close the client.
Close the client without DISCONNECT package.
Emitted on successful connection (CONNACK package received).
function (topic, message, packet) {}
Emitted when the client receives a publish packet
$topictopic of the received packet$contentpayload of the received packet$mqttClient instance.
Emitted when something wrong for example the client cannot connect broker.
Emitted when connection closed.