From e18134cc74e8f2ec3a88704074f94c74944db2bc Mon Sep 17 00:00:00 2001 From: 魏曹先生 <1992414357@qq.com> Date: Thu, 25 Sep 2025 17:20:13 +0800 Subject: Move `workspace` mod to `data` --- crates/vcs/src/data/vault/config.rs | 46 +++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 crates/vcs/src/data/vault/config.rs (limited to 'crates/vcs/src/data/vault/config.rs') diff --git a/crates/vcs/src/data/vault/config.rs b/crates/vcs/src/data/vault/config.rs new file mode 100644 index 0000000..11917de --- /dev/null +++ b/crates/vcs/src/data/vault/config.rs @@ -0,0 +1,46 @@ +use cfg_file::ConfigFile; +use serde::{Deserialize, Serialize}; + +use crate::constants::SERVER_FILE_VAULT; +use crate::data::member::Member; +use crate::data::vault::MemberId; + +#[derive(Serialize, Deserialize, ConfigFile)] +#[cfg_file(path = SERVER_FILE_VAULT)] +pub struct VaultConfig { + /// Vault name, which can be used as the project name and generally serves as a hint + vault_name: String, + + /// Vault admin id, a list of member id representing administrator identities + vault_admin_list: Vec, +} + +impl Default for VaultConfig { + fn default() -> Self { + Self { + vault_name: "JustEnoughVault".to_string(), + vault_admin_list: Vec::new(), + } + } +} + +impl VaultConfig { + // Change name of the vault. + pub fn change_name(&mut self, name: impl Into) { + self.vault_name = name.into() + } + + // Add admin + pub fn add_admin(&mut self, member: &Member) { + let uuid = member.id(); + if !self.vault_admin_list.contains(&uuid) { + self.vault_admin_list.push(uuid); + } + } + + // Remove admin + pub fn remove_admin(&mut self, member: &Member) { + let id = member.id(); + self.vault_admin_list.retain(|x| x != &id); + } +} -- cgit