Skip to content

trestle.core.parser

trestle.core.parser ¤

Model parsing for use when models themselves must be inferred and are not known.

Under most use cases trestle.core.base_model.OscalBaseModel provides functionality for loading Oscal models from files. However, under some circumstances the model internals are unknown. Use of this module should be avoided unless the BaseModel functionality is inadequate.

Attributes¤

logger = logging.getLogger(__name__) module-attribute ¤

Classes¤

Functions¤

parse_dict(data, model_name) ¤

Load a model from the data dict.

This functionality is provided for situations when the OSCAL data type is not known ahead of time. Here the model has been loaded into memory using json loads or similar and passed as a dict.

Parameters:

Name Type Description Default
data Dict[str, Any]

Oscal data loaded into memory as a dictionary with the root key removed.

required
model_name str

should be of the form 'module.class' from trestle.oscal.* modules

required

Returns:

Type Description
OscalBaseModel

The oscal model of the desired model.

Source code in trestle/core/parser.py
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
def parse_dict(data: Dict[str, Any], model_name: str) -> OscalBaseModel:
    """Load a model from the data dict.

    This functionality is provided for situations when the OSCAL data type is not known ahead of time. Here the model
    has been loaded into memory using json loads or similar and passed as a dict.

    Args:
        data: Oscal data loaded into memory as a dictionary with the `root key` removed.
        model_name: should be of the form 'module.class' from trestle.oscal.* modules

    Returns:
        The oscal model of the desired model.
    """
    if data is None:
        raise TrestleError('data name is required')

    if model_name is None:
        raise TrestleError('model_name is required')

    parts = model_name.split('.')
    class_name = parts.pop()
    module_name = '.'.join(parts)

    logger.debug(f'Loading class "{class_name}" from "{module_name}"')
    module = importlib.import_module(module_name)
    mclass: OscalBaseModel = getattr(module, class_name)
    if mclass is None:
        raise TrestleError(f'class "{class_name}" could not be found in "{module_name}"')

    instance = mclass.parse_obj(data)
    return instance

root_key(data) ¤

Find root model name in the data.

Source code in trestle/core/parser.py
67
68
69
70
71
72
def root_key(data: Dict[str, Any]) -> str:
    """Find root model name in the data."""
    if len(data.items()) == 1:
        return next(iter(data))

    raise TrestleError('data does not contain a root key')

to_full_model_name(root_key) ¤

Find model name from the root_key in the file.

Parameters:

Name Type Description Default
root_key str

root key such as 'system-security-plan' from a top level OSCAL model.

required
Source code in trestle/core/parser.py
75
76
77
78
79
80
81
82
83
84
85
86
87
def to_full_model_name(root_key: str) -> str:
    """
    Find model name from the root_key in the file.

    Args:
        root_key: root key such as 'system-security-plan' from a top level OSCAL model.
    """
    if root_key not in const.MODEL_TYPE_LIST:
        raise TrestleError(f'{root_key} is not a top level model name.')

    module = const.MODEL_TYPE_TO_MODEL_MODULE[root_key]
    class_name = alias_to_classname(root_key, AliasMode.JSON)
    return f'{module}.{class_name}'

handler: python