web/admin/providers/oauth2: only show client secret when clientType is not public
Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
parent
aaa1f92945
commit
82c2a202cb
|
@ -66,6 +66,10 @@ export class OutpostForm extends Form<Outpost> {
|
||||||
});
|
});
|
||||||
}), html``)}
|
}), html``)}
|
||||||
</select>
|
</select>
|
||||||
|
<p class="pf-c-form__helper-text">${gettext("Selecting a service-connection enables the management of the outpost by authentik.")}</p>
|
||||||
|
<p class="pf-c-form__helper-text">
|
||||||
|
See <a _target="blank" href="https://goauthentik.io/docs/outposts/outposts">documentation</a>.
|
||||||
|
</p>
|
||||||
</ak-form-element-horizontal>
|
</ak-form-element-horizontal>
|
||||||
<ak-form-element-horizontal
|
<ak-form-element-horizontal
|
||||||
label=${gettext("Providers")}
|
label=${gettext("Providers")}
|
||||||
|
|
|
@ -18,12 +18,16 @@ export class OAuth2ProviderFormPage extends Form<OAuth2Provider> {
|
||||||
id: value,
|
id: value,
|
||||||
}).then(provider => {
|
}).then(provider => {
|
||||||
this.provider = provider;
|
this.provider = provider;
|
||||||
|
this.showClientSecret = provider.clientType === OAuth2ProviderClientTypeEnum.Confidential;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@property({attribute: false})
|
@property({attribute: false})
|
||||||
provider?: OAuth2Provider;
|
provider?: OAuth2Provider;
|
||||||
|
|
||||||
|
@property({type: Boolean})
|
||||||
|
showClientSecret = true;
|
||||||
|
|
||||||
getSuccessMessage(): string {
|
getSuccessMessage(): string {
|
||||||
if (this.provider) {
|
if (this.provider) {
|
||||||
return gettext("Successfully updated provider.");
|
return gettext("Successfully updated provider.");
|
||||||
|
@ -79,7 +83,14 @@ export class OAuth2ProviderFormPage extends Form<OAuth2Provider> {
|
||||||
label=${gettext("Client type")}
|
label=${gettext("Client type")}
|
||||||
?required=${true}
|
?required=${true}
|
||||||
name="clientType">
|
name="clientType">
|
||||||
<select class="pf-c-form-control">
|
<select class="pf-c-form-control" @change=${(ev: Event) => {
|
||||||
|
const target = ev.target as HTMLSelectElement;
|
||||||
|
if (target.selectedOptions[0].value === OAuth2ProviderClientTypeEnum.Public) {
|
||||||
|
this.showClientSecret = false;
|
||||||
|
} else {
|
||||||
|
this.showClientSecret = true;
|
||||||
|
}
|
||||||
|
}}>
|
||||||
<option value=${OAuth2ProviderClientTypeEnum.Confidential} ?selected=${this.provider?.clientType === OAuth2ProviderClientTypeEnum.Confidential}>
|
<option value=${OAuth2ProviderClientTypeEnum.Confidential} ?selected=${this.provider?.clientType === OAuth2ProviderClientTypeEnum.Confidential}>
|
||||||
${gettext("Confidential")}
|
${gettext("Confidential")}
|
||||||
</option>
|
</option>
|
||||||
|
@ -96,6 +107,7 @@ export class OAuth2ProviderFormPage extends Form<OAuth2Provider> {
|
||||||
<input type="text" value="${first(this.provider?.clientId, randomString(40))}" class="pf-c-form-control" required>
|
<input type="text" value="${first(this.provider?.clientId, randomString(40))}" class="pf-c-form-control" required>
|
||||||
</ak-form-element-horizontal>
|
</ak-form-element-horizontal>
|
||||||
<ak-form-element-horizontal
|
<ak-form-element-horizontal
|
||||||
|
?hidden=${!this.showClientSecret}
|
||||||
label=${gettext("Client Secret")}
|
label=${gettext("Client Secret")}
|
||||||
name="clientSecret">
|
name="clientSecret">
|
||||||
<input type="text" value="${first(this.provider?.clientSecret, randomString(128))}" class="pf-c-form-control">
|
<input type="text" value="${first(this.provider?.clientSecret, randomString(128))}" class="pf-c-form-control">
|
||||||
|
|
Reference in a new issue