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.1.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.1-py3-none-any.whl (239.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: unitelabs_sila-0.9.1.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.1.tar.gz
Algorithm Hash digest
SHA256 c4213559fb2ad746f3eb4057714d85f29f465e97a3e1d73da9d7511edd396852
MD5 9403b17173796f7180f0f3995547aa3e
BLAKE2b-256 bea026c7cb3a5d4308cf1b81d70b6f5e56f043082b73c13b8f225cc52aa14f73

See more details on using hashes here.

File details

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

File metadata

  • Download URL: unitelabs_sila-0.9.1-py3-none-any.whl
  • Upload date:
  • Size: 239.6 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b4f9cefd929261c309f32efff7fa32a2e99fa0110976fd5c90519dcc3c2bda3c
MD5 7835765f180a136b73d50d4cb1599720
BLAKE2b-256 b267545e1ede98192ffb9cc1b8d16a5891358d3c6fc3051161028fda0d07c85e

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