public ActionResult Update(Bam.Net.Encryption.Vault dao) { try { dao.Save(); return Json(new { Success = true, Message = "", Dao = dao.ToJsonSafe() }); } catch(Exception ex) { return GetErrorResult(ex); } }
private static Vault CreateFromFilter(IQueryFilter filter, Database database = null) { Database db = database ?? Db.For <Vault>(); var dao = new Vault(); 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); }