Skip to main content

Iotics gRPC client library

Project description

Iotics gRPC Python Client

A Python library for interacting with Iotics API.

Usage and Version Compatibility with Iotics host

iotics-grpc-client-py iotics-host
pip install iotics-grpc-client~=7.0 >= 7
pip install iotics-grpc-client~=6.0 >= 7
pip install iotics-grpc-client~=5.0 >= 6
pip install iotics-grpc-client~=4.0 >= 6
pip install iotics-grpc-client~=3.0 >= 6
pip install iotics-grpc-client~=2.0 >= 5
pip install iotics-grpc-client~=0.10.0 >= 4

Examples

Configuring identity

To run examples, either set up required environment variables or create an .env file with the following values. For more information on the meaning of these values and how to create them, consult identity-api-and-credentials

  • Required:

    • SPACE - Domain name of the IOTICSpace with which to communicate. The scheme can be omitted, eg. examplecorp. iotics.space
    • USER_DID - Identity of the user
    • AGENT_DID - Identity of the agent authorised to operate on the user's behalf
    • AGENT_KEY_NAME - secret value used to (re)create multiple key pairs
    • AGENT_NAME - registered identity name that can be used to e.g. identify public keys
    • AGENT_SECRET - secret value, the agent's private key
  • Optional:

    • DID_RESOLVER_URL - Where the database of identity documents is accessible, defaults to the one used by the given space.
    • TOKEN_TTL - How long in seconds auth tokens will last if not specified in the method call, defaults to 30

Running example scripts

Next, create and activate your virtual environment and run any of the scripts in the examples directory, e.g.:

make deps-py
. env/bin/activate
python examples/search_twin_models.py

FAQs

Installing on Raspberry PI get: Import error GLIBC_2.33 not found

If you see this error running the exmaples on a Rapberry PI, the current workaround is to install Ubuntu for RPi which has a later version of glibc.

ImportError: /lib/arm-linux-gnueabihf/libc.so.6: version 'GLIBC_2.33' not found (required by /home/pi/work/starting/iotics-grpc-client-py/env/lib/python3.9/site-packages/grpc/_cython/cygrpc.cpython-39-arm-linux-gnueabihf.so)

Contributing

Installing dependencies and generating gRPC client

  • To satisfy all dependencies, lint proto files and regenerate client files:

    make build
    
  • To generate gRPC Python files:

    make generate
    
  • To update the Iotics API version and regenerate client (proto files are submoduled in ./iotics-api.git/ from Iotics API repo):

    _ver=vX.X.X
    make GIT_TAG=$_ver deps-proto-update build
    # Address usages of the new client in `src`, update "Unreleased" section in CHANGELOG.md, then:
    git add CHANGELOG.md iotics-api.git src
    git commit -m "Update Iotics API to $_ver"
    # Push your branch and create a PR
    
  • Other make commands:

    • clean - remove artifacts created inside the project.
    • deps-* - install specific requirements if missing.
    • deps-*-update - update specific requirements when applicable.

PRs

Should contain a summary of the changes in CHANGELOG.md under the "Unreleased" section.

Versioning

This package adheres to Semantic Versioning

Releasing

  • Update package version in setup.cfg for the release:
  • Update CHANGELOG.md (move notes from unreleased section, ensure right tags are used, etc.) and any other files as needed.
  • Commit changes and create a PR.
  • Once PR is merged manually run the Create Draft Release GitHub Action, this will create a tag with the version in setup.py and create a draft release in releases.
  • Update the release's information and press the publish button on the release to publish it.
  • The Publish GitHub Action will create a package and will publish it to PyPI.

License

Copyright © 2024 IOTIC LABS LTD. info@iotics.com. All rights reserved. Licensed under the Apache License, Version 2.0. See LICENSE in the project root for license 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

iotics-grpc-client-7.2.0.tar.gz (69.3 kB view details)

Uploaded Source

Built Distribution

iotics_grpc_client-7.2.0-py3-none-any.whl (93.9 kB view details)

Uploaded Python 3

File details

Details for the file iotics-grpc-client-7.2.0.tar.gz.

File metadata

  • Download URL: iotics-grpc-client-7.2.0.tar.gz
  • Upload date:
  • Size: 69.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for iotics-grpc-client-7.2.0.tar.gz
Algorithm Hash digest
SHA256 8cac6ab98b1d11bf4df61b15fed182e847ea2c6bbce7851890fc98219c6fc786
MD5 fc57fb4c9c3060457cb822cc4626b6d2
BLAKE2b-256 283f41d54af9fb7e0314df6790892b52b1c7a2f0014a9f32a0068e8d5d209c25

See more details on using hashes here.

File details

Details for the file iotics_grpc_client-7.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for iotics_grpc_client-7.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f2b3da2b530e650acc71e64342c3eee88c828c76d1091ae9c9214119907f941b
MD5 9a5b045e8292850c30ef630d0b4cc794
BLAKE2b-256 14216a23ac25baadcae0467a285a9586842fe89ac895f1a7b13a768842851dd5

See more details on using hashes here.

Supported by

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