# Unified communication for IoT clients [![license](https://img.shields.io/badge/License-MIT-brightgreen.svg?style=for-the-badge)](https://opensource.org/licenses/MIT) [![github](https://img.shields.io/badge/github-katyo/unicom-8da0cb.svg?style=for-the-badge&logo=github)](https://github.com/katyo/unicom) [![crates](https://img.shields.io/crates/v/unicom.svg?style=for-the-badge&color=fc8d62&logo=rust)](https://crates.io/crates/unicom) [![docs](https://img.shields.io/badge/docs.rs-unicom-66c2a5?style=for-the-badge&logo=)](https://docs.rs/unicom) [![status](https://img.shields.io/github/actions/workflow/status/katyo/unicom/ci.yml?branch=master&style=for-the-badge&logo=github-actions&logoColor=white)](https://github.com/katyo/unicom/actions?query=workflow%3ARust) The backends interface was introduced to support different connection methods. Each backend should provide the way to establish bidirectional connection for exchanging binary data with devices. **IMPORTANT NOTE**: Async runtime feature should be selected explicitly. ## Supported features * __futures__ Use [futures](https://docs.rs/futures/) only * __tokio__ Use [tokio](https://docs.rs/tokio/) runtime * __async-std__ Use [async-std](https://docs.rs/async-std/) runtime ## Built-in backends * _unicom-tcp_ TCP socket connection * _unicom-unix_ Unix-domain socket connection * _unicom-serial_ Serial port connection