Ango-Hub SDK
Project description
Ango Hub Python SDK
A comprehensive Python SDK to interface programmatically with Ango Hub, iMerit's data annotation and AI training platform.
Overview
The iMerit-Ango SDK provides a powerful Python interface for interacting with Ango Hub, enabling you to:
- Manage Projects: Create, configure, and manage annotation projects
- Upload Data: Import assets from local storage, cloud storage (AWS S3, GCP, Azure), or URLs
- Handle Annotations: Import and export annotations in various formats (COCO, YOLO, KITTI, Ango native format)
- Workflow Management: Manage labeling workflows, batches, and task assignments
- Team Collaboration: Add team members, manage roles, and track performance
- Integration: Connect with your existing ML pipelines and data infrastructure
Installation
Install the latest version from PyPI:
pip install imerit-ango
To upgrade to the latest version:
pip install -U imerit-ango
Quick Start
1. Get Your API Key
First, obtain your API key from your Ango Hub account page:
- Navigate to your Account page in Ango Hub
- Go to the API tab
- Create a new API key or copy your existing key
2. Basic Usage
import os
from dotenv import load_dotenv
from imerit_ango.sdk import SDK
# Load environment variables
load_dotenv()
# Initialize SDK
sdk = SDK(api_key=os.getenv('API_KEY'))
# List your projects
projects = sdk.list_projects()
print(f"Found {len(projects)} projects")
# Get project details
project = sdk.get_project(project_id=os.getenv('PROJECT_ID'))
print(f"Project: {project['name']}")
SDK Functions Overview
Project-Level Functions
- Project Management:
create_project(),get_project(),list_projects() - Data Upload:
upload_files(),upload_files_cloud(),upload_chat_assets() - Batch Management:
create_batch(),assign_batches(),get_batches() - Task Management:
get_tasks(),assign_task(),requeue_tasks() - Annotations:
import_labels(),export(),exportV3() - Team:
add_members_to_project() - Performance:
get_metrics(),get_project_performance()
Organization-Level Functions
- Storage:
create_storage(),get_storages(),delete_storage() - Members:
invite_members_to_org(),get_organization_members() - Permissions:
update_organization_members_role()
Supported Asset Types
The SDK supports a wide variety of data types:
- Images: PNG, JPEG, TIFF, BMP, WebP
- Videos: MP4, AVI, MOV, WebM
- Medical: DICOM, NRRD files
- Documents: PDF, Markdown, HTML
- Text: Plain text, NER datasets
- 3D Data: Point clouds, multi-sensor fusion
- Audio: WAV, MP3, FLAC
- LLM: Chat conversations and responses
Documentation
Comprehensive Documentation
Full SDK documentation is available at: https://docs.imerit.net/sdk/sdk-documentation
Key Resources
Examples
Upload and Create a Labeling Project
# Create a new project
project = sdk.create_project(
organization_id=org_id,
name="My Annotation Project",
description="Object detection for autonomous vehicles"
)
# Upload images from local directory
sdk.upload_files(
project_id=project['_id'],
file_paths=['/path/to/images/*.jpg']
)
# Create batches for organized labeling
batch = sdk.create_batch(
project_id=project['_id'],
batch_name="Training Set Batch 1"
)
Export Annotations
# Export annotations in COCO format
export_result = sdk.export(
project_id=project_id,
export_format='COCO'
)
# Download the export
import requests
response = requests.get(export_result['downloadUrl'])
with open('annotations.json', 'wb') as f:
f.write(response.content)
Release Process
Releases are created from master only and are triggered by pushing a vX.Y.Z tag. Using an annotated tag is the recommended release command.
- Update the shared package version in
imerit_ango/version.py. - Merge that version change into
master. - Create an annotated release tag:
git tag -a v1.4.1 -m "Release v1.4.1"
- Push the tag to GitHub:
git push origin v1.4.1
When a vX.Y.Z tag is pushed, GitHub Actions verifies that the tagged commit is in master history and that the tag matches the shared version in imerit_ango/version.py. It then builds both Python packages, publishes them to PyPI, and creates GitHub Release notes.
Versioning
The canonical version lives in imerit_ango/version.py as __version__. Both setup_ango.py and setup_imerit_ango.py read from this file, so updating one place is enough. The tag version (without the leading v) must match __version__ exactly or the workflow will fail.
Deployment and Releasing
One-time setup
Before the first automated release you need to configure PyPI trusted publishing and the GitHub environment:
-
Create a
pypienvironment in GitHub. Go to the repository Settings > Environments and create an environment namedpypi. This is required by the publish job for OIDC token generation. -
Configure PyPI trusted publishing for
ango. On pypi.org, go to theangoproject settings (or create the project if it does not exist yet) and add a trusted publisher with:- PyPI project name:
ango - Owner:
imerit-io - Repository name:
ango-sdk - Workflow filename:
release.yml - Environment name:
pypi
- PyPI project name:
-
Configure PyPI trusted publishing for
imerit-ango. Repeat the same steps for theimerit-angoproject on PyPI:- PyPI project name:
imerit-ango - Owner:
imerit-io - Repository name:
ango-sdk - Workflow filename:
release.yml - Environment name:
pypi
- PyPI project name:
After this setup, pushing a vX.Y.Z tag to master will automatically publish both packages and create a GitHub Release.
Release checklist
- Update
imerit_ango/version.pywith the new version number. - Merge the version change into
master. - Create and push an annotated tag:
git tag -a v1.4.1 -m "Release v1.4.1" git push origin v1.4.1
- Monitor the GitHub Actions run. If the workflow fails on version mismatch or master-ancestry checks, delete the tag, fix the issue, and re-tag:
git push origin :refs/tags/v1.4.1 # delete the remote tag git tag -d v1.4.1 # delete the local tag
- Once the workflow succeeds, both
angoandimerit-angowill be live on PyPI and a GitHub Release will appear on the repository.
Support
- Documentation: https://docs.imerit.net
- Status Page: Ango Hub Status
- Customer Support: Available through your Ango Hub account
License
This SDK is provided by iMerit Technology Services for use with Ango Hub platform.
For the latest updates and detailed API reference, visit our complete documentation.
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 imerit_ango-1.4.0.tar.gz.
File metadata
- Download URL: imerit_ango-1.4.0.tar.gz
- Upload date:
- Size: 34.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
78e281c0d8fe6e2a39a4522ddb46974c1c213e1a0625a72e8ff71b9539b65f82
|
|
| MD5 |
8bc0c5e6d04ff0a3abf3e0a594f56a3d
|
|
| BLAKE2b-256 |
a2421f7fd0896a06cab1864b163e9d2183e8977c85cc536e81d7b8b3e19bc912
|
Provenance
The following attestation bundles were made for imerit_ango-1.4.0.tar.gz:
Publisher:
release.yml on imerit-io/ango-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
imerit_ango-1.4.0.tar.gz -
Subject digest:
78e281c0d8fe6e2a39a4522ddb46974c1c213e1a0625a72e8ff71b9539b65f82 - Sigstore transparency entry: 1591772930
- Sigstore integration time:
-
Permalink:
imerit-io/ango-sdk@20d72442163634a83c7a8de905548b42d48286ae -
Branch / Tag:
refs/tags/v1.4.0 - Owner: https://github.com/imerit-io
-
Access:
internal
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@20d72442163634a83c7a8de905548b42d48286ae -
Trigger Event:
push
-
Statement type:
File details
Details for the file imerit_ango-1.4.0-py3-none-any.whl.
File metadata
- Download URL: imerit_ango-1.4.0-py3-none-any.whl
- Upload date:
- Size: 35.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7cc5d26734a76101a4669ccd2d568b6386aa4ce787fc1958f2a19927ab9cc84a
|
|
| MD5 |
2a25449000bf100f5c491cbdf4406ac7
|
|
| BLAKE2b-256 |
c0aa025c3783382e01292cf220388c8bd75549b226c6bc95fda817e614a1ff74
|
Provenance
The following attestation bundles were made for imerit_ango-1.4.0-py3-none-any.whl:
Publisher:
release.yml on imerit-io/ango-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
imerit_ango-1.4.0-py3-none-any.whl -
Subject digest:
7cc5d26734a76101a4669ccd2d568b6386aa4ce787fc1958f2a19927ab9cc84a - Sigstore transparency entry: 1591773018
- Sigstore integration time:
-
Permalink:
imerit-io/ango-sdk@20d72442163634a83c7a8de905548b42d48286ae -
Branch / Tag:
refs/tags/v1.4.0 - Owner: https://github.com/imerit-io
-
Access:
internal
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@20d72442163634a83c7a8de905548b42d48286ae -
Trigger Event:
push
-
Statement type: