-
Notifications
You must be signed in to change notification settings - Fork 282
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
[Question] Host Mapping of Create OBO Token Endpoint #3000
Comments
[Triage] Could you provide more context as to what is at risk. Pretty sure the issue is that the roles that are mapped in based on network location shouldn't be persisted if the network source changes. |
From my understanding, the service can use this obo token to make a request. If it does so from a different host or IP address, the question becomes: Will the system look at the host mapping (i.e., the correspondence between the IP address and the domain name) when processing the request? In some cases, the IP address or host from which a request originates may not matter at all. In other cases, the system might use host mapping or IP filtering to determine whether a request should be allowed. For instance, if the system has been set up to only accept requests from certain IP addresses or hosts, then a request from an unapproved IP address or host would likely be denied, even if it carries a valid token. |
I still don't think the issue is actionable, @RyanL1997 could you updated the description for what the current state is and what the ideal state is to consider this issue resolved? |
I have updated the descriptions with more details and provided some different design approach. |
IMO if host mapping should be done at all with OBO, it should be when the token is utilized and not taken into consideration on the create token endpoint. Imagine this roles_mapping:
If host mapping is done during create token:
If host mapping is done when the token is utilized:
|
Final UpdateAfter the internal discussion, the team has made the decision of not considering the IP based role mapping into the scope of OBO Authentication. So we can close this due to the above decision. |
0.0 Description
Transferring the previous conversation from the original OBO Authbackend PR to here. This is the issue to track some of the design aspects of host mapping for OBO Authentication.
1.0 Problem
If the service makes a call from a different host/IP address would current implementation of host mapping also come into the picture on that request?
2.0 Solutions
*Following example is provided by @cwperks *
Imagine the following roles_mapping
2.1 Option 1: Host mapping is done during create token (This is the current design)
all_access
roleall_access
permissionsPros:
Cons:
2.2 Option 2: Host mapping is done when the token is utilized
read_only
roleread_only
because 207.64.12.98 is not mapped to any rolesPros:
Cons:
3.0 Recommendation: Option 1 - Host mapping is done during create token
Firstly, from the usage perspective, the OBO authentication is aptly named, indicating its purpose: to be used on a user's behalf. Before invoking the endpoint to issue an OBO token, the current design mandates users to specify the particular 'service' for which this token will be utilized. Similarly, in the extension realm, the tokens have the
aud
as the audience claim to confine their application. Moreover, additional restrictions have been implemented to curtail the misuse of OBO tokens (original edge cases handling issue: #2891).Secondly, considering the token's brief lifespan and its just-in-time essence, it's more logical to map roles during token creation. Continuously checking or remapping roles during token utilization becomes redundant given the token's fleeting validity period. With a default active duration of 5 minutes, extending to a maximum of 10 minutes, credentials are allocated precisely when required and only for the briefest necessary duration.
Lastly, revisiting the foundational principles, the primary objective of OBO authentication was to streamline the often complex user experience associated with configuring security permissions. Introducing option 2 brings in the unpredictability factor. If the roles tethered to a token are influenced by the IP address, it stands to confound users. They might logically expect consistent access rights, aligned with their initial token request, but could be caught off guard by alterations stemming from a changed IP. Such variability not only detracts from the intended user experience but also introduces layers of intricacy to the troubleshooting process. Discerning if disruptions originate from user missteps, system anomalies, or shifting IPs could evolve into a taxing endeavor.
In summary, OBO authentication stands as a formidable tool in our arsenal. Regardless of the particular methodology we adopt, comprehensive documentation is paramount, covering both operational guidance and potential risks linked to its activation. For further insights, please refer to the upcoming documentation issue: #3100.
4.0 Appendix
4.1 An experiment of option 1
The primary aim of the experiment was to ascertain that the current OBO authentication's host mapping design adheres to the principle of "Host mapping being executed during token creation."
On Machine A, an OpenSearch cluster was established, configured to entertain external requests. This was achieved by modifying the
network.host
in theopensearch.yml
file and ensuring port 9200's accessibility. In contrast, Machine B, distinct in its IP address, was readied to act as an external testing client.Once the cluster on Machine A was operational, an OBO token was generated using admin credentials. This token was then utilized on Machine B to send requests to the OpenSearch cluster on Machine A.
The requests from Machine B were processed successfully. Despite the difference in IP addresses, Machine B could authenticate and operate as the admin user due to the OBO token. This outcome solidified the understanding that host mapping predominantly occurs during the token creation phase.
4.2 A potential implementation of option 2 (source code)
Since the the
OnBehalfOfAuthenticator
class is responsible for extracting credentials from an OBO token. We can incorporate the IP-based role determination during the token utilization within this class.RestRequest
parameter in theextractCredentials
method (source code). This IP address can then be passed to a role mapping function similar tomapRoles
for current design.extractCredentials0
method (source code):The text was updated successfully, but these errors were encountered: