-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
Fix sudo paths missing from OpenAPI and docs #21772
Conversation
Various sudo (a.k.a. root-protected) paths are implemented in non-standard ways, and as a result: * are not declared as x-vault-sudo in the OpenAPI spec * and as a result of that, are not included in the hardcoded patterns powering the Vault CLI `-output-policy` flag * and in some cases are missing from the table of all sudo paths in the docs too Fix these problems by: * Adding `seal` and `step-down` to the list of root paths for the system backend. They don't need to be there for enforcement, as those two special endpoints bypass the standard request handling code, but they do need to be there for the OpenAPI generator to be able to know they require sudo. The way in which those two endpoints do things differently can be observed in the code search results for `RootPrivsRequired`: https://github.com/search?q=repo%3Ahashicorp%2Fvault%20RootPrivsRequired&type=code * Fix the implementation of `auth/token/revoke-orphan` to implement endpoint sudo requirements in the standard way. Currently, it has an **incorrect** path declared in the special paths metadata, and then compensates with custom code throwing an error within the request handler function itself.
vault/logical_system_test.go
Outdated
@@ -68,6 +68,8 @@ func TestSystemBackend_RootPaths(t *testing.T) { | |||
"storage/raft/snapshot-auto/config/*", | |||
"leases", | |||
"internal/inspect/*", | |||
"seal", | |||
"step-down", | |||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note to reviewer: I wonder if we might instead just delete this test entirely? It is just retrieving the value of the root paths slice, which is defined as a literal in the main code, and then comparing it to ... another identical literal definition.
It seems to me this is a pointless thing to be testing - of course two literals that are identically defined, will have equal values.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I also don't see much value in this particular test and wouldn't object if it was deleted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Updated to remove the test.
"revoke-orphan/*", | ||
"accessors*", | ||
"revoke-orphan", | ||
"accessors/", | ||
}, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note to reviewer:
The prior definition of revoke-orphan/*
is just plain wrong, so it is fixed.
The prior definition of accessors*
technically works, because it uses a needless wildcard - that change is just for precision.
req.Data = map[string]interface{}{ | ||
"token": "child", | ||
} | ||
req.ClientToken = root | ||
resp, err := ts.HandleRequest(namespace.RootContext(nil), req) | ||
resp, err := c.HandleRequest(namespace.RootContext(nil), req) | ||
if err != nil || (resp != nil && resp.IsError()) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note to reviewer: Since the common sudo-enforcing logic is part of the Core, we need to fix tests which care about the sudo behaviour, and were previously slipping requests directly to the backend, bypassing the Core, to make the request via the proper layers.
This test is the case where the requesting token does have sudo rights, testing the "allowed" case, and the next test below is testing the "denied" case.
@@ -799,44 +799,45 @@ authenticated user. | |||
## Root protected API endpoints | |||
|
|||
~> **Note:** Vault treats the HTTP POST and PUT verbs as equivalent, so for each mention | |||
of POST in the table above, PUT may also be used. Vault uses the non-standard LIST HTTP | |||
of POST in the table below, PUT may also be used. Vault uses the non-standard LIST HTTP | |||
verb, but also allows list requests to be made using the GET verb along with `?list=true` | |||
as a query parameter, so for each mention of LIST in the table above, GET with `?list=true` | |||
may also be used. | |||
|
|||
The following paths requires a root token or `sudo` capability in the policy: | |||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note to reviewer: Only one line in the table has semantic changes, please use a whitespace-ignoring diff mode to see what is really going on: https://github.com/hashicorp/vault/pull/21772/files?diff=unified&w=1#diff-cc6f6f882b5e1952856decc6cefb2caf95af3ead2ece1d3b3cd1073d92c2625e
There are other factual inaccuracies in this table (see issue #20780), but I've refrained from expanding the scope of this PR beyond the specific endpoints I was making code changes to.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks good to me, but probably could use another look from @hashicorp/vault-core to verify the removal of the sudo check.
Makes sense ... for the benefit of someone freshly looking at this PR, we're not removing a sudo requirement entirely - just removing an unusual manual check of sudo status in the middle of an operation handler, in favour of fixing an incorrectly declared path pattern, so that the standard declarative method of enforcing sudo requirements applies instead. |
This PR will conflict with a simple cleanup-only PR that I have just filed, which would ideally be merged first: #21906 |
Conflict resolved. Note: I don't think this PR needs backporting and suggest removing all If you disagree, you'll want to backport #21906 first, to avoid conflicts in the backport cherrypicks. |
Co-authored-by: Anton Averchenkov <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks again for putting this together!
This is a follow-up to hashicorp#21772. Historically, for some reason, `auth/token/revoke-orphan` was sudo-protected by writing custom code in its handler function, instead of via the usual declarative PathsSpecial.Root mechanism. In fact, there was a declaration mentioning revoke-orphan in the token backend's PathsSpecial.Root, but it was incorrect! That was corrected in hashicorp#21772, making the custom code in the handler function redundant. However, removal of the now-redundant code was deferred to this follow-up PR, out of an abundance of caution, and wanting extra eyes on a change deleting a security check.
I have created #21968 to address the last bit of cleanup, that it was decided needed extra reviewers. |
This is a follow-up to #21772. Historically, for some reason, `auth/token/revoke-orphan` was sudo-protected by writing custom code in its handler function, instead of via the usual declarative PathsSpecial.Root mechanism. In fact, there was a declaration mentioning revoke-orphan in the token backend's PathsSpecial.Root, but it was incorrect! That was corrected in #21772, making the custom code in the handler function redundant. However, removal of the now-redundant code was deferred to this follow-up PR, out of an abundance of caution, and wanting extra eyes on a change deleting a security check.
Various sudo (a.k.a. root-protected) paths are implemented in
non-standard ways, and as a result:
are not declared as x-vault-sudo in the OpenAPI spec
and as a result of that, are not included in the hardcoded patterns
powering the Vault CLI
-output-policy
flagand in some cases are missing from the table of all sudo paths in the
docs too
Fix these problems by:
Adding
seal
andstep-down
to the list of root paths for the systembackend. They don't need to be there for enforcement, as those two
special endpoints bypass the standard request handling code, but they
do need to be there for the OpenAPI generator to be able to know they
require sudo.
The way in which those two endpoints do things differently can be
observed in the code search results for
RootPrivsRequired
:https://github.com/search?q=repo%3Ahashicorp%2Fvault%20RootPrivsRequired&type=code
Fix the implementation of
auth/token/revoke-orphan
to implementendpoint sudo requirements in the standard way. Currently, it has an
incorrect path declared in the special paths metadata, and then
compensates with custom code throwing an error within the request
handler function itself.