@ko-developerhong/react-native-mqtt v1.0.3
react-native-mqtt
This library is used to communicate with the message broker using the MQTT protocol. This library is available in a React Native environment and supports TypeScript.
This library uses the following native MQTT client libraries:
Installation
To use this library, you must first install it using npm or yarn.
npm install @ko-developerhong/react-native-mqtt
# OR
yarn add @ko-developerhong/react-native-mqttIOS Setup
Add Podfile
pod "CocoaMQTT", :modular_headers => true
pod "MqttCocoaAsyncSocket", :modular_headers => trueImport
import MqttClient, { ConnectionOptions, ClientEvent, MQTTEventHandler } from 'react-native-mqtt';Connect
To connect to the message broker, use the connect method, which takes the host address and connection options as arguments.
import MqttClient, { ConnectionOptions } from 'react-native-mqtt';
const options: ConnectionOptions = {
  clientId: 'myClientId',
  cleanSession: true,
  keepAlive: 60,
  timeout: 60,
  maxInFlightMessages: 1,
  autoReconnect: true,
  username: 'myUsername',
  password: 'myPassword',
  tls: {
    caDer: Buffer.from('myCertificate'),
    cert: 'myCertificate',
    key: 'myKey',
    p12: Buffer.from('myP12'),
    pass: 'myPass',
  },
  allowUntrustedCA: true,
  enableSsl: true,
  protocol: 'mqtts',
};
MqttClient.connect('mqtt://broker.hivemq.com', options)
  .then(() => console.log('Connected'))
  .catch((error) => console.error('Connection failed: ', error));Subscribe
To subscribe to a specific topic, use the subscribe method.
type MQTT = {
  subscribe: (topic: string, qos?: number) => void;
};MqttClient.subscribe('myTopic', 0);Publish a message
To publish a message, use the publish method.
type MQTT = {
  publish: (topic: string, message: string, qos?: number , retained?: boolean) => void,
}MqttClient.publish('myTopic', 'Hello, World!', 0, false);Event Handler
This library offers a variety of events. To handle events, use the on, once, and off methods.
const onConnect: MQTTEventHandler<ClientEvent.Connect> = (reconnect) => {
  console.log('Connected', reconnect);
};
MqttClient.on(ClientEvent.Connect, onConnect);
MqttClient.once(ClientEvent.Disconnect, (cause) => {
  console.log('Disconnected', cause);
});
MqttClient.off(ClientEvent.Connect, onConnect);Disconnect
To disconnect, use the disconnect method.
MqttClient.disconnect();Close
To close the library, use the close method.
MqttClient.close();Troubleshooting
The Swift pod
CocoaMQTTdepends uponMqttCocoaAsyncSocket, which does not define modules.you may set `use_modular_headers!` globally in your Podfile, or specify `:modular_headers => true` for particular dependencies.
Contributing
See the contributing guide to learn how to contribute to the repository and the development workflow.
NOTE
- This library is available only in React Native environments.
 - This library supports TypeScript.
 - This library is used to communicate with the message broker using the MQTT protocol.
 - This library is based on react-native-mqtt.
 
License
MIT
Made with create-react-native-library
5 months ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago