Skip to content

Commit

Permalink
allow internal openid url as issuer
Browse files Browse the repository at this point in the history
  • Loading branch information
burnettk committed Oct 7, 2024
1 parent 7d0e908 commit a6abdd1
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,7 @@ def config_from_env(variable_name: str, *, default: str | bool | int | None = No
config_from_env("SPIFFWORKFLOW_BACKEND_OPEN_ID_VERIFY_NBF", default=True)
config_from_env("SPIFFWORKFLOW_BACKEND_OPEN_ID_VERIFY_AZP", default=True)
config_from_env("SPIFFWORKFLOW_BACKEND_OPEN_ID_LEEWAY", default=5)
config_from_env("SPIFFWORKFLOW_BACKEND_OPEN_ID_INTERNAL_URL_IS_VALID_ISSUER", default=False)

# Open ID server
# use "http://localhost:7000/openid" for running with simple openid
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -363,9 +363,19 @@ def validate_decoded_token(cls, decoded_token: dict, authentication_identifier:
audience_array_in_token = [aud]
overlapping_aud_values = [x for x in audience_array_in_token if x in valid_audience_values]

if iss not in [cls.server_url(authentication_identifier), UserModel.spiff_generated_jwt_issuer()]:
internal_server_url = cls.server_url(authentication_identifier, internal=True)

trusted_issuer_urls = [
cls.server_url(authentication_identifier),
UserModel.spiff_generated_jwt_issuer(),
]

if current_app.config["SPIFFWORKFLOW_BACKEND_OPEN_ID_INTERNAL_URL_IS_VALID_ISSUER"]:
trusted_issuer_urls.append(internal_server_url)

if iss not in trusted_issuer_urls:
current_app.logger.error(
f"TOKEN INVALID because ISS '{iss}' does not match server url '{cls.server_url(authentication_identifier)}'"
f"TOKEN INVALID because ISS '{iss}' does not match any of the trusted issuer urls '{trusted_issuer_urls}'"
)
valid = False
# aud could be an array or a string
Expand Down

0 comments on commit a6abdd1

Please sign in to comment.