mirror of
https://github.com/status-im/spiff-arena.git
synced 2025-01-27 02:05:17 +00:00
feature/pin-auth-exlusions-to-controller (#1087)
* this adds lookup of the controller names as well as the functions when checking if api call should be excluded * added login functions to exclusion list and turned it into a constant --------- Co-authored-by: jasquat <jasquat@users.noreply.github.com>
This commit is contained in:
parent
02a3932401
commit
044e9facf7
@ -77,6 +77,24 @@ PATH_SEGMENTS_FOR_PERMISSION_ALL = [
|
|||||||
{"path": "/task-data", "relevant_permissions": ["read", "update"]},
|
{"path": "/task-data", "relevant_permissions": ["read", "update"]},
|
||||||
]
|
]
|
||||||
|
|
||||||
|
AUTHENTICATION_EXCLUSION_LIST = {
|
||||||
|
"authentication_begin": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"authentication_callback": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"authentication_options": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"github_webhook_receive": "spiffworkflow_backend.routes.webhooks_controller",
|
||||||
|
"login": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"login_api_return": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"login_return": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"login_with_access_token": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"logout": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"logout_return": "spiffworkflow_backend.routes.authentication_controller",
|
||||||
|
"status": "spiffworkflow_backend.routes.health_controller",
|
||||||
|
"task_allows_guest": "spiffworkflow_backend.routes.tasks_controller",
|
||||||
|
"test_raise_error": "spiffworkflow_backend.routes.debug_controller",
|
||||||
|
"url_info": "spiffworkflow_backend.routes.debug_controller",
|
||||||
|
"webhook": "spiffworkflow_backend.routes.webhooks_controller",
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
class AuthorizationService:
|
class AuthorizationService:
|
||||||
"""Determine whether a user has permission to perform their request."""
|
"""Determine whether a user has permission to perform their request."""
|
||||||
@ -231,18 +249,6 @@ class AuthorizationService:
|
|||||||
@classmethod
|
@classmethod
|
||||||
def should_disable_auth_for_request(cls) -> bool:
|
def should_disable_auth_for_request(cls) -> bool:
|
||||||
swagger_functions = ["get_json_spec"]
|
swagger_functions = ["get_json_spec"]
|
||||||
authentication_exclusion_list = [
|
|
||||||
"authentication_begin",
|
|
||||||
"authentication_callback",
|
|
||||||
"authentication_options",
|
|
||||||
"github_webhook_receive",
|
|
||||||
"prometheus_metrics",
|
|
||||||
"status",
|
|
||||||
"task_allows_guest",
|
|
||||||
"test_raise_error",
|
|
||||||
"url_info",
|
|
||||||
"webhook",
|
|
||||||
]
|
|
||||||
if request.method == "OPTIONS":
|
if request.method == "OPTIONS":
|
||||||
return True
|
return True
|
||||||
|
|
||||||
@ -255,15 +261,20 @@ class AuthorizationService:
|
|||||||
|
|
||||||
api_view_function = current_app.view_functions[request.endpoint]
|
api_view_function = current_app.view_functions[request.endpoint]
|
||||||
module = inspect.getmodule(api_view_function)
|
module = inspect.getmodule(api_view_function)
|
||||||
|
api_function_name = api_view_function.__name__ if api_view_function else None
|
||||||
|
controller_name = module.__name__ if module is not None else None
|
||||||
if (
|
if (
|
||||||
api_view_function
|
api_function_name
|
||||||
and api_view_function.__name__.startswith("login")
|
and (
|
||||||
or api_view_function.__name__.startswith("logout")
|
api_function_name in AUTHENTICATION_EXCLUSION_LIST
|
||||||
or api_view_function.__name__.startswith("console_ui_")
|
and controller_name
|
||||||
or api_view_function.__name__ in authentication_exclusion_list
|
and controller_name in AUTHENTICATION_EXCLUSION_LIST[api_function_name]
|
||||||
or api_view_function.__name__ in swagger_functions
|
)
|
||||||
or module == openid_blueprint
|
or (
|
||||||
or module == scaffold # don't check permissions for static assets
|
api_function_name in swagger_functions
|
||||||
|
or module == openid_blueprint
|
||||||
|
or module == scaffold # don't check permissions for static assets
|
||||||
|
)
|
||||||
):
|
):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user