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.7.tar.gz (11.4 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.7-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for duro_rest-0.0.7.tar.gz
Algorithm Hash digest
SHA256 fc1277becf0113e3916bc48dae48c779b7cd72b07edc511805e6b1a89425636d
MD5 9851db3fdf0d8508b8cb8f866135fe5b
BLAKE2b-256 8d2a4cc68be4710f63fe139d652d57028e377271c82ae0e05418b59a747bcd1d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: duro_rest-0.0.7-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-146-generic

File hashes

Hashes for duro_rest-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 d2f3e0c25ca26e11a762c01e4f8806e5592dc2b1f2f673868e00186595e85d0a
MD5 b6ffae1051dc4dbe232c7a99425e20b4
BLAKE2b-256 7937b271d6e4add1629a466d9cd2874d26701fafd48ff194e25e0bfdb84d8397

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