Python SDK for Iconik's API
Project description
Pythonik
Pythonik is a comprehensive Python SDK designed for seamless interaction with the Iconik API. It offers a user-friendly interface to access various functionalities of Iconik, making it easier for developers to integrate and manage Iconik assets and metadata within their applications.
Features
- Easy-to-use methods for accessing Iconik assets and metadata.
- Robust handling of API authentication and requests.
- Configurable timeout settings for API interactions.
Installation
You can install Pythonik directly from PyPI:
pip install nsa-pythonik
If you're using Poetry:
poetry add nsa-pythonik
Usage
Get an Asset from Iconik
To retrieve an asset from Iconik, use the following code:
from pythonik.client import PythonikClient
from pythonik.models.assets.assets import Asset
from pythonik.models.base import Response
app_id = secrets.get_secret("app_id")
auth_token = secrets.get_secret("auth_token")
asset_id = secrets.get_secret("asset_id")
client: PythonikClient = PythonikClient(app_id=app_id, auth_token=auth_token, timeout=10)
res: Response = client.assets().get(asset_id)
data: Asset = res.data
data_as_dict = data.model_dump()
data_as_json = data.model_dump_json()
Get Metadata from a View
To get metadata for an asset from a specific view, use the following code:
from pythonik.client import PythonikClient
from pythonik.models.assets.metadata import ViewMetadata
from pythonik.models.base import Response
app_id = secrets.get_secret("app_id")
auth_token = secrets.get_secret("auth_token")
asset_id = 'a31sd2asdf123jasdfq134'
view_id = 'a12sl34s56asdf123jhas2'
client: PythonikClient = PythonikClient(app_id=app_id, auth_token=auth_token, timeout=5)
default_model = ViewMetadata()
# intercept_404 intercepts 404 errors if no metadata is found in view and returns a ViewMetadata model you provide so you can handle the error gracefully
res: Response = client.metadata().get_asset_metadata(asset_id, view_id, intercept_404=default_model)
data: ViewMetadata = res.data
data_as_dict = data.model_dump()
data_as_json = data.model_dump_json()
Checkout the API reference and advanced usage guide to see all you can do with Pythonik.
Publishing to PyPI (for maintainers) (Coming Soon)
To publish a new version to PyPI:
- Create and push a tag on the default branch (main):
git tag {tag} git push --tags
Using Poetry
This project uses Poetry for dependency management and packaging. Below are instructions on how to work with Poetry, create a Poetry shell, and run tests using pytest.
Setting Up Poetry
First, install Poetry if you haven't already:
Creating a Poetry Shell
To create and activate a Poetry shell, which sets up an isolated virtual environment for your project:
-
Navigate to your project directory.
-
Run the following command:
poetry shell
This command will activate a virtual environment managed by Poetry. You can now run Python commands and scripts within this environment.
Install all dependencies including pytest
poetry install
Running Tests with pytest
To run tests using pytest, follow these steps:
-
Inside the Poetry shell, run the tests with the following command:
pytest
This will discover and execute all the tests in your project.
By following these steps, you can efficiently manage dependencies, create a virtual environment, and run tests in your Python project using Poetry.
Support
For support, please contact NSA.
Roadmap
Details about upcoming features and enhancements will be added here.
Contributing
Please see the contribution guide for information on how to contribute.
Authors and Acknowledgment
This SDK is developed and maintained by North Shore Automation developers, including Brant Goddard, Prince Duepa, Giovann Wah, and Brandon Dedolph.
Contributors
License
License information will be available soon.
Project Status
Current project status and updates will be posted here.
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
File details
Details for the file nsa_pythonik-0.6.2.tar.gz
.
File metadata
- Download URL: nsa_pythonik-0.6.2.tar.gz
- Upload date:
- Size: 19.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.9.20 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1416748d34334f8a1a51b541e9f310e3ff859f52de7e34d411ace7374fce4c8d |
|
MD5 | 3229f3bbe85d351b7cda03e0ed935f33 |
|
BLAKE2b-256 | ff511e6aecbab43679ae9825d0371e8d362eda1aff9dc3417ce168d7b10e8710 |
File details
Details for the file nsa_pythonik-0.6.2-py3-none-any.whl
.
File metadata
- Download URL: nsa_pythonik-0.6.2-py3-none-any.whl
- Upload date:
- Size: 28.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.9.20 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 38ec2b87c01e81b177e442d3158c2c539da5d9842593b35aaff358b5ff49654a |
|
MD5 | 60716ef68b2e8d0bccf65a596febd695 |
|
BLAKE2b-256 | a383dd8bf53bb888a3b929950bad7d61352c554cfe0c35678e4cce63564a71c0 |