+
{{ 'USER.PASSWORDLESS.DIALOG.SEND_DESCRIPTION' | translate }}
@@ -28,7 +28,7 @@
{{ 'USER.PASSWORDLESS.DIALOG.SEND' | translate }}
-
+
{{ 'USER.PASSWORDLESS.DIALOG.QRCODE_DESCRIPTION' | translate }}
diff --git a/console/src/app/pages/users/user-detail/auth-user-detail/auth-passwordless/dialog-passwordless/dialog-passwordless.component.scss b/console/src/app/pages/users/user-detail/auth-user-detail/auth-passwordless/dialog-passwordless/dialog-passwordless.component.scss
index 55eed0592e..0f4f837516 100644
--- a/console/src/app/pages/users/user-detail/auth-user-detail/auth-passwordless/dialog-passwordless/dialog-passwordless.component.scss
+++ b/console/src/app/pages/users/user-detail/auth-user-detail/auth-passwordless/dialog-passwordless/dialog-passwordless.component.scss
@@ -12,7 +12,7 @@
margin: 0;
}
-.desc {
+.passwordless-desc {
display: flex;
align-items: center;
padding-top: 1rem;
diff --git a/console/src/app/pages/users/user-detail/auth-user-detail/auth-user-detail.component.html b/console/src/app/pages/users/user-detail/auth-user-detail/auth-user-detail.component.html
index 9d58f480f4..0946bdef04 100644
--- a/console/src/app/pages/users/user-detail/auth-user-detail/auth-user-detail.component.html
+++ b/console/src/app/pages/users/user-detail/auth-user-detail/auth-user-detail.component.html
@@ -130,7 +130,13 @@
-
+
diff --git a/console/src/app/pages/users/user-detail/auth-user-detail/auth-user-detail.component.ts b/console/src/app/pages/users/user-detail/auth-user-detail/auth-user-detail.component.ts
index 0fee13f046..521f95bcd7 100644
--- a/console/src/app/pages/users/user-detail/auth-user-detail/auth-user-detail.component.ts
+++ b/console/src/app/pages/users/user-detail/auth-user-detail/auth-user-detail.component.ts
@@ -6,15 +6,18 @@ import { ActivatedRoute, Params } from '@angular/router';
import { TranslateService } from '@ngx-translate/core';
import { Subscription, take } from 'rxjs';
import { ChangeType } from 'src/app/modules/changes/changes.component';
+import { MetadataDialogComponent } from 'src/app/modules/metadata/metadata-dialog/metadata-dialog.component';
import { SidenavSetting } from 'src/app/modules/sidenav/sidenav.component';
import { UserGrantContext } from 'src/app/modules/user-grants/user-grants-datasource';
import { WarnDialogComponent } from 'src/app/modules/warn-dialog/warn-dialog.component';
+import { Metadata } from 'src/app/proto/generated/zitadel/metadata_pb';
import { Email, Gender, Phone, Profile, User, UserState } from 'src/app/proto/generated/zitadel/user_pb';
import { AuthenticationService } from 'src/app/services/authentication.service';
import { Breadcrumb, BreadcrumbService, BreadcrumbType } from 'src/app/services/breadcrumb.service';
import { GrpcAuthService } from 'src/app/services/grpc-auth.service';
+import { ManagementService } from 'src/app/services/mgmt.service';
import { ToastService } from 'src/app/services/toast.service';
-
+import { Buffer } from 'buffer';
import { EditDialogComponent, EditDialogType } from './edit-dialog/edit-dialog.component';
@Component({
@@ -30,6 +33,7 @@ export class AuthUserDetailComponent implements OnDestroy {
private subscription: Subscription = new Subscription();
public loading: boolean = false;
+ public loadingMetadata: boolean = false;
public ChangeType: any = ChangeType;
public userLoginMustBeDomain: boolean = false;
@@ -38,6 +42,8 @@ export class AuthUserDetailComponent implements OnDestroy {
public USERGRANTCONTEXT: UserGrantContext = UserGrantContext.USER;
public refreshChanges$: EventEmitter
= new EventEmitter();
+ public metadata: Metadata.AsObject[] = [];
+
public settingsList: SidenavSetting[] = [
{ id: 'general', i18nKey: 'USER.SETTINGS.GENERAL' },
{ id: 'idp', i18nKey: 'USER.SETTINGS.IDP' },
@@ -55,6 +61,7 @@ export class AuthUserDetailComponent implements OnDestroy {
public userService: GrpcAuthService,
private dialog: MatDialog,
private auth: AuthenticationService,
+ private mgmt: ManagementService,
private breadcrumbService: BreadcrumbService,
private mediaMatcher: MediaMatcher,
private _location: Location,
@@ -104,6 +111,8 @@ export class AuthUserDetailComponent implements OnDestroy {
if (resp.user) {
this.user = resp.user;
+ this.loadMetadata();
+
this.breadcrumbService.setBreadcrumb([
new Breadcrumb({
type: BreadcrumbType.AUTHUSER,
@@ -337,4 +346,45 @@ export class AuthUserDetailComponent implements OnDestroy {
}
});
}
+
+ public loadMetadata(): Promise | void {
+ if (this.user) {
+ this.loadingMetadata = true;
+ return this.mgmt
+ .listUserMetadata(this.user.id)
+ .then((resp) => {
+ this.loadingMetadata = false;
+ this.metadata = resp.resultList.map((md) => {
+ return {
+ key: md.key,
+ value: Buffer.from(md.value as string, 'base64').toString('ascii'),
+ };
+ });
+ })
+ .catch((error) => {
+ this.loadingMetadata = false;
+ this.toast.showError(error);
+ });
+ }
+ }
+
+ public editMetadata(): void {
+ if (this.user && this.user.id) {
+ const setFcn = (key: string, value: string): Promise =>
+ this.mgmt.setUserMetadata(key, Buffer.from(value).toString('base64'), this.user?.id ?? '');
+ const removeFcn = (key: string): Promise => this.mgmt.removeUserMetadata(key, this.user?.id ?? '');
+
+ const dialogRef = this.dialog.open(MetadataDialogComponent, {
+ data: {
+ metadata: this.metadata,
+ setFcn: setFcn,
+ removeFcn: removeFcn,
+ },
+ });
+
+ dialogRef.afterClosed().subscribe(() => {
+ this.loadMetadata();
+ });
+ }
+ }
}
diff --git a/console/src/app/pages/users/user-detail/metadata/metadata.component.html b/console/src/app/pages/users/user-detail/metadata/metadata.component.html
deleted file mode 100644
index 88551c32aa..0000000000
--- a/console/src/app/pages/users/user-detail/metadata/metadata.component.html
+++ /dev/null
@@ -1,25 +0,0 @@
-
-
-
-
-
-
-
-
- {{ md.key }}
- {{ md.value }}
-
-
-
-
- {{ 'USER.METADATA.EMPTY' | translate }}
-
-
diff --git a/console/src/app/pages/users/user-detail/metadata/metadata.component.ts b/console/src/app/pages/users/user-detail/metadata/metadata.component.ts
deleted file mode 100644
index 6fce3c3075..0000000000
--- a/console/src/app/pages/users/user-detail/metadata/metadata.component.ts
+++ /dev/null
@@ -1,55 +0,0 @@
-import { Component, Input, OnInit } from '@angular/core';
-import { MatDialog } from '@angular/material/dialog';
-import { Metadata } from 'src/app/proto/generated/zitadel/metadata_pb';
-import { ManagementService } from 'src/app/services/mgmt.service';
-import { ToastService } from 'src/app/services/toast.service';
-
-import { MetadataDialogComponent } from '../metadata-dialog/metadata-dialog.component';
-
-@Component({
- selector: 'cnsl-metadata',
- templateUrl: './metadata.component.html',
- styleUrls: ['./metadata.component.scss'],
-})
-export class MetadataComponent implements OnInit {
- @Input() userId: string = '';
- public metadata: Metadata.AsObject[] = [];
- public loading: boolean = false;
-
- constructor(private dialog: MatDialog, private service: ManagementService, private toast: ToastService) {}
-
- ngOnInit(): void {
- this.loadMetadata();
- }
-
- public editMetadata(): void {
- const dialogRef = this.dialog.open(MetadataDialogComponent, {
- data: {
- userId: this.userId,
- },
- });
-
- dialogRef.afterClosed().subscribe(() => {
- this.loadMetadata();
- });
- }
-
- public loadMetadata(): Promise {
- this.loading = true;
- return (this.service as ManagementService)
- .listUserMetadata(this.userId)
- .then((resp) => {
- this.loading = false;
- this.metadata = resp.resultList.map((md) => {
- return {
- key: md.key,
- value: atob(md.value as string),
- };
- });
- })
- .catch((error) => {
- this.loading = false;
- this.toast.showError(error);
- });
- }
-}
diff --git a/console/src/app/pages/users/user-detail/user-detail.module.ts b/console/src/app/pages/users/user-detail/user-detail.module.ts
index e0980e8a20..2d40a29faf 100644
--- a/console/src/app/pages/users/user-detail/user-detail.module.ts
+++ b/console/src/app/pages/users/user-detail/user-detail.module.ts
@@ -52,12 +52,11 @@ import { ContactComponent } from './contact/contact.component';
import { DetailFormMachineModule } from './detail-form-machine/detail-form-machine.module';
import { DetailFormModule } from './detail-form/detail-form.module';
import { ExternalIdpsComponent } from './external-idps/external-idps.component';
-import { MetadataDialogComponent } from './metadata-dialog/metadata-dialog.component';
-import { MetadataComponent } from './metadata/metadata.component';
import { PasswordComponent } from './password/password.component';
import { PasswordlessComponent } from './user-detail/passwordless/passwordless.component';
import { UserDetailComponent } from './user-detail/user-detail.component';
import { UserMfaComponent } from './user-detail/user-mfa/user-mfa.component';
+import { MetadataModule } from 'src/app/modules/metadata/metadata.module';
@NgModule({
declarations: [
@@ -76,8 +75,6 @@ import { UserMfaComponent } from './user-detail/user-mfa/user-mfa.component';
DialogU2FComponent,
DialogPasswordlessComponent,
AuthFactorDialogComponent,
- MetadataDialogComponent,
- MetadataComponent,
],
imports: [
ChangesModule,
@@ -95,6 +92,7 @@ import { UserMfaComponent } from './user-detail/user-mfa/user-mfa.component';
ShowTokenDialogModule,
MetaLayoutModule,
MatCheckboxModule,
+ MetadataModule,
TopViewModule,
HasRolePipeModule,
UserGrantsModule,
diff --git a/console/src/app/pages/users/user-detail/user-detail/user-detail.component.html b/console/src/app/pages/users/user-detail/user-detail/user-detail.component.html
index 2bb025bb6b..8b9b4e30fc 100644
--- a/console/src/app/pages/users/user-detail/user-detail/user-detail.component.html
+++ b/console/src/app/pages/users/user-detail/user-detail/user-detail.component.html
@@ -206,7 +206,13 @@
-
+
diff --git a/console/src/app/pages/users/user-detail/user-detail/user-detail.component.ts b/console/src/app/pages/users/user-detail/user-detail/user-detail.component.ts
index a42a22f9be..2b54ccc6c7 100644
--- a/console/src/app/pages/users/user-detail/user-detail/user-detail.component.ts
+++ b/console/src/app/pages/users/user-detail/user-detail/user-detail.component.ts
@@ -7,6 +7,7 @@ import { TranslateService } from '@ngx-translate/core';
import { take } from 'rxjs/operators';
import { ChangeType } from 'src/app/modules/changes/changes.component';
import { InfoSectionType } from 'src/app/modules/info-section/info-section.component';
+import { MetadataDialogComponent } from 'src/app/modules/metadata/metadata-dialog/metadata-dialog.component';
import { SidenavSetting } from 'src/app/modules/sidenav/sidenav.component';
import { UserGrantContext } from 'src/app/modules/user-grants/user-grants-datasource';
import { WarnDialogComponent } from 'src/app/modules/warn-dialog/warn-dialog.component';
@@ -16,7 +17,7 @@ import { Email, Gender, Machine, Phone, Profile, User, UserState } from 'src/app
import { Breadcrumb, BreadcrumbService, BreadcrumbType } from 'src/app/services/breadcrumb.service';
import { ManagementService } from 'src/app/services/mgmt.service';
import { ToastService } from 'src/app/services/toast.service';
-
+import { Buffer } from 'buffer';
import { EditDialogComponent, EditDialogType } from '../auth-user-detail/edit-dialog/edit-dialog.component';
import { ResendEmailDialogComponent } from '../auth-user-detail/resend-email-dialog/resend-email-dialog.component';
@@ -42,7 +43,9 @@ export class UserDetailComponent implements OnInit {
public languages: string[] = ['de', 'en', 'it', 'fr'];
public ChangeType: any = ChangeType;
+
public loading: boolean = true;
+ public loadingMetadata: boolean = true;
public UserState: any = UserState;
public copied: string = '';
@@ -113,6 +116,7 @@ export class UserDetailComponent implements OnInit {
this.mgmtUserService
.getUserByID(id)
.then((resp) => {
+ this.loadMetadata(id);
this.loading = false;
if (resp.user) {
this.user = resp.user;
@@ -129,17 +133,6 @@ export class UserDetailComponent implements OnInit {
this.loading = false;
this.toast.showError(err);
});
-
- this.mgmtUserService
- .listUserMetadata(id, 0, 100, [])
- .then((resp) => {
- if (resp.resultList) {
- this.metadata = resp.resultList;
- }
- })
- .catch((err) => {
- console.error(err);
- });
});
}
@@ -448,4 +441,43 @@ export class UserDetailComponent implements OnInit {
break;
}
}
+
+ public loadMetadata(id: string): Promise
| void {
+ this.loadingMetadata = true;
+ return this.mgmtUserService
+ .listUserMetadata(id)
+ .then((resp) => {
+ this.loadingMetadata = false;
+ this.metadata = resp.resultList.map((md) => {
+ return {
+ key: md.key,
+ value: Buffer.from(md.value as string, 'base64').toString('ascii'),
+ };
+ });
+ })
+ .catch((error) => {
+ this.loadingMetadata = false;
+ this.toast.showError(error);
+ });
+ }
+
+ public editMetadata(): void {
+ if (this.user) {
+ const setFcn = (key: string, value: string): Promise =>
+ this.mgmtUserService.setUserMetadata(key, Buffer.from(value).toString('base64'), this.user.id);
+ const removeFcn = (key: string): Promise => this.mgmtUserService.removeUserMetadata(key, this.user.id);
+
+ const dialogRef = this.dialog.open(MetadataDialogComponent, {
+ data: {
+ metadata: this.metadata,
+ setFcn: setFcn,
+ removeFcn: removeFcn,
+ },
+ });
+
+ dialogRef.afterClosed().subscribe(() => {
+ this.loadMetadata(this.user.id);
+ });
+ }
+ }
}
diff --git a/console/src/app/services/mgmt.service.ts b/console/src/app/services/mgmt.service.ts
index 0e1417cfc1..678db1fa68 100644
--- a/console/src/app/services/mgmt.service.ts
+++ b/console/src/app/services/mgmt.service.ts
@@ -219,6 +219,8 @@ import {
ListOrgMemberRolesResponse,
ListOrgMembersRequest,
ListOrgMembersResponse,
+ ListOrgMetadataRequest,
+ ListOrgMetadataResponse,
ListPersonalAccessTokensRequest,
ListPersonalAccessTokensResponse,
ListProjectChangesRequest,
@@ -303,6 +305,8 @@ import {
RemoveOrgIDPResponse,
RemoveOrgMemberRequest,
RemoveOrgMemberResponse,
+ RemoveOrgMetadataRequest,
+ RemoveOrgMetadataResponse,
RemovePersonalAccessTokenRequest,
RemovePersonalAccessTokenResponse,
RemoveProjectGrantMemberRequest,
@@ -371,6 +375,8 @@ import {
SetCustomVerifyPhoneMessageTextRequest,
SetCustomVerifyPhoneMessageTextResponse,
SetHumanInitialPasswordRequest,
+ SetOrgMetadataRequest,
+ SetOrgMetadataResponse,
SetPrimaryOrgDomainRequest,
SetPrimaryOrgDomainResponse,
SetTriggerActionsRequest,
@@ -1374,6 +1380,26 @@ export class ManagementService {
return this.grpcService.mgmt.listUserMetadata(req, null).then((resp) => resp.toObject());
}
+ public listOrgMetadata(
+ offset?: number,
+ limit?: number,
+ queryList?: MetadataQuery[],
+ ): Promise {
+ const req = new ListOrgMetadataRequest();
+
+ const metadata = new ListQuery();
+ if (offset) {
+ metadata.setOffset(offset);
+ }
+ if (limit) {
+ metadata.setLimit(limit);
+ }
+ if (queryList) {
+ req.setQueriesList(queryList);
+ }
+ return this.grpcService.mgmt.listOrgMetadata(req, null).then((resp) => resp.toObject());
+ }
+
public getUserMetadata(userId: string, key: string): Promise {
const req = new GetUserMetadataRequest();
req.setId(userId);
@@ -1389,6 +1415,13 @@ export class ManagementService {
return this.grpcService.mgmt.setUserMetadata(req, null).then((resp) => resp.toObject());
}
+ public setOrgMetadata(key: string, value: string): Promise {
+ const req = new SetOrgMetadataRequest();
+ req.setKey(key);
+ req.setValue(value);
+ return this.grpcService.mgmt.setOrgMetadata(req, null).then((resp) => resp.toObject());
+ }
+
public bulkSetUserMetadata(
list: BulkSetUserMetadataRequest.Metadata[],
userId: string,
@@ -1406,6 +1439,12 @@ export class ManagementService {
return this.grpcService.mgmt.removeUserMetadata(req, null).then((resp) => resp.toObject());
}
+ public removeOrgMetadata(key: string): Promise {
+ const req = new RemoveOrgMetadataRequest();
+ req.setKey(key);
+ return this.grpcService.mgmt.removeOrgMetadata(req, null).then((resp) => resp.toObject());
+ }
+
public removeUser(id: string): Promise {
const req = new RemoveUserRequest();
req.setId(id);
diff --git a/console/src/assets/i18n/de.json b/console/src/assets/i18n/de.json
index 4011953191..24038388c9 100644
--- a/console/src/assets/i18n/de.json
+++ b/console/src/assets/i18n/de.json
@@ -294,7 +294,7 @@
"TITLE": "Passwortlose Authentifizierungsmethoden",
"DESCRIPTION": "Füge WebAuthn kompatible Authentifikatoren hinzu um dich passwortlos anzumelden.",
"MANAGE_DESCRIPTION": "Verwalte die Multifaktor-Merkmale Deiner Benutzer.",
- "U2F": "Authentifikator hinzufügen",
+ "U2F": "Methode hinzufügen",
"U2F_DIALOG_TITLE": "Authentifikator hinzufügen",
"U2F_DIALOG_DESCRIPTION": "Gib einen Namen für den von dir verwendeten Login an.",
"U2F_SUCCESS": "Passwortlos erfolgreich erstellt!",
@@ -326,17 +326,6 @@
"NEW": "Hinzufügen"
}
},
- "METADATA": {
- "TITLE": "Metadata",
- "DESCRIPTION": "",
- "KEY": "Schlüssel",
- "VALUE": "Wert",
- "ADD": "Neues Element",
- "SAVE": "Speichern",
- "EMPTY": "Keine Metadaten",
- "SETSUCCESS": "Element erfolgreich gespeichert",
- "REMOVESUCCESS": "Element erfolgreich gelöscht"
- },
"MFA": {
"TABLETYPE": "Typ",
"TABLESTATE": "Status",
@@ -346,7 +335,7 @@
"DESCRIPTION": "Füge einen zusätzlichen Faktor hinzu, um Dein Konto optimal zu schützen.",
"MANAGE_DESCRIPTION": "Verwalte die Multifaktor-Merkmale Deiner Benutzer.",
"ADD": "Faktor hinzufügen",
- "OTP": "OTP (One-Time Password)",
+ "OTP": "Authentikator App für OTP (One-Time Password)",
"OTP_DIALOG_TITLE": "OTP hinzufügen",
"OTP_DIALOG_DESCRIPTION": "Scanne den QR-Code mit einer Authenticator App und verifiziere den erhaltenen Code, um OTP zu aktivieren.",
"U2F": "Fingerabdruck, Security Key, Face ID oder andere",
@@ -639,6 +628,17 @@
"DELETED": "Personal Access Token gelöscht."
}
},
+ "METADATA": {
+ "TITLE": "Metadata",
+ "DESCRIPTION": "",
+ "KEY": "Schlüssel",
+ "VALUE": "Wert",
+ "ADD": "Neues Element",
+ "SAVE": "Speichern",
+ "EMPTY": "Keine Metadaten",
+ "SETSUCCESS": "Element erfolgreich gespeichert",
+ "REMOVESUCCESS": "Element erfolgreich gelöscht"
+ },
"FLOWS": {
"TITLE": "Aktionen und Abläufe",
"DESCRIPTION": "Hinterlege scripts die bei einem bestimmten Event ausgeführt werden.",
diff --git a/console/src/assets/i18n/en.json b/console/src/assets/i18n/en.json
index d247253316..28ed9d3a7c 100644
--- a/console/src/assets/i18n/en.json
+++ b/console/src/assets/i18n/en.json
@@ -294,7 +294,7 @@
"TITLE": "Passwordless Authentication",
"DESCRIPTION": "Add WebAuthn based Authentication Methods to log onto ZITADEL passwordless.",
"MANAGE_DESCRIPTION": "Manage the second factor methods of your users.",
- "U2F": "Add authenticator",
+ "U2F": "Add method",
"U2F_DIALOG_TITLE": "Verify authenticator",
"U2F_DIALOG_DESCRIPTION": "Enter a name for your used passwordless Login",
"U2F_SUCCESS": "Passwordless Auth created successfully!",
@@ -326,17 +326,6 @@
"NEW": "Add New"
}
},
- "METADATA": {
- "TITLE": "Metadata",
- "DESCRIPTION": "",
- "KEY": "Key",
- "VALUE": "Value",
- "ADD": "New Entry",
- "SAVE": "Save",
- "EMPTY": "No metadata",
- "SETSUCCESS": "Element saved successfully",
- "REMOVESUCCESS": "Element deleted successfully"
- },
"MFA": {
"TABLETYPE": "Type",
"TABLESTATE": "Status",
@@ -346,7 +335,7 @@
"DESCRIPTION": "Add a second factor to ensure optimal security for your account.",
"MANAGE_DESCRIPTION": "Manage the second factor methods of your users.",
"ADD": "Add Factor",
- "OTP": "OTP (One-Time Password)",
+ "OTP": "Authenticator App for OTP (One-Time Password)",
"OTP_DIALOG_TITLE": "Add OTP",
"OTP_DIALOG_DESCRIPTION": "Scan the QR code with an authenticator app and enter the code below to verify and activate the OTP method.",
"U2F": "Fingerprint, Security Keys, Face ID and other",
@@ -639,6 +628,17 @@
"DELETED": "Token deleted with success."
}
},
+ "METADATA": {
+ "TITLE": "Metadata",
+ "DESCRIPTION": "",
+ "KEY": "Key",
+ "VALUE": "Value",
+ "ADD": "New Entry",
+ "SAVE": "Save",
+ "EMPTY": "No metadata",
+ "SETSUCCESS": "Element saved successfully",
+ "REMOVESUCCESS": "Element deleted successfully"
+ },
"FLOWS": {
"TITLE": "Actions and Flows",
"DESCRIPTION": "Define scripts to execute on a certain event.",
diff --git a/console/src/assets/i18n/fr.json b/console/src/assets/i18n/fr.json
index 8fe94a2465..b3416cc1ae 100644
--- a/console/src/assets/i18n/fr.json
+++ b/console/src/assets/i18n/fr.json
@@ -294,7 +294,7 @@
"TITLE": "Authentification sans mot de passe",
"DESCRIPTION": "Ajoutez des méthodes d'authentification basées sur WebAuthn pour vous connecter à ZITADEL sans mot de passe.",
"MANAGE_DESCRIPTION": "Gérez les méthodes de second facteur de vos utilisateurs.",
- "U2F": "Ajouter un authentifiant",
+ "U2F": "Ajouter une méthode",
"U2F_DIALOG_TITLE": "Vérifier l'authentifiant",
"U2F_DIALOG_DESCRIPTION": "Entrez un nom pour votre connexion sans mot de passe utilisée",
"U2F_SUCCESS": "Auth sans mot de passe créé avec succès !",
@@ -326,17 +326,6 @@
"NEW": "Ajouter un nouveau"
}
},
- "METADATA": {
- "TITLE": "Métadonnées",
- "DESCRIPTION": "",
- "KEY": "Clé",
- "VALUE": "Valeur",
- "ADD": "Nouvelle entrée",
- "SAVE": "Enregistrer",
- "EMPTY": "Pas de métadonnées",
- "SETSUCCESS": "Élément sauvegardé avec succès",
- "REMOVESUCCESS": "Élément supprimé avec succès"
- },
"MFA": {
"TABLETYPE": "Type",
"TABLESTATE": "Statut",
@@ -346,7 +335,7 @@
"DESCRIPTION": "Ajoutez un second facteur pour garantir une sécurité optimale de votre compte.",
"MANAGE_DESCRIPTION": "Gérez les méthodes de second facteur de vos utilisateurs.",
"ADD": "Ajouter un facteur",
- "OTP": "OTP (mot de passe à usage unique)",
+ "OTP": "Application d'authentification pour OTP (One-time password)",
"OTP_DIALOG_TITLE": "Ajouter un OTP",
"OTP_DIALOG_DESCRIPTION": "Scannez le code QR avec une application d'authentification et saisissez le code ci-dessous pour vérifier et activer la méthode OTP.",
"U2F": "Empreinte digitale, clés de sécurité, Face ID et autres",
@@ -639,6 +628,17 @@
"DELETED": "Jeton supprimé avec succès."
}
},
+ "METADATA": {
+ "TITLE": "Métadonnées",
+ "DESCRIPTION": "",
+ "KEY": "Clé",
+ "VALUE": "Valeur",
+ "ADD": "Nouvelle entrée",
+ "SAVE": "Enregistrer",
+ "EMPTY": "Pas de métadonnées",
+ "SETSUCCESS": "Élément sauvegardé avec succès",
+ "REMOVESUCCESS": "Élément supprimé avec succès"
+ },
"FLOWS": {
"TITLE": "Actions et flux",
"DESCRIPTION": "Définissez des scripts à exécuter lors d'un certain événement.",
diff --git a/console/src/assets/i18n/it.json b/console/src/assets/i18n/it.json
index 06338f826d..9ea0c260d5 100644
--- a/console/src/assets/i18n/it.json
+++ b/console/src/assets/i18n/it.json
@@ -294,7 +294,7 @@
"TITLE": "Autenticazione passwordless",
"DESCRIPTION": "Aggiungi i metodi di autenticazione basati su WebAuthn per accedere a ZITADEL senza password.",
"MANAGE_DESCRIPTION": "Gestisci i metodi del secondo fattore dei vostri utenti.",
- "U2F": "Aggiungi autenticatore",
+ "U2F": "Aggiungi metodo",
"U2F_DIALOG_TITLE": "Verifica autenticatore",
"U2F_DIALOG_DESCRIPTION": "Inserisci un nome per il tuo authenticatore o dispositivo usato.",
"U2F_SUCCESS": "Autorizzazione passwordless creata con successo!",
@@ -326,17 +326,6 @@
"NEW": "Aggiungi nuovo"
}
},
- "METADATA": {
- "TITLE": "Metadati",
- "DESCRIPTION": "",
- "KEY": "Chiave",
- "VALUE": "Valore",
- "ADD": "Nuova voce",
- "SAVE": "Salva",
- "EMPTY": "Nessun metadato",
- "SETSUCCESS": "Salvato con successo",
- "REMOVESUCCESS": "Rimosso con successo"
- },
"MFA": {
"TABLETYPE": "Tipo",
"TABLESTATE": "Stato",
@@ -346,7 +335,7 @@
"DESCRIPTION": "Aggiungi un secondo fattore per garantire la sicurezza ottimale del tuo account.",
"MANAGE_DESCRIPTION": "Gestite i metodi del secondo fattore dei vostri utenti.",
"ADD": "Aggiungi fattore",
- "OTP": "OTP (One-Time Password)",
+ "OTP": "App di autenticazione per OTP (One-Time Password)",
"OTP_DIALOG_TITLE": "Aggiungi OTP",
"OTP_DIALOG_DESCRIPTION": "Scansiona il codice QR con un'app di autenticazione e inserisci il codice nel campo sottostante per verificare e attivare il metodo OTP.",
"U2F": "Impronta digitale, chiave di sicurezza, Face ID e altri",
@@ -639,6 +628,17 @@
"DELETED": "Token eliminato con successo."
}
},
+ "METADATA": {
+ "TITLE": "Metadati",
+ "DESCRIPTION": "",
+ "KEY": "Chiave",
+ "VALUE": "Valore",
+ "ADD": "Nuova voce",
+ "SAVE": "Salva",
+ "EMPTY": "Nessun metadato",
+ "SETSUCCESS": "Salvato con successo",
+ "REMOVESUCCESS": "Rimosso con successo"
+ },
"FLOWS": {
"TITLE": "Azioni e Processi",
"DESCRIPTION": "Esegui processi su certi eventi.",
diff --git a/console/src/assets/i18n/zh.json b/console/src/assets/i18n/zh.json
index e8573d4049..63a7b02a3f 100644
--- a/console/src/assets/i18n/zh.json
+++ b/console/src/assets/i18n/zh.json
@@ -294,7 +294,7 @@
"TITLE": "无密码身份验证",
"DESCRIPTION": "添加基于 WebAuthn 的身份验证方法以无密码登录 ZITADEL。",
"MANAGE_DESCRIPTION": "管理用户的第二因素认证方式。",
- "U2F": "添加验证器",
+ "U2F": "添加方法",
"U2F_DIALOG_TITLE": "身份验证器",
"U2F_DIALOG_DESCRIPTION": "输入您使用的无密码登录名",
"U2F_SUCCESS": "无密码验证创建成功!",
@@ -326,17 +326,6 @@
"NEW": "添加"
}
},
- "METADATA": {
- "TITLE": "元数据",
- "DESCRIPTION": "",
- "KEY": "键",
- "VALUE": "值",
- "ADD": "新条目",
- "SAVE": "保存",
- "EMPTY": "暂无元数据",
- "SETSUCCESS": "键值对保存成功",
- "REMOVESUCCESS": "键值对删除成功"
- },
"MFA": {
"TABLETYPE": "类型",
"TABLESTATE": "状态",
@@ -346,7 +335,7 @@
"DESCRIPTION": "添加第二个因素以确保您帐户的最佳安全性。",
"MANAGE_DESCRIPTION": "管理用户的第二因素身份认证方式。",
"ADD": "添加因子",
- "OTP": "一次性密码 (OTP)",
+ "OTP": "用于 OTP 的身份验证器应用程序",
"OTP_DIALOG_TITLE": "添加 OTP",
"OTP_DIALOG_DESCRIPTION": "使用验证器应用程序扫描二维码并输入下面的代码以验证并激活 OTP 方法。",
"U2F": "指纹、安全密钥、Face ID 等",
@@ -639,6 +628,17 @@
"DELETED": "成功删除令牌。"
}
},
+ "METADATA": {
+ "TITLE": "元数据",
+ "DESCRIPTION": "",
+ "KEY": "键",
+ "VALUE": "值",
+ "ADD": "新条目",
+ "SAVE": "保存",
+ "EMPTY": "暂无元数据",
+ "SETSUCCESS": "键值对保存成功",
+ "REMOVESUCCESS": "键值对删除成功"
+ },
"FLOWS": {
"TITLE": "动作和流程",
"DESCRIPTION": "定义要在特定事件上需要执行的脚本。",