This commit is contained in:
@@ -7,23 +7,10 @@ option go_package = "git.lendry.ru/lendry-erp/proto.git/go;pb";
|
||||
service AccountService {
|
||||
rpc GetAccount(GetAccountRequest) returns (GetAccountResponse);
|
||||
rpc ChangePassword (ChangePasswordRequest) returns (ChangePasswordResponse);
|
||||
rpc AdminResetPassword (AdminResetPasswordRequest) returns (AdminResetPasswordResponse);
|
||||
rpc CreateUser(CreateUserRequest) returns (CreateUserResponse);
|
||||
rpc DeleteUser(DeleteUserRequest) returns (DeleteUserResponse);
|
||||
rpc ChangeData(ChangeDataRequest) returns (ChangeDataResponse);
|
||||
rpc AssignRole (AssignRoleRequest) returns (AssignRoleResponse);
|
||||
rpc RevokeRole (RevokeRoleRequest) returns (RevokeRoleResponse);
|
||||
rpc SetPin (SetPinRequest) returns (SetPinResponse);
|
||||
rpc UnlockPin (UnlockPinRequest) returns (UnlockPinResponse);
|
||||
rpc GetPinStatus (GetPinStatusRequest) returns (GetPinStatusResponse);
|
||||
rpc RemovePin (RemovePinRequest) returns (RemovePinResponse);
|
||||
|
||||
rpc BlockUser(BlockUserRequest) returns (BlockUserResponse);
|
||||
rpc UnblockUser(UnblockUserRequest) returns (UnblockUserResponse);
|
||||
rpc BlockIp(BlockIpRequest) returns (BlockIpResponse);
|
||||
rpc UnblockIp(UnblockIpRequest) returns (UnblockIpResponse);
|
||||
|
||||
rpc SyncUsersToSearch (SyncUsersToSearchRequest) returns (SyncUsersToSearchResponse);
|
||||
}
|
||||
|
||||
message GetAccountRequest {
|
||||
@@ -64,71 +51,6 @@ message ChangePasswordResponse {
|
||||
string message = 2;
|
||||
}
|
||||
|
||||
message CreateUserRequest {
|
||||
string username = 1;
|
||||
string password = 2;
|
||||
repeated string roles = 3;
|
||||
}
|
||||
|
||||
message CreateUserResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
|
||||
message DeleteUserRequest {
|
||||
string user_id = 1;
|
||||
}
|
||||
|
||||
message DeleteUserResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
|
||||
message ChangeDataRequest {
|
||||
string user_id = 1;
|
||||
string session_id = 2;
|
||||
optional string email = 3;
|
||||
optional string phone = 4;
|
||||
optional string full_name = 5;
|
||||
optional string avatar_url = 6;
|
||||
optional string custom_status_text = 7;
|
||||
optional string custom_status_emoji = 8;
|
||||
optional string timezone = 9;
|
||||
optional string language = 10;
|
||||
optional bool is_public = 11;
|
||||
}
|
||||
|
||||
message ChangeDataResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
|
||||
message AssignRoleRequest {
|
||||
string user_id = 1;
|
||||
string role_id = 2; // В gRPC передаем как string, внутри преобразуем в Int
|
||||
}
|
||||
message AssignRoleResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
message RevokeRoleRequest {
|
||||
string user_id = 1;
|
||||
string role_id = 2;
|
||||
}
|
||||
message RevokeRoleResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
|
||||
message AdminResetPasswordRequest {
|
||||
string user_id = 1;
|
||||
string new_password = 2;
|
||||
}
|
||||
|
||||
message AdminResetPasswordResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
|
||||
message SetPinRequest {
|
||||
string user_id = 1;
|
||||
@@ -174,37 +96,3 @@ message RemovePinResponse {
|
||||
}
|
||||
|
||||
|
||||
message BlockUserRequest {
|
||||
string user_id = 1; // Кого блокируем
|
||||
string admin_id = 2; // Кто блокирует
|
||||
optional string reason = 3;
|
||||
}
|
||||
message BlockUserResponse { bool success = 1; string message = 2; }
|
||||
|
||||
message UnblockUserRequest {
|
||||
string user_id = 1;
|
||||
string admin_id = 2;
|
||||
}
|
||||
message UnblockUserResponse { bool success = 1; string message = 2; }
|
||||
|
||||
message BlockIpRequest {
|
||||
string ip_address = 1;
|
||||
string admin_id = 2;
|
||||
optional string reason = 3;
|
||||
}
|
||||
message BlockIpResponse { bool success = 1; string message = 2; }
|
||||
|
||||
message UnblockIpRequest {
|
||||
string ip_address = 1;
|
||||
string admin_id = 2;
|
||||
}
|
||||
message UnblockIpResponse { bool success = 1; string message = 2; }
|
||||
|
||||
message SyncUsersToSearchRequest {
|
||||
// Можно оставить пустым, так как нам не нужны входные данные
|
||||
}
|
||||
|
||||
message SyncUsersToSearchResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
@@ -1,95 +0,0 @@
|
||||
syntax = "proto3";
|
||||
|
||||
package ldap.v1;
|
||||
|
||||
option go_package = "git.lendry.ru/lendry-erp/proto.git/go;pb";
|
||||
|
||||
service LdapService {
|
||||
// Управление Пользователями (Bind системного аккаунта) ---
|
||||
rpc GetUsers (EmptyRequest) returns (UserListResponse);
|
||||
rpc CreateUser (CreateUserRequest) returns (StatusResponse);
|
||||
rpc UpdateUser (UpdateUserRequest) returns (StatusResponse);
|
||||
rpc ChangePassword (ChangePasswordRequest) returns (StatusResponse);
|
||||
rpc ToggleUserStatus (ToggleStatusRequest) returns (StatusResponse);
|
||||
|
||||
// Управление Группами ---
|
||||
rpc GetGroups (EmptyRequest) returns (GroupListResponse);
|
||||
rpc AddUserToGroup (GroupMemberRequest) returns (StatusResponse);
|
||||
rpc RemoveUserFromGroup (GroupMemberRequest) returns (StatusResponse);
|
||||
}
|
||||
|
||||
// ==========================================
|
||||
// БАЗОВЫЕ И ПЕРЕИСПОЛЬЗУЕМЫЕ СТРУКТУРЫ
|
||||
// ==========================================
|
||||
message EmptyRequest {}
|
||||
|
||||
// Стандартный ответ для мутаций (создание, обновление, удаление)
|
||||
message StatusResponse {
|
||||
bool success = 1;
|
||||
string error_message = 2;
|
||||
}
|
||||
|
||||
// Полная модель пользователя
|
||||
message UserData {
|
||||
string dn = 1; // Полный путь в AD (Distinguished Name)
|
||||
string username = 2; // Логин (sAMAccountName)
|
||||
string display_name = 3; // ФИО (displayName)
|
||||
string email = 4; // Почта (mail)
|
||||
string description = 5; // Описание/Должность (description)
|
||||
bytes avatar = 6; // Аватарка в байтах (thumbnailPhoto)
|
||||
repeated string groups = 7; // Список групп
|
||||
bool is_active = 8; // Статус аккаунта
|
||||
string phone = 9;
|
||||
}
|
||||
|
||||
// Модель группы
|
||||
message GroupData {
|
||||
string dn = 1;
|
||||
string name = 2; // Короткое имя группы (cn)
|
||||
}
|
||||
|
||||
// --- Списки ---
|
||||
message UserListResponse {
|
||||
bool success = 1;
|
||||
string error_message = 2;
|
||||
repeated UserData users = 3;
|
||||
}
|
||||
|
||||
message GroupListResponse {
|
||||
bool success = 1;
|
||||
string error_message = 2;
|
||||
repeated GroupData groups = 3;
|
||||
}
|
||||
|
||||
// --- Управление профилем ---
|
||||
message CreateUserRequest {
|
||||
string username = 1;
|
||||
string full_name = 2;
|
||||
string password = 3;
|
||||
optional string email = 4; // Сразу при создании можно задать почту
|
||||
}
|
||||
|
||||
// Запрос на обновление. Используем optional для частичного обновления.
|
||||
message UpdateUserRequest {
|
||||
string username = 1; // Обязательное поле: кого обновляем
|
||||
optional string display_name = 2; // Новое ФИО (повлечет Rename CN)
|
||||
optional string email = 3; // Новая почта
|
||||
optional string description = 4; // Новое описание
|
||||
optional bytes avatar = 5; // Новая аватарка (бинарник картинки)
|
||||
}
|
||||
|
||||
message ChangePasswordRequest {
|
||||
string username = 1;
|
||||
string new_password = 2;
|
||||
}
|
||||
|
||||
message ToggleStatusRequest {
|
||||
string username = 1;
|
||||
bool set_active = 2; // true - включить (512), false - отключить (514)
|
||||
}
|
||||
|
||||
// --- Управление членством в группах ---
|
||||
message GroupMemberRequest {
|
||||
string username = 1; // Логин пользователя
|
||||
string group_dn = 2; // Полный путь группы (в которую добавляем / из которой удаляем)
|
||||
}
|
||||
@@ -1,99 +0,0 @@
|
||||
syntax = "proto3";
|
||||
|
||||
package rbac.v1;
|
||||
|
||||
option go_package = "git.lendry.ru/lendry-erp/proto.git/go;pb";
|
||||
|
||||
|
||||
|
||||
service RbacService {
|
||||
rpc CreateRole(CreateRoleRequest) returns (ModifyRoleResponse);
|
||||
rpc UpdateRole(UpdateRoleRequest) returns (ModifyRoleResponse);
|
||||
rpc DeleteRole(DeleteRoleRequest) returns (DeleteRoleResponse);
|
||||
|
||||
rpc CreatePermission(CreatePermissionRequest) returns (ModifyPermissionResponse);
|
||||
rpc UpdatePermission(UpdatePermissionRequest) returns (ModifyPermissionResponse);
|
||||
|
||||
rpc GetAllPermissions (GetAllPermissionsRequest) returns (GetAllPermissionsResponse);
|
||||
rpc GetAllRoles(GetAllRolesRequest) returns (GetAllRolesResponse);
|
||||
}
|
||||
|
||||
message GetAllPermissionsRequest {
|
||||
string user_id = 1;
|
||||
string session_id=2;
|
||||
}
|
||||
|
||||
message GetAllPermissionsResponse {
|
||||
repeated Permission permissions = 1;
|
||||
}
|
||||
|
||||
message Permission {
|
||||
string id = 1;
|
||||
string code = 2;
|
||||
string description = 3;
|
||||
string module = 4;
|
||||
repeated string roles = 5;
|
||||
}
|
||||
|
||||
message GetAllRolesRequest {
|
||||
string user_id = 1;
|
||||
string session_id=2;
|
||||
}
|
||||
|
||||
message GetAllRolesResponse {
|
||||
repeated Roles roles = 1;
|
||||
}
|
||||
|
||||
message CreateRoleRequest {
|
||||
string name = 1;
|
||||
int32 level = 2;
|
||||
repeated string permission_codes = 3;
|
||||
}
|
||||
|
||||
message UpdateRoleRequest {
|
||||
string id = 1;
|
||||
optional string name = 2;
|
||||
optional int32 level = 3;
|
||||
repeated string permission_codes = 4;
|
||||
}
|
||||
|
||||
message ModifyRoleResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
|
||||
message DeleteRoleRequest {
|
||||
string id = 1;
|
||||
}
|
||||
|
||||
message DeleteRoleResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
optional string fallback_role_name = 3;
|
||||
}
|
||||
|
||||
message CreatePermissionRequest {
|
||||
string code = 1;
|
||||
string description = 2;
|
||||
string module = 3;
|
||||
}
|
||||
|
||||
message UpdatePermissionRequest {
|
||||
string id = 1;
|
||||
repeated string role_ids = 2; // Привязка к конкретным ролям
|
||||
}
|
||||
|
||||
message ModifyPermissionResponse {
|
||||
bool success = 1;
|
||||
string message = 2;
|
||||
}
|
||||
|
||||
message Roles {
|
||||
string id = 1;
|
||||
string name = 2;
|
||||
int32 level = 3;
|
||||
repeated string permissions = 4;
|
||||
repeated string ldap_mapping = 5;
|
||||
repeated string accounts = 6;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user