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

Provider Constraint for Leveraged Authorizations and External, Interconnected, and Unauthorized Systems #937

Open
9 of 14 tasks
Tracked by #807 ...
brian-ruf opened this issue Nov 25, 2024 · 2 comments · Fixed by #945
Open
9 of 14 tasks
Tracked by #807 ...

Comments

@brian-ruf
Copy link
Contributor

brian-ruf commented Nov 25, 2024

Constraint Task

Ensure the "provider" responsible-role is present in appropriate components dealing with leveraged systems, interconnections, and authorized services, and each references a valid party.

Intended Outcome

The constraint exists to ensure reviewers know what organization(s) own each external system or service with which this system is communicating.

Syntax Type

This is optional core OSCAL syntax.

Allowed Values

There are no relevant allowed values.

Metapath(s) to Content

The applicable components ...

target = "//component[
   (@type='system' and ./prop[@name='leveraged-authorization-uuid'])
or
   (@type='service' and not(./prop[@name='leveraged-authorization-uuid']) and  ./prop[@name='implementation-point' and @value='external'])
or
   (@type='interconnection')
or 
   (@type='service' and ./prop[@name='implementation-point' and @value='internal'] and ./prop[@name='direction'])
or
   (@type='software' and ./prop[@name='asset-type' and @value='cli'] and ./prop[@name='direction'])
]"

... must each identify exactly one party via the "provider" responsible role:

count(//party[@uuid=./responsible-role[@role-id='provider']/party-uuid]) = 1

Purpose of the OSCAL Content

Documents the owner of systems with which this system communicates across the authorization boundary.

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

@brian-ruf
Copy link
Contributor Author

This issue uses the same target and data constructs as #893. Consider having the same person work both together.

@brian-ruf
Copy link
Contributor Author

@Gabeblis the metapath needs to be revised for this as well:

target="//component[

   (@type='system' and ./prop[@name='leveraged-authorization-uuid'])

or

   (@type=('service', 'software') and not(./prop[@name='leveraged-authorization-uuid']) and  ./prop[@name='implementation-point' and @value='external'])

or

   (@type='interconnection')

or 

   (@type=('service', 'software') and ./prop[@name='implementation-point' and @value='internal'] and ./prop[@name='communicates-externally' and @value='yes' and @ns='http://fedramp.gov/ns/oscal'])

]"

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: 🚢 Ready to Ship
Development

Successfully merging a pull request may close this issue.

2 participants