Skip to main content

An API client for the Duro REST API

Project description

duro_rest

An API client for the Duro REST API.

Installation

Installing from PyPi

pip install duro_rest

Installing from conda-forge

TBD

Examples

The Duro client is a very minimal API client for reading data from the Duro v1 REST API. It does not define classes for each object type and instead returns plain dictionaries and lists.

Base Client

from duro_rest import Client

# Create a new client, providing your API key. By default clients will make calls to the public REST
# API, but the endpoint base can be overridden if needed
client = Client("your-api-key")

# Fetch a component by its Duro assigned id (as opposed to the CPN)
component = client.component("component-id")

# Fetch a list of all components in Duro
components = client.components()

# Fetch a list of all components in Duro filtered by status
components = client.components(status = "OBSOLETE")

BOM Client

The Duro API does not support pulling BOMs directly. The BOM Client is here to make that experience a little easier.

from duro_rest import BOMClient

# Create a new bom client for fetching full BOMs (either nested or flattened). It accepts the same
# arguments as the base client
client = Client("your-api-key")

# Get a nested BOM starting from a product
nested_product_bom = client.product_bom("product-id")

# Get a nested BOM starting from a component
nested_component_bom = client.component("component-id")

# Convert the nested BOM into flattened BOM
indented_product_bom = nested_product_bom.idented()

# Flattening will collapse rows for the same components together
flattened_product_bom = indented_product_bom.flatten()

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

duro_rest-0.0.11.tar.gz (11.5 kB view details)

Uploaded Source

Built Distribution

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

duro_rest-0.0.11-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file duro_rest-0.0.11.tar.gz.

File metadata

  • Download URL: duro_rest-0.0.11.tar.gz
  • Upload date:
  • Size: 11.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.8.10 Linux/5.4.0-153-generic

File hashes

Hashes for duro_rest-0.0.11.tar.gz
Algorithm Hash digest
SHA256 7b8de5643c1329abb3ba22f691e301a17055b4423e9771d429ed5cea1839be33
MD5 be643467f1b763d6fdec244018c47412
BLAKE2b-256 19de75c98a073a82ab5cd881d37d5027d19cdb0d6ee4d120c8a5c4ab29905692

See more details on using hashes here.

File details

Details for the file duro_rest-0.0.11-py3-none-any.whl.

File metadata

  • Download URL: duro_rest-0.0.11-py3-none-any.whl
  • Upload date:
  • Size: 12.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.8.10 Linux/5.4.0-153-generic

File hashes

Hashes for duro_rest-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 515df6eb20146f71a9cf5ced8f85577d172b904cc8ab3427c18588a9b05c4dae
MD5 60958fd3b4eff47e491fb5c1bf53c391
BLAKE2b-256 3bf5b3eba19eccddbd14de6079fd3577941d015cbcd56c59bbbd0ff82ea09f07

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