public void ImportKey(VaultKeyInfo keyInfo, Database db = null) { VaultKey key = VaultKeysByVaultId.AddNew(); key.RsaKey = keyInfo.RsaKey; key.Password = keyInfo.Password; key.Save(db); _items = null; ChildCollections.Clear(); }
public ActionResult Update(Bam.Net.Encryption.VaultKey dao) { try { dao.Save(); return(Json(new { Success = true, Message = "", Dao = dao.ToJsonSafe() })); } catch (Exception ex) { return(GetErrorResult(ex)); } }
private static VaultKey CreateFromFilter(IQueryFilter filter, Database database = null) { Database db = database ?? Db.For <VaultKey>(); var dao = new VaultKey(); filter.Parameters.Each(p => { dao.Property(p.ColumnName, p.Value); }); dao.Save(db); return(dao); }
/// <summary> /// Create a Vault in the specified database by the specified /// name using the specified password to create it if it /// doesn't exist /// </summary> /// <param name="database"></param> /// <param name="name"></param> /// <param name="password"></param> /// <param name="rsaKeyLength"></param> /// <returns></returns> public static Vault Create(Database database, string name, string password, RsaKeyLength rsaKeyLength = RsaKeyLength._1024) { Vault result = Vault.OneWhere(c => c.Name == name, database); if (result == null) { result = new Vault(); result.Name = name; result.Save(database); VaultKey key = result.VaultKeysByVaultId.JustOne(database, false); AsymmetricCipherKeyPair keys = RsaKeyGen.GenerateKeyPair(rsaKeyLength); key.RsaKey = keys.ToPem(); key.Password = password.EncryptWithPublicKey(keys); key.Save(database); } return(result); }