Skip to main content

An un-opinionated SiLA 2 library.

Project description

Unitelabs SiLA Python Library

A Python library for creating SiLA 2 clients and servers. This flexible and unopinionated library gives you everything needed to create a SiLA 2 1.1 compliant Python application. It adheres to the SiLA 2 specification and is used by the UniteLabs CDK to enable rapid development of cloud-native SiLA Servers with a code-first approach.

Getting Started

Prerequisites

Ensure you have Python 3.9+ installed. You can install Python from python.org.

Quickstart

To get started quickly with your first connector, we recommend to use our UniteLabs CDK. Use Cookiecutter to create your project base on our Connector Factory starter template:

cookiecutter git@gitlab.com:unitelabs/cdk/connector-factory.git

Installation

Install the latest version of the library into your Python project:

pip install unitelabs-sila

Usage

Client

To start using the SiLA Python library as a client:

  1. Import and configure your SiLA client instance:

    import asyncio
    
    from sila.client import Client, ClientConfig
    
    async def main():
       client = Client(ClientConfig(hostname="localhost", port=50052, tls=False))
       await client.open()
    
       print(await client.get_server_name())
       print(await client.get_server_uuid())
    
       await client.close()
    
    asyncio.run(main())
    
  2. Run your server:

    $ python your_script.py
    

Server

To start using the SiLA Python library as a server:

  1. Import and configure your SiLA server instance:

    import asyncio
    
    from sila.server import Server
    from your_project.features import your_feature
    
    async def main():
        server = Server({"port": 50000})
        server.add_feature(your_feature)
        await server.start()
    
    asyncio.run(main())
    
  2. To implement a custom SiLA Feature, create a feature definition following the SiLA2 specification:

    from sila.server import Feature, UnobservableCommand
    
    your_feature = Feature(...)
    your_method = UnobservableCommand(...)
    your_method.add_to_feature(your_feature)
    
  3. Run your server:

    $ python your_script.py
    

Important: Without implementing the required SiLA Service Feature, your SiLA Server will not be fully compliant with the standard. For easier compliance, consider using the UniteLabs CDK, which handles this automatically.

Contribute

Submit and share your work!
https://hub.unitelabs.io

We encourage you to submit feature requests and bug reports through the GitLab issue system. Please include a clear description of the issue or feature you are proposing. If you have further questions, issues, or suggestions for improvement, don't hesitate to reach out to us at developers@unitelabs.io.

Join the conversation! Stay up to date with the latest developments by joining the Python channel in the SiLA Slack.

License

Distributed under the MIT License. See MIT license for more information.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

unitelabs_sila-0.9.0.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

unitelabs_sila-0.9.0-py3-none-any.whl (239.5 kB view details)

Uploaded Python 3

File details

Details for the file unitelabs_sila-0.9.0.tar.gz.

File metadata

  • Download URL: unitelabs_sila-0.9.0.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.17.0 {"ci":true,"cpu":"x86_64","distro":{"id":"trixie","libc":{"lib":"glibc","version":"2.41"},"name":"Debian GNU/Linux","version":"13"},"implementation":{"name":"CPython","version":"3.13.14"},"installer":{"name":"hatch","version":"1.17.0"},"openssl_version":"OpenSSL 3.5.6 7 Apr 2026","python":"3.13.14","system":{"name":"Linux","release":"5.15.154+"}} HTTPX2/2.4.0

File hashes

Hashes for unitelabs_sila-0.9.0.tar.gz
Algorithm Hash digest
SHA256 447c1214a003a529f30d110479f8a2864a187f7b2242937d39adc9ca4aac53a3
MD5 2d813de9faf605db2d48b6dccbe673c1
BLAKE2b-256 f3dfd748743552a5ed1ab36bce64995d4f6206f9e94ca915ed4cd9ddeeaac634

See more details on using hashes here.

File details

Details for the file unitelabs_sila-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: unitelabs_sila-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 239.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.17.0 {"ci":true,"cpu":"x86_64","distro":{"id":"trixie","libc":{"lib":"glibc","version":"2.41"},"name":"Debian GNU/Linux","version":"13"},"implementation":{"name":"CPython","version":"3.13.14"},"installer":{"name":"hatch","version":"1.17.0"},"openssl_version":"OpenSSL 3.5.6 7 Apr 2026","python":"3.13.14","system":{"name":"Linux","release":"5.15.154+"}} HTTPX2/2.4.0

File hashes

Hashes for unitelabs_sila-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e0c33e2188ab9f0a07e9c7574142af17705718ff1cdc5248d1c0edfbf68e739d
MD5 f0cd6b5e227bc4c16543a453d66a6394
BLAKE2b-256 f5b8cbe49e8bdf826904dd5a93e6a64698c8a17f1847459cf204df723e27fa73

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page