Trestle demonstration projects and content¤
Trestle has a number of demonstrations setup in the oscal-compass/compliance-trestle-demos repository which is intended to be a single point of call for demonstrations and content.
If you are interested in contributing a demonstration / content open a PR to the demonstration repo and a PR to this page.
Demonstrations, where practical, should include instructions on how they were created.
Current demonstrations¤
Simple sdk examples.¤
This folder contains a number of small examples for using the trestle OSCAL sdks.
arc42 architectural template enforcement using trestle author.¤
arc42 have created a set of open-source architecture documentation templates. This demonstration uses trestle author
to enforce use of the (modified) arc42 templates.
Trestle flask microservice demonstration.¤
trestle
uses a python library called pydantic to form the underlying OSCAL object models. flask-pydantic introduces a mechanism which integrates pydantic models into flask, providing automated user input validation in one line of code. This demo accepts a catalog as a POSTed object, throwing errors if the catalog does not meet the schema, and returns the catalog in the response. Find the demonstration here.
Creating a CIS controls catalog from an excel spreadsheet.¤
The Centre for Internet Security (CIS) produce a number of cross industry standards for IT security including their platform specific benchmarks and a suite of controls. This demo converts a spreadsheet of those controls into a a catalog and three profiles.
Creating an SSP using trestle author.¤
trestle author ssp-generate
and trestle author ssp-assemble
allow users to generate first a set of markdown documents to allow easy editing of control responses and second to reassemble that information up into an OSCAL ssp document. This is a 'baseline' demonstration with more sophisticated updates expected in the near term.
Trestle Repository API (trestle.core.repository
)¤
trestle.core.repository
is an API which abstracts users from the file system of a trestle repository. It provides a way for external developers to access a trestle repository without relying on presumptions (such as cwd being within the repository). Find the demo here.
Task examples¤
Convert a spreadsheet into a component-definition
¤
This demonstration shows how to use the trestle task xlsx-to-oscal-cd
functionality.
Convert a xccdf
result into a partial assessment-results
¤
This demonstration shows how to use the trestle task xccdf_result_to_oscal_ar
functionality.