mackrauss / XMPPArduino

An XMPP client library for the Arduino platform.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Introduction

Arduino-XMPP is a simple write only XMPP client for the Arduino platform. It is based on https://github.com/adamvr/XMPPArduino but was changed for our purposes.

Dependencies

Arduino-XMPP depends on Arduino-Base64 (https://github.com/adamvr/arduino-base64). This should be included before XMPPClient.h or added to your main library directory.

Operation

Basic operation is as follows: 1. Create an XMPPClient instance specifying your XMPP server IP address and port. 2. Call connect on the XMPPClient interface, specifying your username, the server's host name, the resource name you wish to bind to and the your password. 3. If connect returns 1, you're good to go on. 4. Register your presence as available by calling sendPresence. 5. Send messages using sendMessage. 6. Close the connection and XMPP stream using close.

Limitations

This client library is somewhat restricted in what in can do. The major restrictions are as follows: 1. SASL-PLAIN authentication only 2. No SSL/TLS encryption on the stream 3. No ability to receive and interpret incoming messages

While the first one is on the two do list in some capacity, the first two are likely to never be rectified, due primarily to the SRAM restrictions of the Arduino

TODO:

  • Add some semblance of being able to receive messages
  • Simplify the dependency on Base64, put base64 directly in the Arduino-XMPP directory, perhaps.
  • Add the ability to connect using a complete jid, rather than the parts of one
  • Add the ability to send presence messages that aren't just 'I'm here'

About

An XMPP client library for the Arduino platform.


Languages

Language:C++ 88.6%Language:C 11.4%