Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Inventory - OS or Software Version #1036

Open
10 of 15 tasks
Rene2mt opened this issue Dec 24, 2024 · 5 comments · Fixed by #1039
Open
10 of 15 tasks

Inventory - OS or Software Version #1036

Rene2mt opened this issue Dec 24, 2024 · 5 comments · Fixed by #1039
Assignees
Labels

Comments

@Rene2mt
Copy link
Member

Rene2mt commented Dec 24, 2024

Constraint Task

Consistent with issue #813, this work focuses on ensuring every inventory items has a "os-version" or "software-version" prop

Intended Outcome

  • Every inventory-item where the (component) "asset type" is "software" MUST have a "software-version" property either within the inventory-item itself, or within the component linked by the inventory-item

NOTE - FedRAMP prefers "software-version" in all cases, but will accept "os-version" where appropriate.

Syntax Type

This is a FedRAMP constraint in the FedRAMP-specific namespace.

Allowed Values

There are no relevant allowed values.

Metapath(s) to Content

"context=""//inventory-item""

target="". | //component[@uuid=./implemented-component/@component-uuid]""

count(./prop[@name=('software-version', 'os-version') ]) >= 1 "

Purpose of the OSCAL Content

No response

Dependencies

No response

Acceptance Criteria

  • All OSCAL adoption content affected by the change in this issue have been updated in accordance with the Documentation Standards.
    • Explanation is present and accurate
    • sample content is present and accurate
    • Metapath is present, accurate, and does not throw a syntax exception using oscal-cli metaschema metapath eval -e "expression".
  • All constraints associated with the review task have been created
  • The appropriate example OSCAL file is updated with content that demonstrates the FedRAMP-compliant OSCAL presentation.
  • The constraint conforms to the FedRAMP Constraint Style Guide.
    • All automated and manual review items that identify non-conformance are addressed; or technical leads (David Waltermire; AJ Stein) have approved the PR and “override” the style guide requirement.
  • Known good test content is created for unit testing.
  • Known bad test content is created for unit testing.
  • Unit testing is configured to run both known good and known bad test content examples.
  • Passing and failing unit tests, and corresponding test vectors in the form of known valid and invalid OSCAL test files, are created or updated for each constraint.
  • A Pull Request (PR) is submitted that fully addresses the goals section of the User Story in the issue.
  • This issue is referenced in the PR.

Other information

No response

@Rene2mt Rene2mt moved this from 🆕 New to 🔖 Ready in FedRAMP Automation Dec 24, 2024
@Gabeblis Gabeblis assigned Gabeblis and unassigned Gabeblis Dec 25, 2024
@Gabeblis Gabeblis moved this from 🔖 Ready to 🏗 In progress in FedRAMP Automation Dec 26, 2024
@Gabeblis Gabeblis moved this from 🏗 In progress to 👀 In review in FedRAMP Automation Dec 26, 2024
@Rene2mt
Copy link
Member Author

Rene2mt commented Dec 26, 2024

@Gabeblis, I should have included earlier that the "os-version" and "software-version" props are only mandatory for components where @type="software". This could also be inventory-items with "asset-type" prop that have values of "operating-system", "container", or "image".

You'll have to adjust the Metapath above accordingly.

@Gabeblis Gabeblis linked a pull request Dec 26, 2024 that will close this issue
7 tasks
@Gabeblis
Copy link
Contributor

@Rene2mt Just to clarify, we are checking each inventory-item that has a prop with @name='asset-type and @value=('operating-system', 'container', 'image') or a component with @type='software' and a uuid that matches the inventory-item component uuid, for the software version prop? or are we separately checking each component with @type='software' and each inventory-item that has a prop with @name='asset-type and @value=('operating-system', 'container', 'image')? The way I currently have it implemented in #1039 checks the inventory items and components with a matching uuid. However, it wouldn't catch a standalone component with @type='software' that isn't linked to an inventory-item.

@Rene2mt
Copy link
Member Author

Rene2mt commented Dec 27, 2024

@Rene2mt Just to clarify, we are checking each inventory-item that has a prop with @name='asset-type and @value=('operating-system', 'container', 'image') or a component with @type='software' and a uuid that matches the inventory-item component uuid, for the software version prop? or are we separately checking each component with @type='software' and each inventory-item that has a prop with @name='asset-type and @value=('operating-system', 'container', 'image')? The way I currently have it implemented in #1039 checks the inventory items and components with a matching uuid. However, it wouldn't catch a standalone component with @type='software' that isn't linked to an inventory-item.

Good question @Gabeblis. I believe the way you coded it is correct. @brian-ruf can you confirm?

@brian-ruf
Copy link
Contributor

You did it correctly @Gabeblis

@aj-stein-gsa
Copy link
Contributor

Blocked re upstream model constraint conflicts and current sitrep in #1038 (comment).

@aj-stein-gsa aj-stein-gsa moved this from 👀 In review to 🛑 Blocked in FedRAMP Automation Dec 31, 2024
@Gabeblis Gabeblis added the canary Issues with PRs merged into canary branch label Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: 🛑 Blocked
Development

Successfully merging a pull request may close this issue.

4 participants