OSCAL Implementation Layer: Component Definition Model
| Component Schema | Component Converters | Reference | 
|---|---|---|
| JSON Schema | XML to JSON Converter (How do I use this?) | Outline Reference Index | 
| XML Schema | JSON to XML Converter (How do I use this?) | Outline Reference Index | 
Purpose
The OSCAL component definition model represents a description of the controls that are supported in a given implementation of a hardware, software, service, policy, process, procedure, or compliance artifact (e.g., FIPS 140-2 validation). The component definition model is part of the OSCAL implementation layer.
The component definition model allows grouping related components into capabilities, and documenting how the combination of components in a capability together can satisfy specific controls that are not fully satisfied by a single component on its own.
These component definitions can be used by organizations implementing the thing defined by a given component to provide a significant amount of implementation details needed when documenting a system's control implementation in a system security plan. This information can be used by the system security plan author as a starting point for their work, saving time and cost.
Authors and Consumers
Component Definition Authors
Component definitions are authored by vendors of products or services. The vendor can describe the product or service and align implementation settings with control baseline satisfaction.
Capability owners are similar to vendors, except they are typically "in-house". An organization may establish a capability for use by many of the organization's systems and publish a component definition document about the capability.
Policy process owners can publish component definition documents to document which controls are satisfied by the policy or process.
A standards body can publish a component definition document to indicate which controls are satisfied by the adoption of their standard.
Configuration checklist/guide authors can publish a component definition document to describe which controls are enabled by the configuration settings in their checklist.
Validation bodies, such as NIST Labs for FIPS 140-2 validation or Underwriters Laboratories for validation of electrical products, can publish a component definition about the validation they performed on a product.
Component Definition Consumers
As system owners identify components for use in their system, they consume component definition files by importing the relevant content into their system security plan.
Model Overview
An OSCAL component definition model is organized as follows:
- Metadata: Metadata syntax is identical and required in all OSCAL models. It includes information such as the document's title, publication version, publication date, and OSCAL version. Metadata is also used to define roles, parties (people, teams and organizations), and locations.
- Import: Identifies a component definition from another resource, from which related information is referenced.
- Component: Provides information about a defined component that can be part of an implemented system.
- Capability: Identifies a capability as a grouping of multiple components or capabilities.
- Back Matter: Back matter syntax is identical in all OSCAL models. It is used for attachments, citations, and embedded content such as graphics.
Key Concepts
The OSCAL component definition model represents a description of the controls that are supported in a given implementation of a hardware, software, service, policy, process, or procedure.
Each defined component describes where appropriate:
- Information about the organization that provides, develops, and manages the thing described by the component;
- Characteristics of the component, such as its name, version, model, last-modified date, etc.;
- Details about the controls that could be satisfied by the component;
- Configuration options for achieving specific security or privacy objectives; and
- Assessment tests or scripts that may be used to validate the component's implementation.
The component definition model allows grouping related components into capabilities, and documenting how the combination of components in a capability together can satisfy specific controls that are not fully satisfied by a single component on its own.
A component within a component definition can be used to document and share:
- proof of compliance for a security requirement for hardware or software, such as FIPS 140-2 validated cryptography,
- to document information about how a hardware, software, or service offering supports specific security or privacy controls, or
- demonstrate how a policy or procedure implements a given set of security or privacy controls.
The figure below expresses represents the portion of the OSCAL stack as it relates to an OSCAL Component Definition.
Important Note to Developers
Every time the content of an OSCAL file changes, the following must also change:
- A new UUID value must be generated and assigned to the root element's uuid.
- The last-modifiedfield in metadata must be assigned with the date and time at the moment the file is saved with the modified content.
These are two mechanisms by which tools can quickly "know" if a file has changed since it was last encountered. This document level UUID is the only UUID in OSCAL associated with version control.
When converting between formats, such as XML to JSON, these values should remain the same. This enables tools to know the content within the two formats is equivalent.
Modeling Validation Information
OSCAL is designed to allow capture relevant details related to independent validation of components. See the Validation Modeling tutorial for details.
Related Tutorials
The following tutorials are provided that are related to the component definition model.
- Creating a Component Definition: Covers creating a basic OSCAL component definition for a software product.
- Representing Test Validation Information: Explains how to represent test validation information (e.g., FIPS-140-2) for a component in an OSCAL component definition.
Content Examples
Multiple examples of component definitions expressed using the OSCAL component definitions model can be found in the OSCAL GitHub repository in XML, JSON, and YAML formats.