Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jonathanhliu21/COM-Server
A simple API that interacts with serial ports
https://github.com/jonathanhliu21/COM-Server
flask pyserial python
Last synced: about 1 month ago
JSON representation
A simple API that interacts with serial ports
- Host: GitHub
- URL: https://github.com/jonathanhliu21/COM-Server
- Owner: jonathanhliu21
- License: mit
- Created: 2021-10-24T00:56:27.000Z (over 3 years ago)
- Default Branch: develop
- Last Pushed: 2022-02-28T18:11:46.000Z (almost 3 years ago)
- Last Synced: 2024-12-09T16:52:58.014Z (about 2 months ago)
- Topics: flask, pyserial, python
- Language: Python
- Homepage: https://com-server.readthedocs.io
- Size: 636 KB
- Stars: 4
- Watchers: 1
- Forks: 1
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# COM-Server
![GitHub Workflow Status](https://img.shields.io/github/workflow/status/jonyboi396825/COM-Server/Run%20Pytest%20(Push%20to%20master))
[![Documentation Status](https://readthedocs.org/projects/com-server/badge/?version=latest)](https://com-server.readthedocs.io/en/latest/?badge=latest)
![GitHub Workflow Status](https://img.shields.io/github/workflow/status/jonyboi396825/COM-Server/Upload%20Python%20Package?label=PyPI%20upload)
![PyPI](https://img.shields.io/pypi/v/com_server?label=Version)COM-Server is a Python library and a local web server that hosts an API locally and interacts with serial or COM ports. The Python library provides a different way of sending and receiving data from the serial port using a thread, and it also gives a set of tools that simplifies the task of manipulating data to and from the port. Additionally, the server makes it easier for other processes to communicate with the serial port.
The serial communication uses [pyserial](https://pyserial.readthedocs.io/en/latest/pyserial.html) as its back-end and the server uses [flask-restful](https://flask-restful.readthedocs.io/en/latest/quickstart.html) and [Flask](https://flask.palletsprojects.com/en/2.0.x/). Reading their documentations may help with developing with COM-Server.
**NOTE**: COM-Server is mainly tested on a Raspberry Pi connected to an Arduino UNO running Raspberry Pi OS Buster with Python 3.10.2. It has also been tested on:
OS | Version
---- | ----
Linux | Ubuntu 20.04 with Python 3.8.10
MacOS | Big Sur with Python 3.8.9
Windows | Windows 10 with Python 3.9.7, Windows 11 with Python 3.9.7It is likely that this library will not work for non-USB ports.
## Recommended use
COM-Server is **not** meant to be used like a normal JSON API, even though it uses Flask and Flask-restful. If there are many different devices accessing the endpoints at the same time, data will be backed up, since the serial communication is relatively slow and things cannot be sent to the serial device at the same time.The server is recommended to be used like a socket, and it should be used as a way for another process (should be only one; COM-Server has no implemented synchronization) on one computer (could be the same computer or another one on the same network) to communicate with the serial port via `pyserial` and this Python program.
## Installation
**NOTE**: COM-Server only works on Python >= 3.6.
Using [pip](https://pip.pypa.io/en/stable/getting-started/):
```sh
> pip install -U com-server
```For beta releases, use the `--pre` option:
```sh
> pip install --pre com-server
```## Quickstart
The examples below will start an API server that interacts with the port at http://0.0.0.0:8080
```py
# launches a server on http://0.0.0.0:8080from com_server import Connection, ConnectionRoutes, start_app
from com_server.api import V1
from flask import Flask
from flask_restful import Apiapp = Flask(__name__)
api = Api(app)conn = Connection(, "")
handler = ConnectionRoutes(conn)
V1(handler)start_app(app, api, handler)
```
Replace "<serport>" and "<baud>" with the serial port and baud rate.Alternatively, you can use the command line:
```sh
> com_server run
```
Again, replace "<serport>" and "<baud>" with the serial port and baud rate.## Links:
- Documentation: [https://com-server.readthedocs.io/en/latest/](https://com-server.readthedocs.io/en/latest/)
- Source code: https://github.com/jonyboi396825/COM-Server
- Issue tracker: https://github.com/jonyboi396825/COM-Server/issues
- Contributing: [https://github.com/jonyboi396825/COM-Server/blob/master/CONTRIBUTING.md](https://github.com/jonyboi396825/COM-Server/blob/master/CONTRIBUTING.md)
- Changelog: [https://github.com/jonyboi396825/COM-Server/blob/master/CHANGELOG.md](https://github.com/jonyboi396825/COM-Server/blob/master/CHANGELOG.md)