Skip to main content

Construct PROV-O compliant provenance graphs.

Project description

The package supports the creation of PROV-O compliant provenance graphs.

The package requires Python 3.11.

Installation

You can install the package from the Python Package Index (PyPI):

pip install provo

Contents

The package implements the PROV-O starting point classes Entity, Activity and Agent as Python classes with methods to establish starting point properties between them instances of these classes.

Features

The package’s objective is it to support the programmatical creation of provenance graphs that are compliant with the W3C Recommendation PROV-O: The PROV Ontology. Users of the package shall be enabled to tightly couple the generation of data with the generation of their provenance. As the package implements PROV-O, the created graph is exportable as an RDF document. Finally, the graph can be exported as a mermaid flowchart with some configuration options to adjust the style of the resulting chart.

Compliance

  • The PROV-O classes Entity, Activity, and Agent are implemented as Python classes.

  • The PROV-O properties wasGeneratedBy, wasDerivedFrom, wasAttributedTo, startedAtTime, used, wasInformedBy, endedAtTime, wasAssociatedWith, and actedOnBehalfOf are implemented as instance methods of their according classes.

  • Attributes that are passed to these methods are type-checked to enforce compliance with PROV-O.

  • Node Ids are checked for validity.

  • (Accidental) use of the same ID for different objects throws an error.

Ease of Use

  • The package implements full type hint support, thus enabling rich support from the IDE.

  • The classes Provence_Ontology_Graph, Entity, Activity, and Agent can be printed to terminal in a user-friendly, readable way with the default print() command.

  • For some quick testing, objects of the classes Entity, Activity, and Agent can be instantiated with auto-generated Ids (although it’s not recommended using this for production).

  • Export as [mermaid flowchart](https://mermaid-js.github.io/mermaid/#/flowchart) to review the graph visually.

Interface to RDF via the rdflib package

  • The graph’s contents can be converted to an rdflib.Graph object.

  • The graph can be exported in various RDF serializations.

Manual

https://github.com/rue-a/provo#manual

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

provo-1.0.0.tar.gz (28.5 kB view details)

Uploaded Source

Built Distribution

provo-1.0.0-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file provo-1.0.0.tar.gz.

File metadata

  • Download URL: provo-1.0.0.tar.gz
  • Upload date:
  • Size: 28.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.0

File hashes

Hashes for provo-1.0.0.tar.gz
Algorithm Hash digest
SHA256 d8aab3aaa05dbeafee9eecd262ae82d783df8d33aa9ac477f1524b9ed85bd196
MD5 8061db1a4a5b7bdca8f39600c5133404
BLAKE2b-256 cd13d4b1d949151dccb6c81345f40459d0dee49ba2b0ed6679606555b53244f7

See more details on using hashes here.

File details

Details for the file provo-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: provo-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 24.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.0

File hashes

Hashes for provo-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3610bdf178f60c1b058c63c0ba3188c79953cf9100f1ee2cd2e3bced3f1af8de
MD5 b5a14dae17bd5947920760c15e0b86c6
BLAKE2b-256 3dedd726b3bb134957a2500e535a66326c2287b66be078f9c140119e306ce8a7

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page