sources/oauth: introduce authorization code auth method (#14034)
Co-authored-by: Rsgm <rsgm123@gmail.com>
This commit is contained in:

committed by
GitHub

parent
c6f9d5df7b
commit
155a31fd70
@ -7,6 +7,7 @@ import {
|
||||
} from "@goauthentik/admin/sources/oauth/utils";
|
||||
import { DEFAULT_CONFIG, config } from "@goauthentik/common/api/config";
|
||||
import { first } from "@goauthentik/common/utils";
|
||||
import "@goauthentik/components/ak-radio-input";
|
||||
import "@goauthentik/elements/CodeMirror";
|
||||
import { CodeMirrorMode } from "@goauthentik/elements/CodeMirror";
|
||||
import {
|
||||
@ -16,6 +17,7 @@ import {
|
||||
import "@goauthentik/elements/ak-dual-select/ak-dual-select-dynamic-selected-provider.js";
|
||||
import "@goauthentik/elements/forms/FormGroup";
|
||||
import "@goauthentik/elements/forms/HorizontalFormElement";
|
||||
import "@goauthentik/elements/forms/Radio";
|
||||
import "@goauthentik/elements/forms/SearchSelect";
|
||||
|
||||
import { msg } from "@lit/localize";
|
||||
@ -24,6 +26,7 @@ import { customElement, property, state } from "lit/decorators.js";
|
||||
import { ifDefined } from "lit/directives/if-defined.js";
|
||||
|
||||
import {
|
||||
AuthorizationCodeAuthMethodEnum,
|
||||
FlowsInstancesListDesignationEnum,
|
||||
GroupMatchingModeEnum,
|
||||
OAuthSource,
|
||||
@ -36,6 +39,18 @@ import {
|
||||
|
||||
import { propertyMappingsProvider, propertyMappingsSelector } from "./OAuthSourceFormHelpers.js";
|
||||
|
||||
const authorizationCodeAuthMethodOptions = [
|
||||
{
|
||||
label: msg("HTTP Basic Auth"),
|
||||
value: AuthorizationCodeAuthMethodEnum.BasicAuth,
|
||||
default: true,
|
||||
},
|
||||
{
|
||||
label: msg("Include the client ID and secret as request parameters"),
|
||||
value: AuthorizationCodeAuthMethodEnum.PostBody,
|
||||
},
|
||||
];
|
||||
|
||||
@customElement("ak-source-oauth-form")
|
||||
export class OAuthSourceForm extends WithCapabilitiesConfig(BaseSourceForm<OAuthSource>) {
|
||||
async loadInstance(pk: string): Promise<OAuthSource> {
|
||||
@ -240,6 +255,19 @@ export class OAuthSourceForm extends WithCapabilitiesConfig(BaseSourceForm<OAuth
|
||||
<p class="pf-c-form__helper-text">${msg("Raw JWKS data.")}</p>
|
||||
</ak-form-element-horizontal>`
|
||||
: html``}
|
||||
${this.providerType.name === ProviderTypeEnum.Openidconnect
|
||||
? html`<ak-radio-input
|
||||
label=${msg("Authorization code authentication method")}
|
||||
name="authorizationCodeAuthMethod"
|
||||
required
|
||||
.options=${authorizationCodeAuthMethodOptions}
|
||||
.value=${this.instance?.authorizationCodeAuthMethod}
|
||||
help=${msg(
|
||||
"How to perform authentication during an authorization_code token request flow",
|
||||
)}
|
||||
>
|
||||
</ak-radio-input>`
|
||||
: html``}
|
||||
</div>
|
||||
</ak-form-group>`;
|
||||
}
|
||||
|
Reference in New Issue
Block a user