Core library for FIWARE adpater agents based on EBC AgentLib.
Project description
juniconnlib
This python library serves as core library (hence the name juniconnlib_core)
towards connecting all different kinds of components to a FIWARE based
infrastructure. For an overview of related projects, that are build on top
of juniconnlib_core, take a look at related projects.
The library is built ontop of the framework
AgentLib developed by the EBC
and RWTH Aachen and extends the functionality for interacting with the
FIWARE platform components. The main components allow for:
- Device provisioning at the IoT-Agent (JSON)
- Entity provisioning at the Orion Context Broker
- Sending and receiving messages from the IoT-Agent (JSON) using MQTT
- Posting subscriptions to the Orion Context Broker
- Sending (HTTP) and receiving data (from subscriptions with MQTT notification) from the Orion Context Broker
- Working around JSON-Schema data models and creating devices and context entities from these
It contains various modules for device provisioning to FIWARE and data transfer between field devices and FIWARE.
Related Projects
juniconnlib_core serves as a base library for a multitude of other libraries. Most of the other projects work around the integration of different protocols and physical devices into the FIWARE architecture. Bundling everything that is necessary to communicate with FIWARE felt like a natural step, so related projects just need to implement use case specific functionality.
Notable related projects are:
- OPC UA Agent: A generalized protocol Adapter between OPC UA and FIWARE NGSIv2
- LoRaWAN Agent: A generalized protocol Adapter between LoRaWAN and FIWARE NGSIv2
- Messdas Agent: A protocol adapter, that integrates data from the commercial MESSDAS software into FIWARE NGSIv2
- And multiple other protocol converters (e.g. integration of different MODBUS devices into the FIWARE platform)
- FiLiP: A python API wrapper based on pydantic and requests for easy data validation a interaction with the FIWARE components
- FiDERe:
A library for parsing JSON schema data models that represent entities in
NGSIv2 normalized format, validating data and creating FiLiP compatible
ContextEntityandDeviceobjects.
Documentation
Documentation is available at
https://apps.fz-juelich.de/ice-1/ict-platform/juniconnlib-core and is
up-to-date with the most recent release. Building and publishing of the
documentation is done via CI/CD upon tag creation and commits to the master
branch.
In addition, you can find a complete demonstration of the intended usage of juniconnlib_core here
Installation
Clone the repository and into main directory and install juniconnlib as package using pip:
pip install .
Tests
Testing is done automatically on commit using CI/CD, including integration tests for most things. A dedicated FIWARE cluster is instantiated inside the pipeline for that.
If you want to run tests locally install the optional dependencies
pip install .[test]
and make sure the ENV variables are set correctly. You can find an example
in ./tests/.env_example. Finally, run using pytest
pytest test_*.py
A bit more special is Keycloak. The FIWARE cluster running during each
pipeline does not include a Keycloak for authentication (as it takes too
long to start up). Yet still integration tests for Keycloak are available,
besides the obvious mocked ones.
The integration tests for Keycloak are marked with keycloakintegrationtest
and if you don't have keycloak credentials or are not using authentication
at all you can skip these tests by just executing pytest without the
marker:
pytest -m "not keycloakintegrationtest"
As an alternative if you don't set a value for the environment variable
KEYCLOAK_URL the integration tests are skipped by default.
Below you can see an overview of the environment variables used for all the
integration test.
| Name | Default Value | Description |
|---|---|---|
OCB_NOAUTH_URL |
http://orion:1026 |
Orion Context Broker (unauthenticated) URL |
OCB_AUTH_URL |
http://orion:1026 |
Orion Context Broker (authenticated) URL |
IOTA_NOAUTH_URL |
http://iot-agent-json:4041 |
IoT Agent (unauthenticated) URL |
IOTA_AUTH_URL |
http://iot-agent-json:4041 |
IoT Agent (authenticated) URL |
NOAUTH_FIWARE_SERVICE |
test_service |
FIWARE service header for unauthenticated requests |
NOAUTH_FIWARE_SERVICEPATH |
/ |
FIWARE service path for unauthenticated requests |
AUTH_FIWARE_SERVICE |
test_auth_service |
FIWARE service header for authenticated requests |
AUTH_FIWARE_SERVICEPATH |
/ |
FIWARE service path for authenticated requests |
KEYCLOAK_URL |
None |
Keycloak server URL, if not defined keycloakintegrationtests are skipped |
KEYCLOAK_CREDENTIALS_FILE |
<repo-root>/configs/keycloak_credentials_file.json |
Path to Keycloak credentials JSON file (must contain "username" and "password") |
OCB_CLIENT_ID |
orion |
Keycloak client ID for Orion Context Broker |
IOTA_CLIENT_ID |
iot-agent |
Keycloak client ID for IoT Agent |
An example for how the content of the Keycloak credentials file should look
is found in ./tests/config/keycloak_credentials_file.json.
Contributing
Contributing to juniconnlib_core, and its related projects is highly appreciated. Contributions can take all kinds of forms, but in general everything should be done via this Repository or by contacting ice-1-fiware-admin@fz-juelich.de. If you are interested in using juniconnlib_core or its related project, feel free to reach out. In case of bugs or problems, don't be shy on raising issues or asking questions.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file juniconnlib_core-1.1.1.tar.gz.
File metadata
- Download URL: juniconnlib_core-1.1.1.tar.gz
- Upload date:
- Size: 54.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eca20bc20d0dab38d352df7c1bf6336d864c6b7867c5853783ae9c81e0afb54a
|
|
| MD5 |
5672d1b9152cc12e54f71145bc4399f1
|
|
| BLAKE2b-256 |
008ee367b9540748809fbd61ce5a17268dfd67a06a572729b075ca9d4d48abfc
|
File details
Details for the file juniconnlib_core-1.1.1-py3-none-any.whl.
File metadata
- Download URL: juniconnlib_core-1.1.1-py3-none-any.whl
- Upload date:
- Size: 61.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0eb8aca6358a956feb1b9d2c94756587a4bfeed1fb5b2eba1ad2ecb20d8f4829
|
|
| MD5 |
78d2ecacebda7e61a402f1e218f045da
|
|
| BLAKE2b-256 |
8ea1aa8425ceca6abc1c300f43460ec11c316acd152d428c9fa79c15c6419144
|