Skip to main content

Python library to work with OpenEPD format

Project description

Python Library to work with OpenEPD format


This library is a Python library to work with OpenEPD format.

⚠️ Version Warning

This application is currently developed in two major versions in parallel:

  • v6.x (>=6.0.0) — Stable and production-ready. Maintains support for Pydantic v1 and v2 through a compatibility layer.
  • v7.x (>=7.0.0) — Public beta. Fully functional, with native support for Pydantic v2. Still experimental and may introduce breaking changes in internal and integration interfaces.

⚠️ No breaking changes are expected in the public standard or data model, only in internal APIs and integration points.

Both versions currently offer the same set of features.
We recommend using v6 for most production use cases as the more mature and stable option.
v7 is suitable for production environments that can tolerate some level of interface instability and want to adopt the latest internals.

💡 Only the latest version of v7 is guaranteed to contain all the features and updates from v6. Earlier v7 releases may lack some recent improvements.

Once v7 is promoted to stable, all earlier pre-stable (beta) v7 releases will be marked as yanked to prevent accidental usage in production.

About OpenEPD

openEPD is an open data format for passing digital third-party verified Environmental Product Declarations (EPDs) among Program Operators, EPD Databases, Life Cycle Analysis tools, design tools, reporting, and procurement.

Unlike print or PDF EPDs, openEPD provides a shared and precise format to express and refer to EPDs in ways that modern databases can use. openEPD can be used alongside a printable document, or can generate printable EPDs.

Unlike existing formats such as ILCD+EPD, it enforces a key set of guarantees for interoperable data processing,
including uniqueness of organizations/plants, precise PCR references, and dated version control.

The openEPD format is extensible. Standard extensions exist for concrete products, and for documenting supply-chain specific data.

Read More about OpenEPD format here.

Usage

Models

The library provides the Pydantic models for all the OpenEPD entities. The models are available in the openepd.models module. For mode details on the usage please refer to Pydantic documentation.

API Client

The library provides the API client to work with the OpenEPD API. The client is available in the openepd.client module. Currently, the only available implementation is based on synchronous requests library. Client provides the following features:

  • Error handling - depending on HTTP status code the client raises different exceptions allowing to handle errors in a more granular way.
  • Throttling - the client is able to throttle the requests to the API to avoid hitting the rate limits.
  • Retry - the client is able to retry the requests in case of the network errors.

API Client Usage

The following example illustrates the usage of the API client:

from openepd.api.sync_client import OpenEpdApiClientSync

# Setup the client
api_client = OpenEpdApiClientSync(
    "https://openepd.buildingtransparency.org/api",
    "<Your API Token>",
)

# Use API, e.g. get EPD by ID
epd = api_client.epds.get_by_openxpd_uuid("ec3b9j5t")

Bundle

Bundle is a format which allows to bundle multiple openEPD objects together (it might be EPDs, PCRs, Orgs + any other files which might be related to mentioned objects like pdf version of EPD, logo of the PCR company, etc).

Bundle consists of root-level and dependent objects. Dependents are objects which are referenced by root-level objects or related to the root-level objects. For example, EPD is a root-level object, PDF version of this EPD is a dependent, translated version of the same EPD is dependent as well.

The following example illustrates reading of the bundle file containing PCR and some of the related objects:

from openepd.bundle.reader import DefaultBundleReader
from openepd.bundle.model import AssetType, RelType

with DefaultBundleReader("test-bundle.epb") as reader:  # You could either file path or file-like object
    pcr = reader.get_first_root_asset(AssetType.Pcr)  # Get FIRST available root level PCR object. We consider that
    # there is only one PCR in the bundle
    # Read relative PDF file of the found PCR. `related_pdf` is a reference to the PDF file containing metadata only
    related_pdf = reader.get_first_relative_asset(pcr, RelType.Pdf)
    # We have to read the file content separately
    with reader.read_blob_asset(related_pdf) as f:
        pass  # Do something with the file content here

The next example illustrates the writing of the bundle file:

from openepd.bundle.writer import DefaultBundleWriter
from openepd.bundle.model import RelType
from openepd.model.pcr import Pcr

pcr_obj = Pcr(...)  # Let's assume we already have PCR object

with DefaultBundleWriter("my-bundle.epb") as writer, open("test-pcr.pdf", "rb") as pcr_pdf_file:
    # Add our PCR to the bundle. We do not specify any extra information, however you might what to add language
    # and a file name to make it look nicer in the bundle. If omitted the name will be generated automatically.
    pcr_asset = writer.write_object_asset(pcr_obj)
    # Now add related PDF document. We have to specify the content type, related (parent) object and the 
    # type of relation. Again, optionally you might want to specify the language and file name.
    writer.write_blob_asset(pcr_pdf_file, "application/pdf", pcr_asset, RelType.Pdf)

Model attribute access

OpenEPD extends its pydantic models with extra functionality: field descriptors can be accessed via dot notation from class name:

  • Usual pydantic way: TheModel().field["the_field"]
  • In openEPD: TheModel.the_field

Instances hold data as usual.

This behaviour is enabled by default. To disable, run the code with OPENEPD_DISABLE_PYDANTIC_PATCH set to true.

See src/openepd/patch_pydantic.py for details.

Generated enums

The geography and country enums are generated from several sources, including pycountry list of 2-character country codes, UN m49 codification, and special regions. To update the enums, first update any of these sources, then use make codegen. See 'tools/openepd/codegen' for details.

Development

Windows is not supported for development. You can use WSL2 with Ubuntu 20.04 or higher. Instructions are the same as for regular GNU/Linux installation.

Commit messages

Commit messages should follow Conventional Commit specification as we use automatic version with commitizen.

Credits

This library has been written and maintained by C-Change Labs.

License

This library is licensed under Apache 2. This means you are free to use it in commercial projects.

Project details


Release history Release notifications | RSS feed

This version

7.7.0

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

openepd-7.7.0.tar.gz (179.2 kB view details)

Uploaded Source

Built Distribution

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

openepd-7.7.0-py3-none-any.whl (290.4 kB view details)

Uploaded Python 3

File details

Details for the file openepd-7.7.0.tar.gz.

File metadata

  • Download URL: openepd-7.7.0.tar.gz
  • Upload date:
  • Size: 179.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.11.13 Linux/6.11.0-1015-azure

File hashes

Hashes for openepd-7.7.0.tar.gz
Algorithm Hash digest
SHA256 8eeae66d884ab79984690238c665fe4c430770ac63db9e96bc412a5fe5d5214f
MD5 beda9277bf804f0521592438373a01b5
BLAKE2b-256 5231734660c86168252688b032009d160ac53eac001c3efff4e753e63d6153c8

See more details on using hashes here.

File details

Details for the file openepd-7.7.0-py3-none-any.whl.

File metadata

  • Download URL: openepd-7.7.0-py3-none-any.whl
  • Upload date:
  • Size: 290.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.11.13 Linux/6.11.0-1015-azure

File hashes

Hashes for openepd-7.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 aff499bbb54c4e69a5fc1e7ad409c21dc4ed87b052651e87c43c642757f08543
MD5 46bc8a6249ab6eba9042da1c1a17ac15
BLAKE2b-256 b824dd211d2960a0edd43aa6f30efd106d9ea4dda67be2934bca2069efc25328

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