-
Notifications
You must be signed in to change notification settings - Fork 77
Creating Prov output
SPADE includes support for sending all provenance metadata from its kernel to a single file in W3C PROV-N or W3C PROV-O format.
To do this, add the Prov storage before sending provenance metadata (by adding a SPADE reporter). The output
file's extension determines whether the serialization will be in PROV-N or PROV-O format.
For output in PROV-N format, to a file named /tmp/provenance
, use the .provn extension:
-> add storage Prov output=/tmp/provenance.provn
Adding storage Prov... done
For output in PROV-O format, to a file named /tmp/provenance
, use the .ttl extension:
-> add storage Prov output=/tmp/provenance.ttl
Adding storage Prov... done
At this point, PROV metadata sent to the kernel will result in corresponding elements in the /tmp/provenance.provn
or /tmp/provenance.ttl
file. (Note that the file will be overwritten if it already existed.)
To specify that a SPADE reporter's annotation keys are drawn from a particular namespace, the prefix and RDF schema can be provided. For example, the namespace prefix audit
can be defined to correspond to the RDF schema https://spade.csl.sri.com/rdf/audit.rdfs
:
add storage Prov output=/tmp/provenance.ttl audit=http://spade.csl.sri.com/rdf/audit.rdfs
Adding storage Prov... done
Note: The namespace prefixes prov
and data
are reserved and cannot be specified.
To stop further provenance metadata from being sent to the file, the Prov storage can be removed:
-> remove storage Prov
Shutting down storage Prov... done
Note: Only PROV elements are emitted. To translate OPM into a PROV embedding, use the OPM2PROV filter:
add filter OPM2PROV 0
Adding filter OPM2PROV... done
This material is based upon work supported by the National Science Foundation under Grants OCI-0722068, IIS-1116414, and ACI-1547467. Any opinions, findings, and conclusions or recommendations expressed in this material are those of the author(s) and do not necessarily reflect the views of the National Science Foundation.
- Setting up SPADE
- Storing provenance
-
Collecting provenance
- Across the operating system
- Limiting collection to a part of the filesystem
- From an external application
- With compile-time instrumentation
- Using the reporting API
- Of transactions in the Bitcoin blockchain
- Filtering provenance
- Viewing provenance
-
Querying SPADE
- Illustrative example
- Transforming query responses
- Protecting query responses
- Miscellaneous