Skip to main content

Library with Python models derived from the page package world.opensemantic.lab

Project description

PyPI-Server Coveralls

opensemantic.lab

Python models and controllers for the world.opensemantic.lab page package.

Builds on opensemantic.base (DataToolController, TimeSeriesDatabaseController, archiving, typed read/write).

Overview

  • Auto-generated Pydantic models (v1 and v2): OpcUaServer, OpcUaDataChannel, LaboratoryProcess, Sample, Material, etc.
  • OpcUaServer controller - OPC UA client/server lifecycle with channel subscriptions and data archiving

OpcUaServer controller

Extends DataToolController with OPC UA protocol logic:

from opensemantic import compute_scoped_uuid
from opensemantic.lab.v1 import OpcUaServer, OpcUaDataChannel, OpcUaClientMode
from opensemantic.characteristics.quantitative.v1 import Temperature, Time, TimeUnit
from opensemantic.core.v1 import Label
from uuid import NAMESPACE_URL, uuid5

SERVER_UUID = uuid5(NAMESPACE_URL, "my-server")

server = OpcUaServer(
    uuid=SERVER_UUID,
    name="my_server",
    label=[Label(text="My Server")],
    url="opc.tcp://localhost:4840",
    data_channels=[
        OpcUaDataChannel(
            uuid=compute_scoped_uuid(SERVER_UUID, "ns=2;s=Temperature"),
            node_id="ns=2;s=Temperature",
            name="temperature",
            label=[Label(text="Temperature")],
            opcua_data_type="Float",
            client_mode=OpcUaClientMode.Subscription,
            sampling_interval=Time(value=100, unit=TimeUnit.milli_second),
            refresh_interval=Time(value=500, unit=TimeUnit.milli_second),
            characteristic=Temperature.get_cls_iri(),
        ),
    ],
    auto_archive=True,
)

OPC UA-specific methods

  • run_as_server(params) - start an OPC UA server with value callbacks
  • run_as_client(params) - connect, subscribe to channels, auto-archive
  • read_channel(params) / write_channel(params) - direct channel I/O
  • browse(params) - browse the OPC UA address space
  • stop() - flush archive buffer and disconnect

Channel UUIDs

OpcUaDataChannel requires an explicit UUID. Use compute_scoped_uuid(server_uuid, node_id) from opensemantic to avoid collisions across servers.

Controller fields (runtime only)

url, archive_database, auto_archive, reset_opcua_connection_on_error are controller-only fields. They are stripped from to_json() / to_jsonld() serialization. Set them as runtime config when constructing the controller.

Inherited features

All DataTool features from opensemantic.base work automatically: auto-archive from storage_locations, typed read/write, subobject ID prefixing, channel characteristic warnings. See the opensemantic.base README for details.

Examples

See examples/ for complete runnable examples:

  • opc_ua_server.py - define server, store to oold backend, run
  • opc_ua_client.py - load from backend, connect, print archived data
  • opcua_archiving.py - full workflow with auto-archiving and typed read/write

Installation

pip install opensemantic.lab             # models only
pip install opensemantic.lab[controller] # + asyncua, opensemantic.base[controller]

Testing

pytest tests/test_controller.py

Tests include OPC UA server/client integration (uses asyncua's built-in test server, no external services needed).

For PostgREST-based archiving tests, see the opensemantic.base testing docs - requires a running pgstack instance with TimescaleDB.

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

opensemantic_lab-0.7.0.post1000002003002.tar.gz (68.9 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file opensemantic_lab-0.7.0.post1000002003002.tar.gz.

File metadata

File hashes

Hashes for opensemantic_lab-0.7.0.post1000002003002.tar.gz
Algorithm Hash digest
SHA256 3b6c5509a2b443345d27bb3da02b5286bdb2d70f85da436bfd6b4449565eb406
MD5 7cf6f69569e50445f3cb922166d9fd22
BLAKE2b-256 5e7cb0b1a52f06487269d6924e183380a365b9f4ad65b1ca07b3f661a7f780c1

See more details on using hashes here.

File details

Details for the file opensemantic_lab-0.7.0.post1000002003002-py3-none-any.whl.

File metadata

File hashes

Hashes for opensemantic_lab-0.7.0.post1000002003002-py3-none-any.whl
Algorithm Hash digest
SHA256 61452177ad62d49690fd62d51a6b04d7a27cf2b68caff640ba45486e5ffa392b
MD5 757d640203512cf38a60f1466c8d3919
BLAKE2b-256 9b9b338a945378fa7d59954016b58402e7fdfd126981e5bd7c75010435f4fba8

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