From: Ian Jackson Date: Sat, 24 Oct 2020 17:21:05 +0000 (+0100) Subject: wip new account etc., adding acctid etc. X-Git-Tag: otter-0.2.0~596 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=commitdiff_plain;h=d8792be0c13ca59854ae86af9d8c41cebf820b12;p=otter.git wip new account etc., adding acctid etc. Signed-off-by: Ian Jackson --- diff --git a/src/accounts.rs b/src/accounts.rs index 7acaf7a6..ff962c40 100644 --- a/src/accounts.rs +++ b/src/accounts.rs @@ -152,7 +152,7 @@ pub struct TokenRevelation { pub earliest: Timestamp, } -#[derive(Debug)] +#[derive(Debug,Default)] #[derive(Serialize,Deserialize)] struct Accounts { names: HashMap, @@ -235,21 +235,18 @@ impl AccountRecord { -> Result where F: FnOnce(&mut AccountRecord, AccountId) -> T { - let entry = AccountRecord::lookup_mut_caller_must_save(account, auth) + let (entry, acctid) + = AccountRecord::lookup_mut_caller_must_save(account, auth) .ok_or(MgmtError::AccountNotFound)?; let old_access = entry.access.clone(); - let output = f(entry); + let output = f(&mut *entry, acctid); let mut ok = true; - if_chain!{ - if let Some(entry) = entry; - if Arc::ptr_eq(old_access, entry.access); - then { + if ! Arc::ptr_eq(&old_access, &entry.access) { // xxx actually do this // invalidate_all_tokens_for_account(accid) // .dont_just_questionmark - } }; - let ok = if entry.is_some() { save_accounts_now() } else { Ok(()) }; + let ok = save_accounts_now(); match ok { Ok(()) => Ok(output), Err(e) => Err((e, output)) @@ -261,7 +258,12 @@ impl AccountRecord { _auth: Authorisation, data: AccountRecord) { - let entry = ACCOUNTS.write().unwrap_or_default().entry(account); + let accounts = ACCOUNTS.write(); + use hash_map::Entry::*; + match accounts.names.get(account) { + Occupied(oe) => accounts.records.oe.value() + + .get_or_insert_with(default).entry(account); use hash_map::Entry::*; let ve = match entry { Occupied(_) => throw!(ME::AlreadyExists),