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

[FEATURE] required_audience should support a list #3723

Closed
m4rkw opened this issue Nov 16, 2023 · 5 comments
Closed

[FEATURE] required_audience should support a list #3723

m4rkw opened this issue Nov 16, 2023 · 5 comments
Labels
enhancement New feature or request triaged Issues labeled as 'Triaged' have been reviewed and are deemed actionable.

Comments

@m4rkw
Copy link

m4rkw commented Nov 16, 2023

Is your feature request related to a problem?
The identity provider we use in our environment doesn't allow us to use the same audience claim for cli-based access vs web access (eg dashboards). Therefore we're unable to use the claim validation in its current state because it only supports a single value. I originally reported the lack of claim validation a couple of years ago when we were still running OpenDistro and was happy to see it had been added, but unfortunately a static value makes it impossible for us to use so we'll have to write a patch for internal use.

What solution would you like?
The required_audience field should support a list of valid claims.

What alternatives have you considered?
Tried to make the stack run with the same single claim but our identity provider doesn't allow for it.

Do you have any additional context?
No

@m4rkw m4rkw added enhancement New feature or request untriaged Require the attention of the repository maintainers and may need to be prioritized labels Nov 16, 2023
@stephen-crawford
Copy link
Contributor

[Triage] Hi @m4rkw, this sounds like a great idea. If you would like to submit your internal patch as a PR, we would happily review any PRs towards this effort. Thanks.

@stephen-crawford stephen-crawford added triaged Issues labeled as 'Triaged' have been reviewed and are deemed actionable. and removed untriaged Require the attention of the repository maintainers and may need to be prioritized labels Nov 20, 2023
@m4rkw
Copy link
Author

m4rkw commented Nov 22, 2023

@scrawfor99 sure - https://github.com/opensearch-project/security/pull/3765/files

this is what we're using internally. It works however I'm not a java developer so have no idea if the code is sensible/efficient/etc.

@cwperks
Copy link
Member

cwperks commented Dec 5, 2023

@m4rkw I modified your PR a bit to accommodate this change everywhere where a JWT could be verified in this plugin: cwperks#12

Could you please update this issue to describe how multiple audiences could be handled?

i.e. Would you setup an authenticator with multiple required audiences and if a token has audiences wholly contained in the list of required audiences it would be verified?

JWT Authenticator

jwt_auth_domain:
      description: "Authenticate via Json Web Token"
      http_enabled: true
      transport_enabled: true
      order: 0
      http_authenticator:
        type: jwt
        challenge: false
        config:
          signing_key: "<base64EncodedSgningKey>"
          jwt_header: "Authorization"
          jwt_url_parameter: null
          roles_key: "roles"
          subject_key: "sub"
          required_audience:
            - aud1
            - aud2

Valid token payloads:

{
  "sub": "username",
  "roles": "role1,role2",
  "aud": "aud1"
}
{
  "sub": "username",
  "roles": "role1,role2",
  "aud": "aud2"
}
{
  "sub": "username",
  "roles": "role1,role2",
  "aud": "aud1,aud2"
}

What about a token that has some overlapping audiences, but not others:

{
  "sub": "username",
  "roles": "role1,role2",
  "aud": "aud1,wrong_audience"
}

@m4rkw
Copy link
Author

m4rkw commented Dec 6, 2023

@cwperks I’m not an expert on the oauth2 spec but from what I understand talking to our internal team who run the identity provider, only supporting a single audience claim essentially isn’t fully supporting oauth2. This is (I think) because the two access methods, that is API access to elastic and web access via dashboards, are different oauth2 flows and so necessitate different claims. Eg if your cluster is elkmark you might have a claim for elasticsearch api access of “elkmark-dev”, but the identity provider may mandate a .web extension for web-based flows so the audience claim for the dashboards flow would have to be “elkmark-dev.web”. This is the case in our environment and the identity provider won’t let us use either one of these claims in both scenarios. I’m speculating now but I think this is probably part of the spec because one point of JWTs is to limit exposure in the event of a token being stolen. If the claims are limited in scope then an intercepted token from a dashboards session can’t then be used for direct api access, and vice versa.

In my opinion having any valid claim in the token should grant access regardless of there being other invalid claims.

@derek-ho
Copy link
Collaborator

derek-ho commented Oct 9, 2024

Looks like this issue is fixed/now supported with the linked PR. I will close it. @m4rkw feel free to re-open or create a new one if I am mistaken.

@derek-ho derek-ho closed this as completed Oct 9, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request triaged Issues labeled as 'Triaged' have been reviewed and are deemed actionable.
Projects
None yet
Development

No branches or pull requests

4 participants