Merge branch 'master' into publish-api-to-npm
Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> # Conflicts: # web/package-lock.json # web/src/pages/sources/oauth/OAuthSourceForm.ts
This commit is contained in:
		| @ -32,7 +32,7 @@ export function configureSentry(canDoPpi: boolean = false): Promise<Config> { | ||||
|                             return null; | ||||
|                         } | ||||
|                     } | ||||
|                     if (hint.originalException instanceof Response) { | ||||
|                     if (hint.originalException instanceof Response || hint.originalException instanceof DOMException) { | ||||
|                         return null; | ||||
|                     } | ||||
|                     if (event.exception) { | ||||
|  | ||||
| @ -3,7 +3,7 @@ export const SUCCESS_CLASS = "pf-m-success"; | ||||
| export const ERROR_CLASS = "pf-m-danger"; | ||||
| export const PROGRESS_CLASS = "pf-m-in-progress"; | ||||
| export const CURRENT_CLASS = "pf-m-current"; | ||||
| export const VERSION = "2021.7.3"; | ||||
| export const VERSION = "2021.8.1-rc1"; | ||||
| export const PAGE_SIZE = 20; | ||||
| export const TITLE_DEFAULT = "authentik"; | ||||
| export const ROUTE_SEPARATOR = ";"; | ||||
|  | ||||
| @ -1,9 +1,20 @@ | ||||
| import { css, CSSResult, customElement, html, LitElement, TemplateResult } from "lit-element"; | ||||
| import { | ||||
|     css, | ||||
|     CSSResult, | ||||
|     customElement, | ||||
|     html, | ||||
|     LitElement, | ||||
|     property, | ||||
|     TemplateResult, | ||||
| } from "lit-element"; | ||||
| import PFBase from "@patternfly/patternfly/patternfly-base.css"; | ||||
| import { PFSize } from "./Spinner"; | ||||
|  | ||||
| @customElement("ak-loading-overlay") | ||||
| export class LoadingOverlay extends LitElement { | ||||
|     @property({ type: Boolean }) | ||||
|     topMost = false; | ||||
|  | ||||
|     static get styles(): CSSResult[] { | ||||
|         return [ | ||||
|             PFBase, | ||||
| @ -18,6 +29,9 @@ export class LoadingOverlay extends LitElement { | ||||
|                     background-color: var(--pf-global--BackgroundColor--dark-transparent-100); | ||||
|                     z-index: 1; | ||||
|                 } | ||||
|                 :host([topMost]) { | ||||
|                     z-index: 999; | ||||
|                 } | ||||
|             `, | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
| @ -46,6 +46,9 @@ export class ModalButton extends LitElement { | ||||
|     @property({ type: Boolean }) | ||||
|     open = false; | ||||
|  | ||||
|     @property({ type: Boolean }) | ||||
|     locked = false; | ||||
|  | ||||
|     handlerBound = false; | ||||
|  | ||||
|     static get styles(): CSSResult[] { | ||||
| @ -63,6 +66,11 @@ export class ModalButton extends LitElement { | ||||
|             PFContent, | ||||
|             AKGlobal, | ||||
|             MODAL_BUTTON_STYLES, | ||||
|             css` | ||||
|                 .locked { | ||||
|                     overflow-y: hidden !important; | ||||
|                 } | ||||
|             `, | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
| @ -108,7 +116,11 @@ export class ModalButton extends LitElement { | ||||
|     renderModal(): TemplateResult { | ||||
|         return html`<div class="pf-c-backdrop"> | ||||
|             <div class="pf-l-bullseye"> | ||||
|                 <div class="pf-c-modal-box ${this.size}" role="dialog" aria-modal="true"> | ||||
|                 <div | ||||
|                     class="pf-c-modal-box ${this.size} ${this.locked ? "locked" : ""}" | ||||
|                     role="dialog" | ||||
|                     aria-modal="true" | ||||
|                 > | ||||
|                     <button | ||||
|                         @click=${() => (this.open = false)} | ||||
|                         class="pf-c-button pf-m-plain" | ||||
|  | ||||
| @ -5,6 +5,7 @@ import PFForm from "@patternfly/patternfly/components/Form/form.css"; | ||||
| import PFFormControl from "@patternfly/patternfly/components/FormControl/form-control.css"; | ||||
| import AKGlobal from "../../authentik.css"; | ||||
| import { t } from "@lingui/macro"; | ||||
| import { FormGroup } from "./FormGroup"; | ||||
|  | ||||
| @customElement("ak-form-element-horizontal") | ||||
| export class HorizontalFormElement extends LitElement { | ||||
| @ -43,8 +44,20 @@ export class HorizontalFormElement extends LitElement { | ||||
|     @property() | ||||
|     errorMessage = ""; | ||||
|  | ||||
|     _invalid = false; | ||||
|  | ||||
|     @property({ type: Boolean }) | ||||
|     invalid = false; | ||||
|     set invalid(v: boolean) { | ||||
|         this._invalid = v; | ||||
|         // check if we're in a form group, and expand that form group | ||||
|         const parent = this.parentElement?.parentElement; | ||||
|         if (parent && "expanded" in parent) { | ||||
|             (parent as FormGroup).expanded = true; | ||||
|         } | ||||
|     } | ||||
|     get invalid(): boolean { | ||||
|         return this._invalid; | ||||
|     } | ||||
|  | ||||
|     @property() | ||||
|     name = ""; | ||||
|  | ||||
| @ -30,6 +30,7 @@ export class ModalForm extends ModalButton { | ||||
|                     form?.resetForm(); | ||||
|                 } | ||||
|                 this.loading = false; | ||||
|                 this.locked = false; | ||||
|                 this.dispatchEvent( | ||||
|                     new CustomEvent(EVENT_REFRESH, { | ||||
|                         bubbles: true, | ||||
| @ -39,12 +40,15 @@ export class ModalForm extends ModalButton { | ||||
|             }) | ||||
|             .catch((exc) => { | ||||
|                 this.loading = false; | ||||
|                 this.locked = false; | ||||
|                 throw exc; | ||||
|             }); | ||||
|     } | ||||
|  | ||||
|     renderModalInner(): TemplateResult { | ||||
|         return html`${this.loading ? html`<ak-loading-overlay></ak-loading-overlay>` : html``} | ||||
|         return html`${this.loading | ||||
|                 ? html`<ak-loading-overlay ?topMost=${true}></ak-loading-overlay>` | ||||
|                 : html``} | ||||
|             <section class="pf-c-page__main-section pf-m-light"> | ||||
|                 <div class="pf-c-content"> | ||||
|                     <h1 class="pf-c-title pf-m-2xl"> | ||||
| @ -59,6 +63,7 @@ export class ModalForm extends ModalButton { | ||||
|                 <ak-spinner-button | ||||
|                     .callAction=${() => { | ||||
|                         this.loading = true; | ||||
|                         this.locked = true; | ||||
|                         return this.confirm(); | ||||
|                     }} | ||||
|                     class="pf-m-primary" | ||||
|  | ||||
| @ -233,7 +233,6 @@ msgstr "App" | ||||
|  | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| #: src/pages/admin-overview/TopApplicationsTable.ts | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| #: src/pages/providers/ProviderListPage.ts | ||||
| msgid "Application" | ||||
| msgstr "Application" | ||||
| @ -254,6 +253,10 @@ msgstr "Application requires following permissions:" | ||||
| msgid "Application's display Name." | ||||
| msgstr "Application's display Name." | ||||
|  | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| msgid "Application(s)" | ||||
| msgstr "Application(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/LibraryPage.ts | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| @ -284,7 +287,7 @@ msgstr "" | ||||
| msgid "Are you sure you want to delete {0} {1}?" | ||||
| msgstr "Are you sure you want to delete {0} {1}?" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "Are you sure you want to delete {0} {objName} ?" | ||||
| msgstr "Are you sure you want to delete {0} {objName} ?" | ||||
|  | ||||
| @ -363,9 +366,13 @@ msgstr "Authenticator" | ||||
| msgid "Authorization" | ||||
| msgstr "Authorization" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Authorization Code" | ||||
| #~ msgstr "Authorization Code" | ||||
|  | ||||
| #: src/elements/oauth/UserCodeList.ts | ||||
| msgid "Authorization Code" | ||||
| msgstr "Authorization Code" | ||||
| msgid "Authorization Code(s)" | ||||
| msgstr "Authorization Code(s)" | ||||
|  | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceViewPage.ts | ||||
| @ -487,7 +494,7 @@ msgstr "Browser" | ||||
| msgid "Build hash:" | ||||
| msgstr "Build hash:" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Build hash: {0}" | ||||
| #~ msgstr "Build hash: {0}" | ||||
|  | ||||
| @ -518,7 +525,7 @@ msgstr "Can be in the format of 'unix://' when connecting to a local docker daem | ||||
|  | ||||
| #: src/elements/forms/ConfirmationForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| #: src/elements/forms/ModalForm.ts | ||||
| #: src/pages/groups/MemberSelectModal.ts | ||||
| #: src/pages/users/GroupSelectModal.ts | ||||
| @ -552,9 +559,13 @@ msgstr "Certificate Subjet" | ||||
| msgid "Certificate used to sign outgoing Responses going to the Service Provider." | ||||
| msgstr "Certificate used to sign outgoing Responses going to the Service Provider." | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Certificate-Key Pair" | ||||
| #~ msgstr "Certificate-Key Pair" | ||||
|  | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| msgid "Certificate-Key Pair" | ||||
| msgstr "Certificate-Key Pair" | ||||
| msgid "Certificate-Key Pair(s)" | ||||
| msgstr "Certificate-Key Pair(s)" | ||||
|  | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| msgid "Certificate-Key Pairs" | ||||
| @ -792,6 +803,7 @@ msgid "Connect" | ||||
| msgstr "Connect" | ||||
|  | ||||
| #: src/pages/user-settings/settings/SourceSettingsOAuth.ts | ||||
| #: src/pages/user-settings/settings/SourceSettingsPlex.ts | ||||
| msgid "Connected." | ||||
| msgstr "Connected." | ||||
|  | ||||
| @ -804,9 +816,9 @@ msgstr "Connection error, reconnecting..." | ||||
| msgid "Connection settings" | ||||
| msgstr "Connection settings" | ||||
|  | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| msgid "Consent" | ||||
| msgstr "Consent" | ||||
| #:  | ||||
| #~ msgid "Consent" | ||||
| #~ msgstr "Consent" | ||||
|  | ||||
| #: src/pages/stages/consent/ConsentStageForm.ts | ||||
| msgid "Consent expires in" | ||||
| @ -820,6 +832,10 @@ msgstr "Consent expires." | ||||
| msgid "Consent given last indefinitely" | ||||
| msgstr "Consent given last indefinitely" | ||||
|  | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| msgid "Consent(s)" | ||||
| msgstr "Consent(s)" | ||||
|  | ||||
| #: src/pages/sources/ldap/LDAPSourceForm.ts | ||||
| msgid "Consider Objects matching this filter to be Groups." | ||||
| msgstr "Consider Objects matching this filter to be Groups." | ||||
| @ -1091,17 +1107,21 @@ msgid "Define how notifications are sent to users, like Email or Webhook." | ||||
| msgstr "Define how notifications are sent to users, like Email or Webhook." | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| #: src/elements/oauth/UserCodeList.ts | ||||
| #: src/elements/oauth/UserRefreshList.ts | ||||
| #: src/elements/user/SessionList.ts | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| #: src/pages/events/RuleListPage.ts | ||||
| #: src/pages/events/TransportListPage.ts | ||||
| #: src/pages/flows/BoundStagesList.ts | ||||
| #: src/pages/flows/FlowListPage.ts | ||||
| #: src/pages/groups/GroupListPage.ts | ||||
| #: src/pages/outposts/OutpostListPage.ts | ||||
| #: src/pages/outposts/ServiceConnectionListPage.ts | ||||
| #: src/pages/policies/BoundPoliciesList.ts | ||||
| #: src/pages/policies/PolicyListPage.ts | ||||
| #: src/pages/policies/reputation/IPReputationListPage.ts | ||||
| #: src/pages/policies/reputation/UserReputationListPage.ts | ||||
| @ -1119,26 +1139,26 @@ msgstr "Define how notifications are sent to users, like Email or Webhook." | ||||
| msgid "Delete" | ||||
| msgstr "Delete" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Delete Authorization Code" | ||||
| #~ msgstr "Delete Authorization Code" | ||||
|  | ||||
| #: src/pages/flows/BoundStagesList.ts | ||||
| #: src/pages/policies/BoundPoliciesList.ts | ||||
| msgid "Delete Binding" | ||||
| msgstr "Delete Binding" | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Delete Binding" | ||||
| #~ msgstr "Delete Binding" | ||||
|  | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| msgid "Delete Consent" | ||||
| msgstr "Delete Consent" | ||||
| #:  | ||||
| #~ msgid "Delete Consent" | ||||
| #~ msgstr "Delete Consent" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Delete Refresh Code" | ||||
| #~ msgstr "Delete Refresh Code" | ||||
|  | ||||
| #: src/elements/user/SessionList.ts | ||||
| msgid "Delete Session" | ||||
| msgstr "Delete Session" | ||||
| #:  | ||||
| #~ msgid "Delete Session" | ||||
| #~ msgstr "Delete Session" | ||||
|  | ||||
| #: src/pages/user-settings/UserSelfForm.ts | ||||
| msgid "Delete account" | ||||
| @ -1165,7 +1185,7 @@ msgstr "" | ||||
| "confirmation. Use a consent stage to ensure the user is aware of their actions." | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "Delete {0}" | ||||
| msgstr "Delete {0}" | ||||
|  | ||||
| @ -1230,8 +1250,8 @@ msgstr "Digest algorithm" | ||||
| msgid "Digits" | ||||
| msgstr "Digits" | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Disable" | ||||
| #~ msgstr "Disable" | ||||
|  | ||||
| @ -1252,6 +1272,7 @@ msgid "Disabled" | ||||
| msgstr "Disabled" | ||||
|  | ||||
| #: src/pages/user-settings/settings/SourceSettingsOAuth.ts | ||||
| #: src/pages/user-settings/settings/SourceSettingsPlex.ts | ||||
| msgid "Disconnect" | ||||
| msgstr "Disconnect" | ||||
|  | ||||
| @ -1278,6 +1299,10 @@ msgstr "Download Certificate" | ||||
| msgid "Download Private key" | ||||
| msgstr "Download Private key" | ||||
|  | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| msgid "Due to protocol limitations, this certificate is only used when the outpost has a single provider." | ||||
| msgstr "Due to protocol limitations, this certificate is only used when the outpost has a single provider." | ||||
|  | ||||
| #: src/pages/stages/dummy/DummyStageForm.ts | ||||
| msgid "Dummy stage used for testing. Shows a simple continue button and always passes." | ||||
| msgstr "Dummy stage used for testing. Shows a simple continue button and always passes." | ||||
| @ -1382,8 +1407,8 @@ msgstr "Email: Text field with Email type." | ||||
| msgid "Embedded outpost is not configured correctly." | ||||
| msgstr "Embedded outpost is not configured correctly." | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Enable" | ||||
| #~ msgstr "Enable" | ||||
|  | ||||
| @ -1536,6 +1561,7 @@ msgstr "Expires?" | ||||
| msgid "Expiring" | ||||
| msgstr "Expiring" | ||||
|  | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| msgid "Expiry" | ||||
| msgstr "Expiry" | ||||
| @ -1607,7 +1633,7 @@ msgid "Failed to delete policy cache" | ||||
| msgstr "Failed to delete policy cache" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "Failed to delete {0}: {1}" | ||||
| msgstr "Failed to delete {0}: {1}" | ||||
|  | ||||
| @ -1653,7 +1679,6 @@ msgid "Fields a user can identify themselves with. If no fields are selected, th | ||||
| msgstr "Fields a user can identify themselves with. If no fields are selected, the user will only be able to use sources." | ||||
|  | ||||
| #: src/pages/flows/FlowImportForm.ts | ||||
| #: src/pages/flows/FlowListPage.ts | ||||
| msgid "Flow" | ||||
| msgstr "Flow" | ||||
|  | ||||
| @ -1712,6 +1737,10 @@ msgstr "Flow used to logout. If left empty, the first applicable flow sorted by | ||||
| msgid "Flow used when authorizing this provider." | ||||
| msgstr "Flow used when authorizing this provider." | ||||
|  | ||||
| #: src/pages/flows/FlowListPage.ts | ||||
| msgid "Flow(s)" | ||||
| msgstr "Flow(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/admin-overview/AdminOverviewPage.ts | ||||
| @ -1794,7 +1823,6 @@ msgid "Go to previous page" | ||||
| msgstr "Go to previous page" | ||||
|  | ||||
| #: src/pages/events/RuleForm.ts | ||||
| #: src/pages/groups/GroupListPage.ts | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| @ -1821,6 +1849,10 @@ msgstr "Group users together and give them permissions based on the membership." | ||||
| msgid "Group {0}" | ||||
| msgstr "Group {0}" | ||||
|  | ||||
| #: src/pages/groups/GroupListPage.ts | ||||
| msgid "Group(s)" | ||||
| msgstr "Group(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/admin-overview/AdminOverviewPage.ts | ||||
| #: src/pages/groups/GroupListPage.ts | ||||
| @ -1890,6 +1922,7 @@ msgstr "How many attempts a user has before the flow is canceled. To lock the us | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| #: src/pages/users/UserListPage.ts | ||||
| msgid "ID" | ||||
| msgstr "ID" | ||||
|  | ||||
| @ -1940,6 +1973,10 @@ msgstr "If enabled, use the local connection. Required Docker socket/Kubernetes | ||||
| msgid "If left empty, authentik will try to extract the launch URL based on the selected provider." | ||||
| msgstr "If left empty, authentik will try to extract the launch URL based on the selected provider." | ||||
|  | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| msgid "If multiple providers share an outpost, a self-signed certificate is used." | ||||
| msgstr "If multiple providers share an outpost, a self-signed certificate is used." | ||||
|  | ||||
| #: src/pages/providers/oauth2/OAuth2ProviderForm.ts | ||||
| msgid "If no explicit redirect URIs are specified, any redirect URI is allowed." | ||||
| msgstr "If no explicit redirect URIs are specified, any redirect URI is allowed." | ||||
| @ -2038,14 +2075,18 @@ msgstr "Invalidation" | ||||
| msgid "Invalidation flow" | ||||
| msgstr "Invalidation flow" | ||||
|  | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| msgid "Invitation" | ||||
| msgstr "Invitation" | ||||
| #:  | ||||
| #~ msgid "Invitation" | ||||
| #~ msgstr "Invitation" | ||||
|  | ||||
| #: src/pages/events/utils.ts | ||||
| msgid "Invitation used" | ||||
| msgstr "Invitation used" | ||||
|  | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| msgid "Invitation(s)" | ||||
| msgstr "Invitation(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| msgid "Invitations" | ||||
| @ -2233,7 +2274,6 @@ msgstr "Loading" | ||||
| #: src/pages/sources/ldap/LDAPSourceForm.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| #: src/pages/sources/plex/PlexSourceForm.ts | ||||
| #: src/pages/sources/plex/PlexSourceForm.ts | ||||
| #: src/pages/sources/saml/SAMLSourceForm.ts | ||||
| @ -2421,6 +2461,7 @@ msgstr "My Applications" | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| #: src/pages/crypto/CertificateKeyPairForm.ts | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| #: src/pages/events/EventInfo.ts | ||||
| #: src/pages/events/RuleForm.ts | ||||
| #: src/pages/events/RuleListPage.ts | ||||
| @ -2607,6 +2648,7 @@ msgid "Not configured action" | ||||
| msgstr "Not configured action" | ||||
|  | ||||
| #: src/pages/user-settings/settings/SourceSettingsOAuth.ts | ||||
| #: src/pages/user-settings/settings/SourceSettingsPlex.ts | ||||
| msgid "Not connected." | ||||
| msgstr "Not connected." | ||||
|  | ||||
| @ -2647,17 +2689,25 @@ msgstr "Notification Rules" | ||||
| msgid "Notification Transports" | ||||
| msgstr "Notification Transports" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Notification rule" | ||||
| #~ msgstr "Notification rule" | ||||
|  | ||||
| #: src/pages/events/RuleListPage.ts | ||||
| msgid "Notification rule" | ||||
| msgstr "Notification rule" | ||||
| msgid "Notification rule(s)" | ||||
| msgstr "Notification rule(s)" | ||||
|  | ||||
| #: src/pages/events/TransportListPage.ts | ||||
| msgid "Notification transports(s)" | ||||
| msgstr "Notification transports(s)" | ||||
|  | ||||
| #: src/elements/notifications/NotificationDrawer.ts | ||||
| msgid "Notifications" | ||||
| msgstr "Notifications" | ||||
|  | ||||
| #: src/pages/events/TransportListPage.ts | ||||
| msgid "Notifications Transport" | ||||
| msgstr "Notifications Transport" | ||||
| #:  | ||||
| #~ msgid "Notifications Transport" | ||||
| #~ msgstr "Notifications Transport" | ||||
|  | ||||
| #: src/pages/stages/prompt/PromptForm.ts | ||||
| msgid "Number" | ||||
| @ -2702,7 +2752,7 @@ msgstr "Only fail the policy, don't invalidate user's password." | ||||
| msgid "Only send notification once, for example when sending a webhook into a chat channel." | ||||
| msgstr "Only send notification once, for example when sending a webhook into a chat channel." | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Open application" | ||||
| #~ msgstr "Open application" | ||||
|  | ||||
| @ -2771,26 +2821,34 @@ msgstr "Other global settings" | ||||
| msgid "Outdated outposts" | ||||
| msgstr "Outdated outposts" | ||||
|  | ||||
| #: src/pages/outposts/OutpostListPage.ts | ||||
| msgid "Outpost" | ||||
| msgstr "Outpost" | ||||
| #:  | ||||
| #~ msgid "Outpost" | ||||
| #~ msgstr "Outpost" | ||||
|  | ||||
| #: src/pages/outposts/OutpostDeploymentModal.ts | ||||
| msgid "Outpost Deployment Info" | ||||
| msgstr "Outpost Deployment Info" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Outpost Service-connection" | ||||
| #~ msgstr "Outpost Service-connection" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Outpost integration" | ||||
| #~ msgstr "Outpost integration" | ||||
|  | ||||
| #: src/pages/outposts/ServiceConnectionListPage.ts | ||||
| msgid "Outpost integration" | ||||
| msgstr "Outpost integration" | ||||
| msgid "Outpost integration(s)" | ||||
| msgstr "Outpost integration(s)" | ||||
|  | ||||
| #: src/pages/admin-overview/AdminOverviewPage.ts | ||||
| msgid "Outpost status" | ||||
| msgstr "Outpost status" | ||||
|  | ||||
| #: src/pages/outposts/OutpostListPage.ts | ||||
| msgid "Outpost(s)" | ||||
| msgstr "Outpost(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/outposts/OutpostListPage.ts | ||||
| @ -2884,7 +2942,6 @@ msgstr "Policies" | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/policies/PolicyListPage.ts | ||||
| msgid "Policy" | ||||
| msgstr "Policy" | ||||
|  | ||||
| @ -2893,6 +2950,10 @@ msgstr "Policy" | ||||
| msgid "Policy / Group / User Bindings" | ||||
| msgstr "Policy / Group / User Bindings" | ||||
|  | ||||
| #: src/pages/policies/PolicyListPage.ts | ||||
| msgid "Policy / Policies" | ||||
| msgstr "Policy / Policies" | ||||
|  | ||||
| #: src/pages/policies/BoundPoliciesList.ts | ||||
| msgid "Policy / User / Group" | ||||
| msgstr "Policy / User / Group" | ||||
| @ -2903,9 +2964,13 @@ msgstr "Policy / User / Group" | ||||
| msgid "Policy Bindings" | ||||
| msgstr "Policy Bindings" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Policy binding" | ||||
| #~ msgstr "Policy binding" | ||||
|  | ||||
| #: src/pages/policies/BoundPoliciesList.ts | ||||
| msgid "Policy binding" | ||||
| msgstr "Policy binding" | ||||
| msgid "Policy binding(s)" | ||||
| msgstr "Policy binding(s)" | ||||
|  | ||||
| #: src/pages/applications/ApplicationForm.ts | ||||
| #: src/pages/applications/ApplicationViewPage.ts | ||||
| @ -2973,27 +3038,35 @@ msgstr "Private key, acquired from https://www.google.com/recaptcha/intro/v3.htm | ||||
| msgid "Profile URL" | ||||
| msgstr "Profile URL" | ||||
|  | ||||
| #: src/pages/stages/prompt/PromptListPage.ts | ||||
| msgid "Prompt" | ||||
| msgstr "Prompt" | ||||
| #:  | ||||
| #~ msgid "Prompt" | ||||
| #~ msgstr "Prompt" | ||||
|  | ||||
| #: src/pages/stages/consent/ConsentStageForm.ts | ||||
| msgid "Prompt for the user's consent. The consent can either be permanent or expire in a defined amount of time." | ||||
| msgstr "Prompt for the user's consent. The consent can either be permanent or expire in a defined amount of time." | ||||
|  | ||||
| #: src/pages/stages/prompt/PromptListPage.ts | ||||
| msgid "Prompt(s)" | ||||
| msgstr "Prompt(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/stages/prompt/PromptListPage.ts | ||||
| msgid "Prompts" | ||||
| msgstr "Prompts" | ||||
|  | ||||
| #: src/pages/property-mappings/PropertyMappingListPage.ts | ||||
| msgid "Property Mapping" | ||||
| msgstr "Property Mapping" | ||||
| #:  | ||||
| #~ msgid "Property Mapping" | ||||
| #~ msgstr "Property Mapping" | ||||
|  | ||||
| #: src/pages/events/utils.ts | ||||
| msgid "Property Mapping exception" | ||||
| msgstr "Property Mapping exception" | ||||
|  | ||||
| #: src/pages/property-mappings/PropertyMappingListPage.ts | ||||
| msgid "Property Mapping(s)" | ||||
| msgstr "Property Mapping(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/property-mappings/PropertyMappingListPage.ts | ||||
| msgid "Property Mappings" | ||||
| @ -3033,7 +3106,6 @@ msgstr "Provide support for protocols like SAML and OAuth to assigned applicatio | ||||
| #: src/pages/applications/ApplicationForm.ts | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| #: src/pages/applications/ApplicationViewPage.ts | ||||
| #: src/pages/providers/ProviderListPage.ts | ||||
| msgid "Provider" | ||||
| msgstr "Provider" | ||||
|  | ||||
| @ -3042,9 +3114,13 @@ msgstr "Provider" | ||||
| msgid "Provider Type" | ||||
| msgstr "Provider Type" | ||||
|  | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| msgid "Provider type" | ||||
| msgstr "Provider type" | ||||
| #:  | ||||
| #~ msgid "Provider type" | ||||
| #~ msgstr "Provider type" | ||||
|  | ||||
| #: src/pages/providers/ProviderListPage.ts | ||||
| msgid "Provider(s)" | ||||
| msgstr "Provider(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/outposts/OutpostForm.ts | ||||
| @ -3168,9 +3244,13 @@ msgstr "Redirect binding" | ||||
| msgid "Refresh" | ||||
| msgstr "Refresh" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Refresh Code" | ||||
| #~ msgstr "Refresh Code" | ||||
|  | ||||
| #: src/elements/oauth/UserRefreshList.ts | ||||
| msgid "Refresh Code" | ||||
| msgstr "Refresh Code" | ||||
| msgid "Refresh Code(s)" | ||||
| msgstr "Refresh Code(s)" | ||||
|  | ||||
| #: src/flows/stages/authenticator_webauthn/WebAuthnAuthenticatorRegisterStage.ts | ||||
| msgid "Register device" | ||||
| @ -3419,7 +3499,7 @@ msgstr "Select which transports should be used to notify the user. If none are s | ||||
| msgid "Selected policies are executed when the stage is submitted to validate the data." | ||||
| msgstr "Selected policies are executed when the stage is submitted to validate the data." | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Selecting a service-connection enables the management of the outpost by authentik." | ||||
| #~ msgstr "Selecting a service-connection enables the management of the outpost by authentik." | ||||
|  | ||||
| @ -3468,15 +3548,15 @@ msgstr "Server URI" | ||||
| msgid "Server and client are further than 5 seconds apart." | ||||
| msgstr "Server and client are further than 5 seconds apart." | ||||
|  | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| msgid "Server name for which this provider's certificate is valid for." | ||||
| msgstr "Server name for which this provider's certificate is valid for." | ||||
| #:  | ||||
| #~ msgid "Server name for which this provider's certificate is valid for." | ||||
| #~ msgstr "Server name for which this provider's certificate is valid for." | ||||
|  | ||||
| #: src/flows/stages/authenticator_webauthn/WebAuthnAuthenticatorRegisterStage.ts | ||||
| msgid "Server validation of credential failed: {err}" | ||||
| msgstr "Server validation of credential failed: {err}" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Service Connections" | ||||
| #~ msgstr "Service Connections" | ||||
|  | ||||
| @ -3484,14 +3564,14 @@ msgstr "Server validation of credential failed: {err}" | ||||
| msgid "Service Provider Binding" | ||||
| msgstr "Service Provider Binding" | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Service connection" | ||||
| #~ msgstr "Service connection" | ||||
|  | ||||
| #: src/elements/user/SessionList.ts | ||||
| msgid "Session" | ||||
| msgstr "Session" | ||||
| #:  | ||||
| #~ msgid "Session" | ||||
| #~ msgstr "Session" | ||||
|  | ||||
| #: src/pages/stages/user_login/UserLoginStageForm.ts | ||||
| msgid "Session duration" | ||||
| @ -3505,6 +3585,10 @@ msgstr "Session not valid on or after current time + this value (Format: hours=1 | ||||
| msgid "Session valid not on or after" | ||||
| msgstr "Session valid not on or after" | ||||
|  | ||||
| #: src/elements/user/SessionList.ts | ||||
| msgid "Session(s)" | ||||
| msgstr "Session(s)" | ||||
|  | ||||
| #: src/pages/users/UserViewPage.ts | ||||
| msgid "Sessions" | ||||
| msgstr "Sessions" | ||||
| @ -3585,18 +3669,23 @@ msgstr "Slug" | ||||
| msgid "Something went wrong! Please try again later." | ||||
| msgstr "Something went wrong! Please try again later." | ||||
|  | ||||
| #: src/pages/sources/SourcesListPage.ts | ||||
| msgid "Source" | ||||
| msgstr "Source" | ||||
| #:  | ||||
| #~ msgid "Source" | ||||
| #~ msgstr "Source" | ||||
|  | ||||
| #: src/pages/events/utils.ts | ||||
| msgid "Source linked" | ||||
| msgstr "Source linked" | ||||
|  | ||||
| #: src/pages/user-settings/settings/SourceSettingsOAuth.ts | ||||
| #: src/pages/user-settings/settings/SourceSettingsPlex.ts | ||||
| msgid "Source {0}" | ||||
| msgstr "Source {0}" | ||||
|  | ||||
| #: src/pages/sources/SourcesListPage.ts | ||||
| msgid "Source(s)" | ||||
| msgstr "Source(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/sources/SourcesListPage.ts | ||||
| #: src/pages/stages/identification/IdentificationStageForm.ts | ||||
| @ -3619,9 +3708,13 @@ msgstr "Stage Bindings" | ||||
| msgid "Stage Configuration" | ||||
| msgstr "Stage Configuration" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Stage binding" | ||||
| #~ msgstr "Stage binding" | ||||
|  | ||||
| #: src/pages/flows/BoundStagesList.ts | ||||
| msgid "Stage binding" | ||||
| msgstr "Stage binding" | ||||
| msgid "Stage binding(s)" | ||||
| msgstr "Stage binding(s)" | ||||
|  | ||||
| #: src/pages/stages/authenticator_validate/AuthenticatorValidateStageForm.ts | ||||
| msgid "Stage used to configure Authenticator when user doesn't have any compatible devices. After this configuration Stage passes, the user is not prompted again." | ||||
| @ -3647,6 +3740,10 @@ msgstr "Stage used to configure a static authenticator (i.e. static tokens). Thi | ||||
| msgid "Stage used to validate any authenticator. This stage should be used during authentication or authorization flows." | ||||
| msgstr "Stage used to validate any authenticator. This stage should be used during authentication or authorization flows." | ||||
|  | ||||
| #: src/pages/stages/StageListPage.ts | ||||
| msgid "Stage(s)" | ||||
| msgstr "Stage(s)" | ||||
|  | ||||
| #: src/pages/stages/authenticator_duo/AuthenticatorDuoStageForm.ts | ||||
| #: src/pages/stages/authenticator_static/AuthenticatorStaticStageForm.ts | ||||
| #: src/pages/stages/authenticator_totp/AuthenticatorTOTPStageForm.ts | ||||
| @ -3804,8 +3901,8 @@ msgstr "Successfully created provider." | ||||
| msgid "Successfully created rule." | ||||
| msgstr "Successfully created rule." | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Successfully created service-connection." | ||||
| #~ msgstr "Successfully created service-connection." | ||||
|  | ||||
| @ -3854,7 +3951,7 @@ msgid "Successfully created user." | ||||
| msgstr "Successfully created user." | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "Successfully deleted {0} {1}" | ||||
| msgstr "Successfully deleted {0} {1}" | ||||
|  | ||||
| @ -3958,8 +4055,8 @@ msgstr "Successfully updated provider." | ||||
| msgid "Successfully updated rule." | ||||
| msgstr "Successfully updated rule." | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Successfully updated service-connection." | ||||
| #~ msgstr "Successfully updated service-connection." | ||||
|  | ||||
| @ -4078,9 +4175,9 @@ msgstr "System task execution" | ||||
| msgid "TLS Authentication Certificate" | ||||
| msgstr "TLS Authentication Certificate" | ||||
|  | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| msgid "TLS Server name" | ||||
| msgstr "TLS Server name" | ||||
| #:  | ||||
| #~ msgid "TLS Server name" | ||||
| #~ msgstr "TLS Server name" | ||||
|  | ||||
| #: src/pages/outposts/ServiceConnectionDockerForm.ts | ||||
| msgid "TLS Verification Certificate" | ||||
| @ -4107,10 +4204,13 @@ msgid "Template" | ||||
| msgstr "Template" | ||||
|  | ||||
| #: src/pages/events/EventListPage.ts | ||||
| #: src/pages/tenants/TenantListPage.ts | ||||
| msgid "Tenant" | ||||
| msgstr "Tenant" | ||||
|  | ||||
| #: src/pages/tenants/TenantListPage.ts | ||||
| msgid "Tenant(s)" | ||||
| msgstr "Tenant(s)" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/tenants/TenantListPage.ts | ||||
| msgid "Tenants" | ||||
| @ -4147,11 +4247,11 @@ msgstr "The external URL you'll access the application at. Include any non-stand | ||||
| msgid "The external URL you'll authenticate at. Can be the same domain as authentik." | ||||
| msgstr "The external URL you'll authenticate at. Can be the same domain as authentik." | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| msgid "The following objects use {0}:" | ||||
| msgstr "The following objects use {0}:" | ||||
| #:  | ||||
| #~ msgid "The following objects use {0}:" | ||||
| #~ msgstr "The following objects use {0}:" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "The following objects use {objName}" | ||||
| msgstr "The following objects use {objName}" | ||||
|  | ||||
| @ -4258,10 +4358,10 @@ msgstr "To" | ||||
| msgid "To use SSL instead, use 'ldaps://' and disable this option." | ||||
| msgstr "To use SSL instead, use 'ldaps://' and disable this option." | ||||
|  | ||||
| #: src/pages/tokens/TokenListPage.ts | ||||
| #: src/pages/user-settings/tokens/UserTokenList.ts | ||||
| msgid "Token" | ||||
| msgstr "Token" | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Token" | ||||
| #~ msgstr "Token" | ||||
|  | ||||
| #: src/pages/providers/oauth2/OAuth2ProviderViewPage.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceViewPage.ts | ||||
| @ -4280,6 +4380,11 @@ msgstr "Token expiry" | ||||
| msgid "Token validity" | ||||
| msgstr "Token validity" | ||||
|  | ||||
| #: src/pages/tokens/TokenListPage.ts | ||||
| #: src/pages/user-settings/tokens/UserTokenList.ts | ||||
| msgid "Token(s)" | ||||
| msgstr "Token(s)" | ||||
|  | ||||
| #: src/flows/stages/authenticator_static/AuthenticatorStaticStage.ts | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/tokens/TokenListPage.ts | ||||
| @ -4396,7 +4501,7 @@ msgstr "Unhealthy outposts" | ||||
| msgid "Unknown" | ||||
| msgstr "Unknown" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Unmanaged" | ||||
| #~ msgstr "Unmanaged" | ||||
|  | ||||
| @ -4703,6 +4808,7 @@ msgstr "Userinfo URL" | ||||
| #: src/pages/stages/identification/IdentificationStageForm.ts | ||||
| #: src/pages/user-settings/UserSelfForm.ts | ||||
| #: src/pages/users/UserForm.ts | ||||
| #: src/pages/users/UserListPage.ts | ||||
| #: src/pages/users/UserViewPage.ts | ||||
| msgid "Username" | ||||
| msgstr "Username" | ||||
| @ -4924,7 +5030,7 @@ msgstr "authentik Builtin Database" | ||||
| msgid "authentik LDAP Backend" | ||||
| msgstr "authentik LDAP Backend" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "connecting object will be deleted" | ||||
| msgstr "connecting object will be deleted" | ||||
|  | ||||
| @ -4937,17 +5043,17 @@ msgid "no tabs defined" | ||||
| msgstr "no tabs defined" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "object will be DELETED" | ||||
| msgstr "object will be DELETED" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "reference will be reset to default value" | ||||
| msgstr "reference will be reset to default value" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "reference will be set to an empty value" | ||||
| msgstr "reference will be set to an empty value" | ||||
|  | ||||
| @ -4965,7 +5071,7 @@ msgid "{0} ({1})" | ||||
| msgstr "{0} ({1})" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "{0} ({consequence})" | ||||
| msgstr "{0} ({consequence})" | ||||
|  | ||||
|  | ||||
| @ -233,7 +233,6 @@ msgstr "" | ||||
|  | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| #: src/pages/admin-overview/TopApplicationsTable.ts | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| #: src/pages/providers/ProviderListPage.ts | ||||
| msgid "Application" | ||||
| msgstr "" | ||||
| @ -254,6 +253,10 @@ msgstr "" | ||||
| msgid "Application's display Name." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| msgid "Application(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/LibraryPage.ts | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| @ -280,7 +283,7 @@ msgstr "" | ||||
| msgid "Are you sure you want to delete {0} {1}?" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "Are you sure you want to delete {0} {objName} ?" | ||||
| msgstr "" | ||||
|  | ||||
| @ -359,8 +362,12 @@ msgstr "" | ||||
| msgid "Authorization" | ||||
| msgstr "" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Authorization Code" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/elements/oauth/UserCodeList.ts | ||||
| msgid "Authorization Code" | ||||
| msgid "Authorization Code(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| @ -483,7 +490,7 @@ msgstr "" | ||||
| msgid "Build hash:" | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Build hash: {0}" | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -514,7 +521,7 @@ msgstr "" | ||||
|  | ||||
| #: src/elements/forms/ConfirmationForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| #: src/elements/forms/ModalForm.ts | ||||
| #: src/pages/groups/MemberSelectModal.ts | ||||
| #: src/pages/users/GroupSelectModal.ts | ||||
| @ -548,8 +555,12 @@ msgstr "" | ||||
| msgid "Certificate used to sign outgoing Responses going to the Service Provider." | ||||
| msgstr "" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Certificate-Key Pair" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| msgid "Certificate-Key Pair" | ||||
| msgid "Certificate-Key Pair(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| @ -786,6 +797,7 @@ msgid "Connect" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/user-settings/settings/SourceSettingsOAuth.ts | ||||
| #: src/pages/user-settings/settings/SourceSettingsPlex.ts | ||||
| msgid "Connected." | ||||
| msgstr "" | ||||
|  | ||||
| @ -798,9 +810,9 @@ msgstr "" | ||||
| msgid "Connection settings" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| msgid "Consent" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Consent" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/stages/consent/ConsentStageForm.ts | ||||
| msgid "Consent expires in" | ||||
| @ -814,6 +826,10 @@ msgstr "" | ||||
| msgid "Consent given last indefinitely" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| msgid "Consent(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/sources/ldap/LDAPSourceForm.ts | ||||
| msgid "Consider Objects matching this filter to be Groups." | ||||
| msgstr "" | ||||
| @ -1085,17 +1101,21 @@ msgid "Define how notifications are sent to users, like Email or Webhook." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| #: src/elements/oauth/UserCodeList.ts | ||||
| #: src/elements/oauth/UserRefreshList.ts | ||||
| #: src/elements/user/SessionList.ts | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| #: src/pages/events/RuleListPage.ts | ||||
| #: src/pages/events/TransportListPage.ts | ||||
| #: src/pages/flows/BoundStagesList.ts | ||||
| #: src/pages/flows/FlowListPage.ts | ||||
| #: src/pages/groups/GroupListPage.ts | ||||
| #: src/pages/outposts/OutpostListPage.ts | ||||
| #: src/pages/outposts/ServiceConnectionListPage.ts | ||||
| #: src/pages/policies/BoundPoliciesList.ts | ||||
| #: src/pages/policies/PolicyListPage.ts | ||||
| #: src/pages/policies/reputation/IPReputationListPage.ts | ||||
| #: src/pages/policies/reputation/UserReputationListPage.ts | ||||
| @ -1113,26 +1133,26 @@ msgstr "" | ||||
| msgid "Delete" | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Delete Authorization Code" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/flows/BoundStagesList.ts | ||||
| #: src/pages/policies/BoundPoliciesList.ts | ||||
| msgid "Delete Binding" | ||||
| msgstr "" | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Delete Binding" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/elements/user/UserConsentList.ts | ||||
| msgid "Delete Consent" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Delete Consent" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Delete Refresh Code" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/elements/user/SessionList.ts | ||||
| msgid "Delete Session" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Delete Session" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/user-settings/UserSelfForm.ts | ||||
| msgid "Delete account" | ||||
| @ -1157,7 +1177,7 @@ msgid "" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "Delete {0}" | ||||
| msgstr "" | ||||
|  | ||||
| @ -1222,8 +1242,8 @@ msgstr "" | ||||
| msgid "Digits" | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Disable" | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -1244,6 +1264,7 @@ msgid "Disabled" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/user-settings/settings/SourceSettingsOAuth.ts | ||||
| #: src/pages/user-settings/settings/SourceSettingsPlex.ts | ||||
| msgid "Disconnect" | ||||
| msgstr "" | ||||
|  | ||||
| @ -1270,6 +1291,10 @@ msgstr "" | ||||
| msgid "Download Private key" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| msgid "Due to protocol limitations, this certificate is only used when the outpost has a single provider." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/stages/dummy/DummyStageForm.ts | ||||
| msgid "Dummy stage used for testing. Shows a simple continue button and always passes." | ||||
| msgstr "" | ||||
| @ -1374,8 +1399,8 @@ msgstr "" | ||||
| msgid "Embedded outpost is not configured correctly." | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Enable" | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -1528,6 +1553,7 @@ msgstr "" | ||||
| msgid "Expiring" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| msgid "Expiry" | ||||
| msgstr "" | ||||
| @ -1599,7 +1625,7 @@ msgid "Failed to delete policy cache" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "Failed to delete {0}: {1}" | ||||
| msgstr "" | ||||
|  | ||||
| @ -1645,7 +1671,6 @@ msgid "Fields a user can identify themselves with. If no fields are selected, th | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/flows/FlowImportForm.ts | ||||
| #: src/pages/flows/FlowListPage.ts | ||||
| msgid "Flow" | ||||
| msgstr "" | ||||
|  | ||||
| @ -1704,6 +1729,10 @@ msgstr "" | ||||
| msgid "Flow used when authorizing this provider." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/flows/FlowListPage.ts | ||||
| msgid "Flow(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/admin-overview/AdminOverviewPage.ts | ||||
| @ -1786,7 +1815,6 @@ msgid "Go to previous page" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/events/RuleForm.ts | ||||
| #: src/pages/groups/GroupListPage.ts | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| @ -1813,6 +1841,10 @@ msgstr "" | ||||
| msgid "Group {0}" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/groups/GroupListPage.ts | ||||
| msgid "Group(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/admin-overview/AdminOverviewPage.ts | ||||
| #: src/pages/groups/GroupListPage.ts | ||||
| @ -1882,6 +1914,7 @@ msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| #: src/pages/users/UserListPage.ts | ||||
| msgid "ID" | ||||
| msgstr "" | ||||
|  | ||||
| @ -1932,6 +1965,10 @@ msgstr "" | ||||
| msgid "If left empty, authentik will try to extract the launch URL based on the selected provider." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| msgid "If multiple providers share an outpost, a self-signed certificate is used." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/providers/oauth2/OAuth2ProviderForm.ts | ||||
| msgid "If no explicit redirect URIs are specified, any redirect URI is allowed." | ||||
| msgstr "" | ||||
| @ -2030,14 +2067,18 @@ msgstr "" | ||||
| msgid "Invalidation flow" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| msgid "Invitation" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Invitation" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/events/utils.ts | ||||
| msgid "Invitation used" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| msgid "Invitation(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/stages/invitation/InvitationListPage.ts | ||||
| msgid "Invitations" | ||||
| @ -2225,7 +2266,6 @@ msgstr "" | ||||
| #: src/pages/sources/ldap/LDAPSourceForm.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| #: src/pages/sources/plex/PlexSourceForm.ts | ||||
| #: src/pages/sources/plex/PlexSourceForm.ts | ||||
| #: src/pages/sources/saml/SAMLSourceForm.ts | ||||
| @ -2413,6 +2453,7 @@ msgstr "" | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| #: src/pages/crypto/CertificateKeyPairForm.ts | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| #: src/pages/crypto/CertificateKeyPairListPage.ts | ||||
| #: src/pages/events/EventInfo.ts | ||||
| #: src/pages/events/RuleForm.ts | ||||
| #: src/pages/events/RuleListPage.ts | ||||
| @ -2599,6 +2640,7 @@ msgid "Not configured action" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/user-settings/settings/SourceSettingsOAuth.ts | ||||
| #: src/pages/user-settings/settings/SourceSettingsPlex.ts | ||||
| msgid "Not connected." | ||||
| msgstr "" | ||||
|  | ||||
| @ -2639,17 +2681,25 @@ msgstr "" | ||||
| msgid "Notification Transports" | ||||
| msgstr "" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Notification rule" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/events/RuleListPage.ts | ||||
| msgid "Notification rule" | ||||
| msgid "Notification rule(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/events/TransportListPage.ts | ||||
| msgid "Notification transports(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/notifications/NotificationDrawer.ts | ||||
| msgid "Notifications" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/events/TransportListPage.ts | ||||
| msgid "Notifications Transport" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Notifications Transport" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/stages/prompt/PromptForm.ts | ||||
| msgid "Number" | ||||
| @ -2694,7 +2744,7 @@ msgstr "" | ||||
| msgid "Only send notification once, for example when sending a webhook into a chat channel." | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Open application" | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -2763,26 +2813,34 @@ msgstr "" | ||||
| msgid "Outdated outposts" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/outposts/OutpostListPage.ts | ||||
| msgid "Outpost" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Outpost" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/outposts/OutpostDeploymentModal.ts | ||||
| msgid "Outpost Deployment Info" | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Outpost Service-connection" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Outpost integration" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/outposts/ServiceConnectionListPage.ts | ||||
| msgid "Outpost integration" | ||||
| msgid "Outpost integration(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/admin-overview/AdminOverviewPage.ts | ||||
| msgid "Outpost status" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/outposts/OutpostListPage.ts | ||||
| msgid "Outpost(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/outposts/OutpostListPage.ts | ||||
| @ -2876,7 +2934,6 @@ msgstr "" | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/policies/PolicyBindingForm.ts | ||||
| #: src/pages/policies/PolicyListPage.ts | ||||
| msgid "Policy" | ||||
| msgstr "" | ||||
|  | ||||
| @ -2885,6 +2942,10 @@ msgstr "" | ||||
| msgid "Policy / Group / User Bindings" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/policies/PolicyListPage.ts | ||||
| msgid "Policy / Policies" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/policies/BoundPoliciesList.ts | ||||
| msgid "Policy / User / Group" | ||||
| msgstr "" | ||||
| @ -2895,8 +2956,12 @@ msgstr "" | ||||
| msgid "Policy Bindings" | ||||
| msgstr "" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Policy binding" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/policies/BoundPoliciesList.ts | ||||
| msgid "Policy binding" | ||||
| msgid "Policy binding(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/applications/ApplicationForm.ts | ||||
| @ -2965,27 +3030,35 @@ msgstr "" | ||||
| msgid "Profile URL" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/stages/prompt/PromptListPage.ts | ||||
| msgid "Prompt" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Prompt" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/stages/consent/ConsentStageForm.ts | ||||
| msgid "Prompt for the user's consent. The consent can either be permanent or expire in a defined amount of time." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/stages/prompt/PromptListPage.ts | ||||
| msgid "Prompt(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/stages/prompt/PromptListPage.ts | ||||
| msgid "Prompts" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/property-mappings/PropertyMappingListPage.ts | ||||
| msgid "Property Mapping" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Property Mapping" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/events/utils.ts | ||||
| msgid "Property Mapping exception" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/property-mappings/PropertyMappingListPage.ts | ||||
| msgid "Property Mapping(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/property-mappings/PropertyMappingListPage.ts | ||||
| msgid "Property Mappings" | ||||
| @ -3025,7 +3098,6 @@ msgstr "" | ||||
| #: src/pages/applications/ApplicationForm.ts | ||||
| #: src/pages/applications/ApplicationListPage.ts | ||||
| #: src/pages/applications/ApplicationViewPage.ts | ||||
| #: src/pages/providers/ProviderListPage.ts | ||||
| msgid "Provider" | ||||
| msgstr "" | ||||
|  | ||||
| @ -3034,8 +3106,12 @@ msgstr "" | ||||
| msgid "Provider Type" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/sources/oauth/OAuthSourceForm.ts | ||||
| msgid "Provider type" | ||||
| #:  | ||||
| #~ msgid "Provider type" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/providers/ProviderListPage.ts | ||||
| msgid "Provider(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| @ -3160,8 +3236,12 @@ msgstr "" | ||||
| msgid "Refresh" | ||||
| msgstr "" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Refresh Code" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/elements/oauth/UserRefreshList.ts | ||||
| msgid "Refresh Code" | ||||
| msgid "Refresh Code(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/flows/stages/authenticator_webauthn/WebAuthnAuthenticatorRegisterStage.ts | ||||
| @ -3411,7 +3491,7 @@ msgstr "" | ||||
| msgid "Selected policies are executed when the stage is submitted to validate the data." | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Selecting a service-connection enables the management of the outpost by authentik." | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -3460,15 +3540,15 @@ msgstr "" | ||||
| msgid "Server and client are further than 5 seconds apart." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| msgid "Server name for which this provider's certificate is valid for." | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Server name for which this provider's certificate is valid for." | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/flows/stages/authenticator_webauthn/WebAuthnAuthenticatorRegisterStage.ts | ||||
| msgid "Server validation of credential failed: {err}" | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Service Connections" | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -3476,14 +3556,14 @@ msgstr "" | ||||
| msgid "Service Provider Binding" | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Service connection" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/elements/user/SessionList.ts | ||||
| msgid "Session" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Session" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/stages/user_login/UserLoginStageForm.ts | ||||
| msgid "Session duration" | ||||
| @ -3497,6 +3577,10 @@ msgstr "" | ||||
| msgid "Session valid not on or after" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/user/SessionList.ts | ||||
| msgid "Session(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/users/UserViewPage.ts | ||||
| msgid "Sessions" | ||||
| msgstr "" | ||||
| @ -3577,18 +3661,23 @@ msgstr "" | ||||
| msgid "Something went wrong! Please try again later." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/sources/SourcesListPage.ts | ||||
| msgid "Source" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "Source" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/events/utils.ts | ||||
| msgid "Source linked" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/user-settings/settings/SourceSettingsOAuth.ts | ||||
| #: src/pages/user-settings/settings/SourceSettingsPlex.ts | ||||
| msgid "Source {0}" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/sources/SourcesListPage.ts | ||||
| msgid "Source(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/sources/SourcesListPage.ts | ||||
| #: src/pages/stages/identification/IdentificationStageForm.ts | ||||
| @ -3611,8 +3700,12 @@ msgstr "" | ||||
| msgid "Stage Configuration" | ||||
| msgstr "" | ||||
|  | ||||
| #:  | ||||
| #~ msgid "Stage binding" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/flows/BoundStagesList.ts | ||||
| msgid "Stage binding" | ||||
| msgid "Stage binding(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/stages/authenticator_validate/AuthenticatorValidateStageForm.ts | ||||
| @ -3639,6 +3732,10 @@ msgstr "" | ||||
| msgid "Stage used to validate any authenticator. This stage should be used during authentication or authorization flows." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/stages/StageListPage.ts | ||||
| msgid "Stage(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/stages/authenticator_duo/AuthenticatorDuoStageForm.ts | ||||
| #: src/pages/stages/authenticator_static/AuthenticatorStaticStageForm.ts | ||||
| #: src/pages/stages/authenticator_totp/AuthenticatorTOTPStageForm.ts | ||||
| @ -3796,8 +3893,8 @@ msgstr "" | ||||
| msgid "Successfully created rule." | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Successfully created service-connection." | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -3846,7 +3943,7 @@ msgid "Successfully created user." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "Successfully deleted {0} {1}" | ||||
| msgstr "" | ||||
|  | ||||
| @ -3950,8 +4047,8 @@ msgstr "" | ||||
| msgid "Successfully updated rule." | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #: | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Successfully updated service-connection." | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -4070,9 +4167,9 @@ msgstr "" | ||||
| msgid "TLS Authentication Certificate" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/providers/ldap/LDAPProviderForm.ts | ||||
| msgid "TLS Server name" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "TLS Server name" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/outposts/ServiceConnectionDockerForm.ts | ||||
| msgid "TLS Verification Certificate" | ||||
| @ -4099,10 +4196,13 @@ msgid "Template" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/events/EventListPage.ts | ||||
| #: src/pages/tenants/TenantListPage.ts | ||||
| msgid "Tenant" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/tenants/TenantListPage.ts | ||||
| msgid "Tenant(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/tenants/TenantListPage.ts | ||||
| msgid "Tenants" | ||||
| @ -4139,11 +4239,11 @@ msgstr "" | ||||
| msgid "The external URL you'll authenticate at. Can be the same domain as authentik." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| msgid "The following objects use {0}:" | ||||
| msgstr "" | ||||
| #:  | ||||
| #~ msgid "The following objects use {0}:" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "The following objects use {objName}" | ||||
| msgstr "" | ||||
|  | ||||
| @ -4243,10 +4343,10 @@ msgstr "" | ||||
| msgid "To use SSL instead, use 'ldaps://' and disable this option." | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/tokens/TokenListPage.ts | ||||
| #: src/pages/user-settings/tokens/UserTokenList.ts | ||||
| msgid "Token" | ||||
| msgstr "" | ||||
| #:  | ||||
| #:  | ||||
| #~ msgid "Token" | ||||
| #~ msgstr "" | ||||
|  | ||||
| #: src/pages/providers/oauth2/OAuth2ProviderViewPage.ts | ||||
| #: src/pages/sources/oauth/OAuthSourceViewPage.ts | ||||
| @ -4265,6 +4365,11 @@ msgstr "" | ||||
| msgid "Token validity" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/pages/tokens/TokenListPage.ts | ||||
| #: src/pages/user-settings/tokens/UserTokenList.ts | ||||
| msgid "Token(s)" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/flows/stages/authenticator_static/AuthenticatorStaticStage.ts | ||||
| #: src/interfaces/AdminInterface.ts | ||||
| #: src/pages/tokens/TokenListPage.ts | ||||
| @ -4381,7 +4486,7 @@ msgstr "" | ||||
| msgid "Unknown" | ||||
| msgstr "" | ||||
|  | ||||
| #: | ||||
| #:  | ||||
| #~ msgid "Unmanaged" | ||||
| #~ msgstr "" | ||||
|  | ||||
| @ -4688,6 +4793,7 @@ msgstr "" | ||||
| #: src/pages/stages/identification/IdentificationStageForm.ts | ||||
| #: src/pages/user-settings/UserSelfForm.ts | ||||
| #: src/pages/users/UserForm.ts | ||||
| #: src/pages/users/UserListPage.ts | ||||
| #: src/pages/users/UserViewPage.ts | ||||
| msgid "Username" | ||||
| msgstr "" | ||||
| @ -4907,7 +5013,7 @@ msgstr "" | ||||
| msgid "authentik LDAP Backend" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "connecting object will be deleted" | ||||
| msgstr "" | ||||
|  | ||||
| @ -4920,17 +5026,17 @@ msgid "no tabs defined" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "object will be DELETED" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "reference will be reset to default value" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "reference will be set to an empty value" | ||||
| msgstr "" | ||||
|  | ||||
| @ -4948,7 +5054,7 @@ msgid "{0} ({1})" | ||||
| msgstr "" | ||||
|  | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteBulkForm.ts | ||||
| #: src/elements/forms/DeleteForm.ts | ||||
| msgid "{0} ({consequence})" | ||||
| msgstr "" | ||||
|  | ||||
|  | ||||
| @ -40,6 +40,7 @@ export class LDAPProviderFormPage extends ModelForm<LDAPProvider, number> { | ||||
|                 lDAPProviderRequest: data, | ||||
|             }); | ||||
|         } else { | ||||
|             data.tlsServerName = ""; | ||||
|             return new ProvidersApi(DEFAULT_CONFIG).providersLdapCreate({ | ||||
|                 lDAPProviderRequest: data, | ||||
|             }); | ||||
| @ -129,16 +130,6 @@ export class LDAPProviderFormPage extends ModelForm<LDAPProvider, number> { | ||||
|                             ${t`LDAP DN under which bind requests and search requests can be made.`} | ||||
|                         </p> | ||||
|                     </ak-form-element-horizontal> | ||||
|                     <ak-form-element-horizontal label=${t`TLS Server name`} name="tlsServerName"> | ||||
|                         <input | ||||
|                             type="text" | ||||
|                             value="${first(this.instance?.tlsServerName, "")}" | ||||
|                             class="pf-c-form-control" | ||||
|                         /> | ||||
|                         <p class="pf-c-form__helper-text"> | ||||
|                             ${t`Server name for which this provider's certificate is valid for.`} | ||||
|                         </p> | ||||
|                     </ak-form-element-horizontal> | ||||
|                     <ak-form-element-horizontal label=${t`Certificate`} name="certificate"> | ||||
|                         <select class="pf-c-form-control"> | ||||
|                             <option value="" ?selected=${this.instance?.certificate === undefined}> | ||||
| @ -163,6 +154,12 @@ export class LDAPProviderFormPage extends ModelForm<LDAPProvider, number> { | ||||
|                                 html`<option>${t`Loading...`}</option>`, | ||||
|                             )} | ||||
|                         </select> | ||||
|                         <p class="pf-c-form__helper-text"> | ||||
|                             ${t`Due to protocol limitations, this certificate is only used when the outpost has a single provider.`} | ||||
|                         </p> | ||||
|                         <p class="pf-c-form__helper-text"> | ||||
|                             ${t`If multiple providers share an outpost, a self-signed certificate is used.`} | ||||
|                         </p> | ||||
|                     </ak-form-element-horizontal> | ||||
|                     <ak-form-element-horizontal | ||||
|                         label=${t`UID start number`} | ||||
|  | ||||
| @ -5,6 +5,7 @@ import { | ||||
|     UserMatchingModeEnum, | ||||
|     OAuthSourceRequest, | ||||
|     FlowsInstancesListDesignationEnum, | ||||
|     SourceType, | ||||
| } from "@goauthentik/api"; | ||||
| import { t } from "@lingui/macro"; | ||||
| import { customElement, property } from "lit-element"; | ||||
| @ -25,19 +26,30 @@ export class OAuthSourceForm extends ModelForm<OAuthSource, string> { | ||||
|                 slug: pk, | ||||
|             }) | ||||
|             .then((source) => { | ||||
|                 this.showUrlOptions = first(source.type?.urlsCustomizable, false); | ||||
|                 this.providerType = source.type; | ||||
|                 return source; | ||||
|             }); | ||||
|     } | ||||
|  | ||||
|     _modelName?: string; | ||||
|  | ||||
|     @property() | ||||
|     modelName?: string; | ||||
|     set modelName(v: string | undefined) { | ||||
|         this._modelName = v; | ||||
|         new SourcesApi(DEFAULT_CONFIG) | ||||
|             .sourcesOauthSourceTypesList({ | ||||
|                 name: v?.replace("oauthsource", ""), | ||||
|             }) | ||||
|             .then((type) => { | ||||
|                 this.providerType = type[0]; | ||||
|             }); | ||||
|     } | ||||
|     get modelName(): string | undefined { | ||||
|         return this._modelName; | ||||
|     } | ||||
|  | ||||
|     @property({ type: Boolean }) | ||||
|     showUrlOptions = false; | ||||
|  | ||||
|     @property({ type: Boolean }) | ||||
|     showRequestTokenURL = false; | ||||
|     @property({ attribute: false }) | ||||
|     providerType?: SourceType; | ||||
|  | ||||
|     getSuccessMessage(): string { | ||||
|         if (this.instance) { | ||||
| @ -48,6 +60,7 @@ export class OAuthSourceForm extends ModelForm<OAuthSource, string> { | ||||
|     } | ||||
|  | ||||
|     send = (data: OAuthSource): Promise<OAuthSource> => { | ||||
|         data.providerType = this.providerType?.slug || ""; | ||||
|         if (this.instance?.slug) { | ||||
|             return new SourcesApi(DEFAULT_CONFIG).sourcesOauthPartialUpdate({ | ||||
|                 slug: this.instance.slug, | ||||
| @ -61,7 +74,7 @@ export class OAuthSourceForm extends ModelForm<OAuthSource, string> { | ||||
|     }; | ||||
|  | ||||
|     renderUrlOptions(): TemplateResult { | ||||
|         if (!this.showUrlOptions) { | ||||
|         if (!this.providerType?.urlsCustomizable) { | ||||
|             return html``; | ||||
|         } | ||||
|         return html` <ak-form-group> | ||||
| @ -74,7 +87,10 @@ export class OAuthSourceForm extends ModelForm<OAuthSource, string> { | ||||
|                 > | ||||
|                     <input | ||||
|                         type="text" | ||||
|                         value="${first(this.instance?.authorizationUrl, "")}" | ||||
|                         value="${first( | ||||
|                             this.instance?.authorizationUrl, | ||||
|                             this.providerType.authorizationUrl, | ||||
|                         )}" | ||||
|                         class="pf-c-form-control" | ||||
|                         required | ||||
|                     /> | ||||
| @ -89,7 +105,10 @@ export class OAuthSourceForm extends ModelForm<OAuthSource, string> { | ||||
|                 > | ||||
|                     <input | ||||
|                         type="text" | ||||
|                         value="${first(this.instance?.accessTokenUrl, "")}" | ||||
|                         value="${first( | ||||
|                             this.instance?.accessTokenUrl, | ||||
|                             this.providerType.accessTokenUrl, | ||||
|                         )}" | ||||
|                         class="pf-c-form-control" | ||||
|                         required | ||||
|                     /> | ||||
| @ -104,7 +123,7 @@ export class OAuthSourceForm extends ModelForm<OAuthSource, string> { | ||||
|                 > | ||||
|                     <input | ||||
|                         type="text" | ||||
|                         value="${first(this.instance?.profileUrl, "")}" | ||||
|                         value="${first(this.instance?.profileUrl, this.providerType.profileUrl)}" | ||||
|                         class="pf-c-form-control" | ||||
|                         required | ||||
|                     /> | ||||
| @ -112,7 +131,7 @@ export class OAuthSourceForm extends ModelForm<OAuthSource, string> { | ||||
|                         ${t`URL used by authentik to get user information.`} | ||||
|                     </p> | ||||
|                 </ak-form-element-horizontal> | ||||
|                 ${this.showRequestTokenURL | ||||
|                 ${this.providerType.requestTokenUrl | ||||
|                     ? html`<ak-form-element-horizontal | ||||
|                           label=${t`Request token URL`} | ||||
|                           name="requestTokenUrl" | ||||
| @ -226,54 +245,6 @@ export class OAuthSourceForm extends ModelForm<OAuthSource, string> { | ||||
|                     > | ||||
|                         <input type="text" value="" class="pf-c-form-control" required /> | ||||
|                     </ak-form-element-horizontal> | ||||
|                     <ak-form-element-horizontal label=${t`Provider type`} name="providerType"> | ||||
|                         <select | ||||
|                             class="pf-c-form-control" | ||||
|                             @change=${(ev: Event) => { | ||||
|                                 const el = ev.target as HTMLSelectElement; | ||||
|                                 const selected = el.selectedOptions[0]; | ||||
|                                 this.showUrlOptions = "data-urls-custom" in selected.attributes; | ||||
|                                 this.showRequestTokenURL = | ||||
|                                     "data-request-token" in selected.attributes; | ||||
|                                 if (!this.instance) { | ||||
|                                     this.instance = {} as OAuthSource; | ||||
|                                 } | ||||
|                                 this.instance.providerType = selected.value; | ||||
|                             }} | ||||
|                         > | ||||
|                             ${until( | ||||
|                                 new SourcesApi(DEFAULT_CONFIG) | ||||
|                                     .sourcesOauthSourceTypesList() | ||||
|                                     .then((types) => { | ||||
|                                         return types.map((type) => { | ||||
|                                             let selected = | ||||
|                                                 this.instance?.providerType === type.slug; | ||||
|                                             const modelSlug = this.modelName | ||||
|                                                 ?.replace("oauthsource", "") | ||||
|                                                 .replace("-", ""); | ||||
|                                             const typeSlug = type.slug.replace("-", ""); | ||||
|                                             if (!this.instance?.pk) { | ||||
|                                                 if (modelSlug === typeSlug) { | ||||
|                                                     selected = true; | ||||
|                                                     this.showUrlOptions = type.urlsCustomizable; | ||||
|                                                     this.showRequestTokenURL = | ||||
|                                                         type.requestTokenUrl !== null; | ||||
|                                                 } | ||||
|                                             } | ||||
|                                             return html`<option | ||||
|                                                 ?data-urls-custom=${type.urlsCustomizable} | ||||
|                                                 ?data-request-token=${type.requestTokenUrl} | ||||
|                                                 value=${type.slug} | ||||
|                                                 ?selected=${selected} | ||||
|                                             > | ||||
|                                                 ${type.name} | ||||
|                                             </option>`; | ||||
|                                         }); | ||||
|                                     }), | ||||
|                                 html`<option>${t`Loading...`}</option>`, | ||||
|                             )} | ||||
|                         </select> | ||||
|                     </ak-form-element-horizontal> | ||||
|                 </div> | ||||
|             </ak-form-group> | ||||
|             ${this.renderUrlOptions()} | ||||
|  | ||||
| @ -27,6 +27,7 @@ import "./settings/UserSettingsAuthenticatorTOTP"; | ||||
| import "./settings/UserSettingsAuthenticatorWebAuthn"; | ||||
| import "./settings/UserSettingsPassword"; | ||||
| import "./settings/SourceSettingsOAuth"; | ||||
| import "./settings/SourceSettingsPlex"; | ||||
| import { EVENT_REFRESH } from "../../constants"; | ||||
|  | ||||
| @customElement("ak-user-settings") | ||||
| @ -112,6 +113,12 @@ export class UserSettingsPage extends LitElement { | ||||
|                     .configureUrl=${source.configureUrl} | ||||
|                 > | ||||
|                 </ak-user-settings-source-oauth>`; | ||||
|             case "ak-user-settings-source-plex": | ||||
|                 return html`<ak-user-settings-source-plex | ||||
|                     objectId=${source.objectUid} | ||||
|                     title=${source.title} | ||||
|                 > | ||||
|                 </ak-user-settings-source-plex>`; | ||||
|             default: | ||||
|                 return html`<p>${t`Error: unsupported source settings: ${source.component}`}</p>`; | ||||
|         } | ||||
|  | ||||
| @ -21,7 +21,7 @@ export class SourceSettingsOAuth extends BaseUserSettings { | ||||
|     renderInner(): TemplateResult { | ||||
|         return html`${until( | ||||
|             new SourcesApi(DEFAULT_CONFIG) | ||||
|                 .sourcesOauthUserConnectionsList({ | ||||
|                 .sourcesUserConnectionsOauthList({ | ||||
|                     sourceSlug: this.objectId, | ||||
|                 }) | ||||
|                 .then((connection) => { | ||||
| @ -32,7 +32,7 @@ export class SourceSettingsOAuth extends BaseUserSettings { | ||||
|                                 @click=${() => { | ||||
|                                     return new SourcesApi( | ||||
|                                         DEFAULT_CONFIG, | ||||
|                                     ).sourcesOauthUserConnectionsDestroy({ | ||||
|                                     ).sourcesUserConnectionsOauthDestroy({ | ||||
|                                         id: connection.results[0].pk || 0, | ||||
|                                     }); | ||||
|                                 }} | ||||
|  | ||||
							
								
								
									
										46
									
								
								web/src/pages/user-settings/settings/SourceSettingsPlex.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								web/src/pages/user-settings/settings/SourceSettingsPlex.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,46 @@ | ||||
| import { customElement, html, property, TemplateResult } from "lit-element"; | ||||
| import { BaseUserSettings } from "./BaseUserSettings"; | ||||
| import { SourcesApi } from "@goauthentik/api"; | ||||
| import { until } from "lit-html/directives/until"; | ||||
| import { DEFAULT_CONFIG } from "../../../api/Config"; | ||||
| import { t } from "@lingui/macro"; | ||||
|  | ||||
| @customElement("ak-user-settings-source-plex") | ||||
| export class SourceSettingsPlex extends BaseUserSettings { | ||||
|     @property() | ||||
|     title!: string; | ||||
|  | ||||
|     render(): TemplateResult { | ||||
|         return html`<div class="pf-c-card"> | ||||
|             <div class="pf-c-card__title">${t`Source ${this.title}`}</div> | ||||
|             <div class="pf-c-card__body">${this.renderInner()}</div> | ||||
|         </div>`; | ||||
|     } | ||||
|  | ||||
|     renderInner(): TemplateResult { | ||||
|         return html`${until( | ||||
|             new SourcesApi(DEFAULT_CONFIG) | ||||
|                 .sourcesUserConnectionsPlexList({ | ||||
|                     sourceSlug: this.objectId, | ||||
|                 }) | ||||
|                 .then((connection) => { | ||||
|                     if (connection.results.length > 0) { | ||||
|                         return html`<p>${t`Connected.`}</p> | ||||
|                             <button | ||||
|                                 class="pf-c-button pf-m-danger" | ||||
|                                 @click=${() => { | ||||
|                                     return new SourcesApi( | ||||
|                                         DEFAULT_CONFIG, | ||||
|                                     ).sourcesUserConnectionsPlexDestroy({ | ||||
|                                         id: connection.results[0].pk || 0, | ||||
|                                     }); | ||||
|                                 }} | ||||
|                             > | ||||
|                                 ${t`Disconnect`} | ||||
|                             </button>`; | ||||
|                     } | ||||
|                     return html`<p>${t`Not connected.`}</p>`; | ||||
|                 }), | ||||
|         )}`; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Jens Langhammer
					Jens Langhammer