mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-10-24 04:54:00 -07:00
Keycloak modules retry request on authentication error, support refresh token parameter (#9494)
* feat: begin refactor to support refresh token in keycloak modules
* chore: add start of tests for shared token usage
* feat: progress towards supporting refresh token; token introspection not yet working [8857]
* chore: reset to main branch previous state; a different approach is needed [8857]
* feat: add request methods to keycloak class, which will be expanded with retry logic [8857]
* feat: all requests to keycloak use request methods instead of open_url [8857]
* fix: data argument is optional in keycloak request methods [8857]
* feat: add integration test for keycloak module authentication methods [8857]
* chore: refactor get token logic to separate logic using username/pass credentials [8857]
* chore: refactor token request logic further to isolate request logic [8857]
* chore: fix minor lint issues [8857]
* test: add (currently failing) test for request with invalid auth token, valid refresh token [8857]
* chore: allow realm to be provided to role module with refresh_token, without username/pass [8857]
* feat: add retry logic to requests in keycloak module utils [8857]
* chore: rename keycloak module fail_open_url method to fail_request [8857]
* chore: update all keycloak modules to support refresh token param [8857]
* chore: add refresh_token param to keycloak doc_fragments [8857]
* chore: restore dependency between auth_realm and auth_username,auth_password params [8857]
* chore: rearrange module param checks to reduce future pr size [8857]
* chore: remove extra comma [8857]
* chore: update version added for refresh token param [8857]
* chore: add changelog fragment [8857]
* chore: re-add fail_open_url to keycloak module utils for backward compatability [8857]
* fix: do not make a new request to keycloak without reauth when refresh token not provided (#8857)
* fix: only make final auth attempt if username/pass provided, and return exception on failure (#8857)
* fix: make re-auth and retry code more consistent, ensure final exceptions are thrown (#8857)
* test: fix arguments for invalid token, valid refresh token test (#8857)
* feat: catch invalid refresh token errors during re-auth attempt (#8857)
Add test to verify this behaviour works.
* test: improve test coverage, including some unhappy path tests for authentication failures (#8857)
* chore: store auth errors from token request in backwards compatible way (#8857)
* fix: ensure method is still specified for all requests (#8857)
* chore: simplify token request logic (#8857)
* chore: rename functions to request tokens using refresh token or username/password (#8857)
To emphasize their difference from the `get_token` function,
which either gets the token from the module params
*or* makes a request for it.
* doc: add docstrings for new or significantly modified functions (#8857)
* test: repair unit test following change to exception message upon key error during auth request (#8857)
(cherry picked from commit af0118278b
)
Co-authored-by: Mark Armstrong <markparmstrong@gmail.com>
95 lines
2.1 KiB
Python
95 lines
2.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright (c) 2017, Eike Frost <ei@kefro.st>
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
__metaclass__ = type
|
|
|
|
|
|
class ModuleDocFragment(object):
|
|
|
|
# Standard documentation fragment
|
|
DOCUMENTATION = r"""
|
|
options:
|
|
auth_keycloak_url:
|
|
description:
|
|
- URL to the Keycloak instance.
|
|
type: str
|
|
required: true
|
|
aliases:
|
|
- url
|
|
|
|
auth_client_id:
|
|
description:
|
|
- OpenID Connect C(client_id) to authenticate to the API with.
|
|
type: str
|
|
default: admin-cli
|
|
|
|
auth_realm:
|
|
description:
|
|
- Keycloak realm name to authenticate to for API access.
|
|
type: str
|
|
|
|
auth_client_secret:
|
|
description:
|
|
- Client Secret to use in conjunction with O(auth_client_id) (if required).
|
|
type: str
|
|
|
|
auth_username:
|
|
description:
|
|
- Username to authenticate for API access with.
|
|
type: str
|
|
aliases:
|
|
- username
|
|
|
|
auth_password:
|
|
description:
|
|
- Password to authenticate for API access with.
|
|
type: str
|
|
aliases:
|
|
- password
|
|
|
|
token:
|
|
description:
|
|
- Authentication token for Keycloak API.
|
|
type: str
|
|
version_added: 3.0.0
|
|
|
|
refresh_token:
|
|
description:
|
|
- Authentication refresh token for Keycloak API.
|
|
type: str
|
|
version_added: 10.3.0
|
|
|
|
validate_certs:
|
|
description:
|
|
- Verify TLS certificates (do not disable this in production).
|
|
type: bool
|
|
default: true
|
|
|
|
connection_timeout:
|
|
description:
|
|
- Controls the HTTP connections timeout period (in seconds) to Keycloak API.
|
|
type: int
|
|
default: 10
|
|
version_added: 4.5.0
|
|
|
|
http_agent:
|
|
description:
|
|
- Configures the HTTP User-Agent header.
|
|
type: str
|
|
default: Ansible
|
|
version_added: 5.4.0
|
|
"""
|
|
|
|
ACTIONGROUP_KEYCLOAK = r"""
|
|
options: {}
|
|
attributes:
|
|
action_group:
|
|
description: Use C(group/community.general.keycloak) in C(module_defaults) to set defaults for this module.
|
|
support: full
|
|
membership:
|
|
- community.general.keycloak
|
|
"""
|