mirror of
https://github.com/zitadel/zitadel.git
synced 2025-03-01 05:47:23 +00:00
data:image/s3,"s3://crabby-images/16048/1604893f81a66cbabd06f1372cb76ac3ddb1eeb4" alt="Stefan Benz"
* feat(import): add functionality to import data into an instance * feat(import): move import to admin api and additional checks for nil pointer * fix(export): export implementation with filtered members and grants * fix: export and import implementation * fix: add possibility to export hashed passwords with the user * fix(import): import with structure of v1 and v2 * docs: add v1 proto * fix(import): check im imported user is already existing * fix(import): add otp import function * fix(import): add external idps, domains, custom text and messages * fix(import): correct usage of default values from login policy * fix(export): fix renaming of add project function * fix(import): move checks for unit tests * expect filter * fix(import): move checks for unit tests * fix(import): move checks for unit tests * fix(import): produce prerelease from branch * fix(import): correctly use provided user id for machine user imports * fix(import): corrected otp import and added guide for export and import * fix: import verified and primary domains * fix(import): add reading from gcs, s3 and localfile with tracing * fix(import): gcs and s3, file size correction and error logging * Delete docker-compose.yml * fix(import): progress logging and count of resources * fix(import): progress logging and count of resources * log subscription * fix(import): incorporate review * fix(import): incorporate review * docs: add suggestion for import Co-authored-by: Fabi <38692350+hifabienne@users.noreply.github.com> * fix(import): add verification otp event and handling of deleted but existing users Co-authored-by: Livio Amstutz <livio.a@gmail.com> Co-authored-by: Fabienne <fabienne.gerschwiler@gmail.com> Co-authored-by: Silvan <silvan.reusser@gmail.com> Co-authored-by: Fabi <38692350+hifabienne@users.noreply.github.com>
161 lines
5.7 KiB
Protocol Buffer
161 lines
5.7 KiB
Protocol Buffer
syntax = "proto3";
|
|
|
|
import "zitadel/user.proto";
|
|
import "zitadel/idp.proto";
|
|
import "zitadel/org.proto";
|
|
import "zitadel/management.proto";
|
|
|
|
import "protoc-gen-openapiv2/options/annotations.proto";
|
|
|
|
import "validate/validate.proto";
|
|
|
|
package zitadel.v1.v1;
|
|
|
|
option go_package ="github.com/zitadel/zitadel/pkg/grpc/v1";
|
|
|
|
message AddCustomOrgIAMPolicyRequest {
|
|
option (grpc.gateway.protoc_gen_openapiv2.options.openapiv2_schema) = {
|
|
json_schema: {
|
|
required: ["org_id"]
|
|
};
|
|
};
|
|
|
|
string org_id = 1 [
|
|
(validate.rules).string = {min_len: 1, max_len: 200},
|
|
(grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = {
|
|
example: "\"#69629023906488334\"";
|
|
min_length: 1;
|
|
max_length: 200;
|
|
}
|
|
];
|
|
bool user_login_must_be_domain = 2 [
|
|
(grpc.gateway.protoc_gen_openapiv2.options.openapiv2_field) = {
|
|
description: "the username has to end with the domain of it's organisation"
|
|
}
|
|
]; // the username has to end with the domain of it's organisation (uniqueness is organisation based)
|
|
}
|
|
message ImportDataOrg {
|
|
repeated DataOrg orgs = 1;
|
|
}
|
|
|
|
message DataOrg {
|
|
string org_id = 1;
|
|
zitadel.management.v1.AddOrgRequest org = 3;
|
|
AddCustomOrgIAMPolicyRequest iam_policy = 4;
|
|
zitadel.management.v1.AddCustomLabelPolicyRequest label_policy = 5;
|
|
zitadel.management.v1.AddCustomLockoutPolicyRequest lockout_policy = 6;
|
|
zitadel.management.v1.AddCustomLoginPolicyRequest login_policy = 7;
|
|
zitadel.management.v1.AddCustomPasswordComplexityPolicyRequest password_complexity_policy = 8;
|
|
zitadel.management.v1.AddCustomPrivacyPolicyRequest privacy_policy = 9;
|
|
|
|
repeated DataProject projects = 10;
|
|
repeated zitadel.management.v1.AddProjectRoleRequest project_roles = 11;
|
|
repeated DataAPIApplication api_apps = 12;
|
|
repeated DataOIDCApplication oidc_apps = 13;
|
|
repeated DataHumanUser human_users = 14;
|
|
repeated DataMachineUser machine_users = 15;
|
|
repeated zitadel.management.v1.SetTriggerActionsRequest trigger_actions = 16;
|
|
repeated DataAction actions = 17;
|
|
|
|
repeated DataProjectGrant project_grants = 18;
|
|
repeated zitadel.management.v1.AddUserGrantRequest user_grants = 19;
|
|
|
|
repeated zitadel.management.v1.AddOrgMemberRequest org_members = 20;
|
|
repeated zitadel.management.v1.AddProjectMemberRequest project_members = 21;
|
|
repeated zitadel.management.v1.AddProjectGrantMemberRequest project_grant_members = 22;
|
|
|
|
repeated zitadel.management.v1.SetUserMetadataRequest user_metadata = 23;
|
|
|
|
repeated zitadel.management.v1.SetCustomLoginTextsRequest login_texts = 24;
|
|
|
|
repeated zitadel.management.v1.SetCustomInitMessageTextRequest init_messages = 25;
|
|
repeated zitadel.management.v1.SetCustomPasswordResetMessageTextRequest password_reset_messages = 26;
|
|
repeated zitadel.management.v1.SetCustomVerifyEmailMessageTextRequest verify_email_messages = 27;
|
|
repeated zitadel.management.v1.SetCustomVerifyPhoneMessageTextRequest verify_phone_messages = 28;
|
|
repeated zitadel.management.v1.SetCustomDomainClaimedMessageTextRequest domain_claimed_messages = 29;
|
|
repeated zitadel.management.v1.SetCustomPasswordlessRegistrationMessageTextRequest passwordless_registration_messages = 30;
|
|
|
|
repeated DataOIDCIDP oidc_idps = 31;
|
|
repeated DataJWTIDP jwt_idps = 32;
|
|
|
|
repeated zitadel.management.v1.AddSecondFactorToLoginPolicyRequest second_factors = 33;
|
|
repeated zitadel.management.v1.AddMultiFactorToLoginPolicyRequest multi_factors = 34;
|
|
repeated zitadel.management.v1.AddIDPToLoginPolicyRequest idps = 35;
|
|
|
|
repeated zitadel.idp.v1.IDPUserLink user_links = 36;
|
|
repeated zitadel.org.v1.Domain domains = 37;
|
|
}
|
|
message DataOIDCIDP{
|
|
string idp_id = 1;
|
|
zitadel.management.v1.AddOrgOIDCIDPRequest idp = 2;
|
|
}
|
|
message DataJWTIDP{
|
|
string idp_id = 1;
|
|
zitadel.management.v1.AddOrgJWTIDPRequest idp = 32;
|
|
}
|
|
|
|
message ExportHumanUser {
|
|
message Profile {
|
|
string first_name = 1 [(validate.rules).string = {min_len: 1, max_len: 200}];
|
|
string last_name = 2 [(validate.rules).string = {min_len: 1, max_len: 200}];
|
|
string nick_name = 3 [(validate.rules).string = {max_len: 200}];
|
|
string display_name = 4 [(validate.rules).string = {max_len: 200}];
|
|
string preferred_language = 5 [(validate.rules).string = {max_len: 10}];
|
|
zitadel.user.v1.Gender gender = 6;
|
|
}
|
|
message Email {
|
|
string email = 1 [(validate.rules).string.email = true]; //TODO: check if no value is allowed
|
|
bool is_email_verified = 2;
|
|
}
|
|
message Phone {
|
|
// has to be a global number
|
|
string phone = 1 [(validate.rules).string = {min_len: 1, max_len: 50, prefix: "+"}];
|
|
bool is_phone_verified = 2;
|
|
}
|
|
message HashedPassword{
|
|
string value = 1;
|
|
string algorithm = 2;
|
|
}
|
|
|
|
string user_name = 1 [(validate.rules).string = {min_len: 1, max_len: 200}];
|
|
|
|
Profile profile = 2 [(validate.rules).message.required = true];
|
|
Email email = 3 [(validate.rules).message.required = true];
|
|
Phone phone = 4;
|
|
string password = 5;
|
|
HashedPassword hashed_password = 6;
|
|
bool password_change_required = 7;
|
|
bool request_passwordless_registration = 8;
|
|
|
|
string otp_code = 9;
|
|
}
|
|
|
|
|
|
message DataProject {
|
|
string project_id = 1;
|
|
zitadel.management.v1.AddProjectRequest project = 2;
|
|
}
|
|
message DataAPIApplication {
|
|
string app_id = 1;
|
|
zitadel.management.v1.AddAPIAppRequest app = 2;
|
|
}
|
|
message DataOIDCApplication {
|
|
string app_id = 1;
|
|
zitadel.management.v1.AddOIDCAppRequest app = 2;
|
|
}
|
|
message DataHumanUser {
|
|
string user_id = 1;
|
|
zitadel.management.v1.ImportHumanUserRequest user = 2;
|
|
}
|
|
message DataMachineUser {
|
|
string user_id = 1;
|
|
zitadel.management.v1.AddMachineUserRequest user = 2;
|
|
}
|
|
message DataAction {
|
|
string action_id = 1;
|
|
zitadel.management.v1.CreateActionRequest action = 2;
|
|
}
|
|
message DataProjectGrant {
|
|
string grant_id = 1;
|
|
zitadel.management.v1.AddProjectGrantRequest project_grant = 2;
|
|
} |