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

Authorized Users for Leveraged Authorizations and External, Interconnected, and Unauthorized Systems #893

Open
14 tasks done
Tracked by #807 ...
Rene2mt opened this issue Nov 12, 2024 · 5 comments · Fixed by #949
Open
14 tasks done
Tracked by #807 ...

Comments

@Rene2mt
Copy link
Member

Rene2mt commented Nov 12, 2024

Constraint Task

As a maintainer of a digital authorization package, I need to clearly document the in my SSP the authorized uses of any leveraged FedRAMP authorized services, so that agencies that use my service understand potential risk around the user types that can access data in the external system. Checking to ensure I have provided complete listing of authorized users will prevent pass back during review of my SSP.

Intended Outcome

Define a constraint to ensure that only valid / defined users are referenced when listing authorized users for a leveraged authorization. In other words, each //system-implementation/leveraged-authorization/prop[@name='user-uuid'][@ns='http://fedramp.gov/ns/oscal']/@value must reference a valid //system-implementation/user

The constraint should give an ERROR if the condition is not met.

Syntax Type

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

Allowed Values

There are no relevant allowed values.

Metapath(s) to Content

Each appropriate component type (leveraged authorizations, interconnections, external services, etc.) has at least one responsible-role other than the "provider" role.

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'])
]"

Constraint:

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

Each non-provider responsible role references at least one user/authorized-privilege/function-performed via the "privilege-uuid" property/extension.

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'])
]  

/responsible-role[not(@role-id='provider')]
"

Constraint:

count(//system-implementation/user[@uuid=./prop[@name='privilege-uuid' and @ns='http://fedramp.gov/ns/oscal']/@value]/authorized-privilege/function-performed) >= 1

Purpose of the OSCAL Content

No response

Dependencies

Check to ensure that for each leveraged authorized system / service, the SSP clearly documents (what user types / roles) are authorized users.

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

This is being revised and expanded to cover both #807 and #808

@brian-ruf
Copy link
Contributor

This was revised and is now ready for assignment. It was changed to align the handling of authorized users the same for both #807 and #808 above, and using the Variant 2 solution discussed in THIS COMMENT of issue #534.

@brian-ruf brian-ruf changed the title Check authorized users for leveraged authorization Authorized Users for Leveraged Authorizations and External, Interconnected, and Unauthorized Systems Nov 25, 2024
@brian-ruf
Copy link
Contributor

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

@brian-ruf brian-ruf moved this from 🆕 New to 🔖 Ready in FedRAMP Automation Nov 26, 2024
@Gabeblis Gabeblis self-assigned this Nov 27, 2024
@Gabeblis Gabeblis moved this from 🔖 Ready to 🏗 In progress in FedRAMP Automation Nov 27, 2024
@Gabeblis Gabeblis linked a pull request Dec 2, 2024 that will close this issue
7 tasks
@Gabeblis Gabeblis moved this from 🏗 In progress to 👀 In review in FedRAMP Automation Dec 2, 2024
@Gabeblis Gabeblis moved this from 👀 In review to 🚢 Ready to Ship in FedRAMP Automation Dec 3, 2024
@brian-ruf
Copy link
Contributor

@Gabeblis the metapath needs to change for this one as well:

//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'])

]

@Gabeblis Gabeblis mentioned this issue Dec 8, 2024
6 tasks
@Gabeblis
Copy link
Contributor

Gabeblis commented Dec 9, 2024

@Gabeblis the metapath needs to change for this one as well:

//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'])

]

Ok, resolved in #974.

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.

3 participants