2023-08-02 14:46:20 +02:00
2023-08-02 12:13:04 +02:00
2023-08-02 12:09:33 +02:00
2023-08-02 14:43:40 +02:00
2023-08-02 12:09:33 +02:00
2023-08-02 12:06:19 +02:00
2023-08-02 12:13:04 +02:00
2023-08-02 12:06:19 +02:00
2023-08-02 12:06:23 +02:00
2023-08-02 12:06:19 +02:00
2023-08-02 14:46:20 +02:00

pydase (Python Data Service)

pydase is a Python library for creating data service servers with integrated web and RPC servers. It's designed to handle the management of data structures, automated tasks, and callbacks, and provides built-in functionality for serving data over different protocols.

Features

  • Integrated web and RPC servers
  • Automated task management
  • Event-based callback functionality for real-time updates
  • Built-in support for serving data over different protocols
  • Support for additional servers for specific use-cases

Installation

Install pydase using poetry:

poetry add git+https://github.com/tiqi-group/pydase.git

Usage

To use pydase, you will need to create a class that inherits from DataService. This class will be exposed via RPC (using rpyc) and a web server. The class can implement class / instance attributes and synchronous and asynchronous tasks.

Here's an example:

from pydase import DataService, Server
from pydase.components import NumberSlider

class Device(DataService):

    _current = 0.0
    _voltage = 0.0
    _power = False

    @property
    def current(self):
        # run code to get current
        return self._current

    @current.setter
    def current(self, value):
        # run code to set current
        self._current = value

    @property
    def voltage(self):
        # run code to get voltage
        return self._voltage

    @voltage.setter
    def voltage(self, value):
        # run code to set voltage
        self._voltage = value

    @property
    def power(self):
        # run code to get power state
        return self._power

    @power.setter
    def power(self, value):
        # run code to set power state
        self._power = value

    def reset(self):
        self.current = 0.0
        self.voltage = 0.0


if __name__ == "__main__":
    service = ServiceClass()
    Server(service).run()

Documentation

For more details about usage and features, see the full documentation.

Contributing

We welcome contributions! Please see CONTRIBUTING.md for details on how to contribute.

License

pydase is licensed under the MIT License.

Description
A Python library for creating remote control interfaces of Python objects.
Readme MIT 10 MiB
Languages
Python 81.9%
TypeScript 17.3%
HTML 0.4%
CSS 0.2%
JavaScript 0.2%