mirror of
https://github.com/bitwarden/android.git
synced 2025-01-12 11:17:30 +03:00
convert to local functions to avoid continuewith
This commit is contained in:
parent
6d8af4d97a
commit
c6ce3e9480
5 changed files with 95 additions and 78 deletions
|
@ -104,11 +104,14 @@ namespace Bit.Core.Models.Domain
|
||||||
{
|
{
|
||||||
model.Attachments = new List<AttachmentView>();
|
model.Attachments = new List<AttachmentView>();
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
|
async Task decryptAndAddAttachmentAsync(Attachment attachment)
|
||||||
|
{
|
||||||
|
var decAttachment = await attachment.DecryptAsync(OrganizationId);
|
||||||
|
model.Attachments.Add(decAttachment);
|
||||||
|
}
|
||||||
foreach(var attachment in Attachments)
|
foreach(var attachment in Attachments)
|
||||||
{
|
{
|
||||||
var t = attachment.DecryptAsync(OrganizationId)
|
tasks.Add(decryptAndAddAttachmentAsync(attachment));
|
||||||
.ContinueWith(async decAttachment => model.Attachments.Add(await decAttachment));
|
|
||||||
tasks.Add(t);
|
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
}
|
}
|
||||||
|
@ -116,11 +119,14 @@ namespace Bit.Core.Models.Domain
|
||||||
{
|
{
|
||||||
model.Fields = new List<FieldView>();
|
model.Fields = new List<FieldView>();
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
|
async Task decryptAndAddFieldAsync(Field field)
|
||||||
|
{
|
||||||
|
var decField = await field.DecryptAsync(OrganizationId);
|
||||||
|
model.Fields.Add(decField);
|
||||||
|
}
|
||||||
foreach(var field in Fields)
|
foreach(var field in Fields)
|
||||||
{
|
{
|
||||||
var t = field.DecryptAsync(OrganizationId)
|
tasks.Add(decryptAndAddFieldAsync(field));
|
||||||
.ContinueWith(async decField => model.Fields.Add(await decField));
|
|
||||||
tasks.Add(t);
|
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
}
|
}
|
||||||
|
@ -128,11 +134,14 @@ namespace Bit.Core.Models.Domain
|
||||||
{
|
{
|
||||||
model.PasswordHistory = new List<PasswordHistoryView>();
|
model.PasswordHistory = new List<PasswordHistoryView>();
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
|
async Task decryptAndAddHistoryAsync(PasswordHistory ph)
|
||||||
|
{
|
||||||
|
var decPh = await ph.DecryptAsync(OrganizationId);
|
||||||
|
model.PasswordHistory.Add(decPh);
|
||||||
|
}
|
||||||
foreach(var ph in PasswordHistory)
|
foreach(var ph in PasswordHistory)
|
||||||
{
|
{
|
||||||
var t = ph.DecryptAsync(OrganizationId)
|
tasks.Add(decryptAndAddHistoryAsync(ph));
|
||||||
.ContinueWith(async decPh => model.PasswordHistory.Add(await decPh));
|
|
||||||
tasks.Add(t);
|
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,18 +58,14 @@ namespace Bit.Core.Models.Domain
|
||||||
var viewModelType = viewModel.GetType();
|
var viewModelType = viewModel.GetType();
|
||||||
var domainType = domain.GetType();
|
var domainType = domain.GetType();
|
||||||
|
|
||||||
Task<string> decCs(string propName)
|
async Task decCsAndSetDec(string propName)
|
||||||
{
|
{
|
||||||
var domainPropInfo = domainType.GetProperty(propName);
|
var domainPropInfo = domainType.GetProperty(propName);
|
||||||
var domainProp = domainPropInfo.GetValue(domain) as CipherString;
|
string val = null;
|
||||||
if(domainProp != null)
|
if(domainPropInfo.GetValue(domain) is CipherString domainProp)
|
||||||
{
|
{
|
||||||
return domainProp.DecryptAsync(orgId);
|
val = await domainProp.DecryptAsync(orgId);
|
||||||
}
|
}
|
||||||
return Task.FromResult((string)null);
|
|
||||||
};
|
|
||||||
void setDec(string propName, string val)
|
|
||||||
{
|
|
||||||
var viewModelPropInfo = viewModelType.GetProperty(propName);
|
var viewModelPropInfo = viewModelType.GetProperty(propName);
|
||||||
viewModelPropInfo.SetValue(viewModel, val, null);
|
viewModelPropInfo.SetValue(viewModel, val, null);
|
||||||
};
|
};
|
||||||
|
@ -77,7 +73,7 @@ namespace Bit.Core.Models.Domain
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
foreach(var prop in map)
|
foreach(var prop in map)
|
||||||
{
|
{
|
||||||
tasks.Add(decCs(prop).ContinueWith(async val => setDec(prop, await val)));
|
tasks.Add(decCsAndSetDec(prop));
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
return viewModel;
|
return viewModel;
|
||||||
|
|
|
@ -169,12 +169,9 @@ namespace Bit.Core.Services
|
||||||
"Notes"
|
"Notes"
|
||||||
}, key),
|
}, key),
|
||||||
EncryptCipherDataAsync(cipher, model, key),
|
EncryptCipherDataAsync(cipher, model, key),
|
||||||
EncryptFieldsAsync(model.Fields, key)
|
EncryptFieldsAsync(model.Fields, key, cipher),
|
||||||
.ContinueWith(async fields => cipher.Fields = await fields),
|
EncryptPasswordHistoriesAsync(model.PasswordHistory, key, cipher),
|
||||||
EncryptPasswordHistoriesAsync(model.PasswordHistory, key)
|
EncryptAttachmentsAsync(model.Attachments, key, cipher)
|
||||||
.ContinueWith(async phs => cipher.PasswordHistory = await phs),
|
|
||||||
EncryptAttachmentsAsync(model.Attachments, key)
|
|
||||||
.ContinueWith(async attachments => cipher.Attachments = await attachments)
|
|
||||||
};
|
};
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
return cipher;
|
return cipher;
|
||||||
|
@ -220,11 +217,16 @@ namespace Bit.Core.Services
|
||||||
throw new Exception("No key.");
|
throw new Exception("No key.");
|
||||||
}
|
}
|
||||||
var decCiphers = new List<CipherView>();
|
var decCiphers = new List<CipherView>();
|
||||||
|
async Task decryptAndAddCipherAsync(Cipher cipher)
|
||||||
|
{
|
||||||
|
var c = await cipher.DecryptAsync();
|
||||||
|
decCiphers.Add(c);
|
||||||
|
}
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
var ciphers = await GetAllAsync();
|
var ciphers = await GetAllAsync();
|
||||||
foreach(var cipher in ciphers)
|
foreach(var cipher in ciphers)
|
||||||
{
|
{
|
||||||
tasks.Add(cipher.DecryptAsync().ContinueWith(async c => decCiphers.Add(await c)));
|
tasks.Add(decryptAndAddCipherAsync(cipher));
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
decCiphers = decCiphers.OrderBy(c => c, new CipherLocaleComparer(_i18nService)).ToList();
|
decCiphers = decCiphers.OrderBy(c => c, new CipherLocaleComparer(_i18nService)).ToList();
|
||||||
|
@ -872,18 +874,15 @@ namespace Bit.Core.Services
|
||||||
var modelType = model.GetType();
|
var modelType = model.GetType();
|
||||||
var objType = obj.GetType();
|
var objType = obj.GetType();
|
||||||
|
|
||||||
Task<CipherString> makeCs(string propName)
|
async Task makeAndSetCs(string propName)
|
||||||
{
|
{
|
||||||
var modelPropInfo = modelType.GetProperty(propName);
|
var modelPropInfo = modelType.GetProperty(propName);
|
||||||
var modelProp = modelPropInfo.GetValue(model) as string;
|
var modelProp = modelPropInfo.GetValue(model) as string;
|
||||||
|
CipherString val = null;
|
||||||
if(!string.IsNullOrWhiteSpace(modelProp))
|
if(!string.IsNullOrWhiteSpace(modelProp))
|
||||||
{
|
{
|
||||||
return _cryptoService.EncryptAsync(modelProp, key);
|
val = await _cryptoService.EncryptAsync(modelProp, key);
|
||||||
}
|
}
|
||||||
return Task.FromResult((CipherString)null);
|
|
||||||
};
|
|
||||||
void setCs(string propName, CipherString val)
|
|
||||||
{
|
|
||||||
var objPropInfo = objType.GetProperty(propName);
|
var objPropInfo = objType.GetProperty(propName);
|
||||||
objPropInfo.SetValue(obj, val, null);
|
objPropInfo.SetValue(obj, val, null);
|
||||||
};
|
};
|
||||||
|
@ -891,44 +890,44 @@ namespace Bit.Core.Services
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
foreach(var prop in map)
|
foreach(var prop in map)
|
||||||
{
|
{
|
||||||
tasks.Add(makeCs(prop).ContinueWith(async val => setCs(prop, await val)));
|
tasks.Add(makeAndSetCs(prop));
|
||||||
}
|
}
|
||||||
return Task.WhenAll(tasks);
|
return Task.WhenAll(tasks);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<List<Attachment>> EncryptAttachmentsAsync(
|
private async Task EncryptAttachmentsAsync(List<AttachmentView> attachmentsModel, SymmetricCryptoKey key,
|
||||||
List<AttachmentView> attachmentsModel, SymmetricCryptoKey key)
|
Cipher cipher)
|
||||||
{
|
{
|
||||||
if(!attachmentsModel?.Any() ?? true)
|
if(!attachmentsModel?.Any() ?? true)
|
||||||
{
|
{
|
||||||
return null;
|
cipher.Attachments = null;
|
||||||
}
|
}
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
var encAttachments = new List<Attachment>();
|
var encAttachments = new List<Attachment>();
|
||||||
foreach(var model in attachmentsModel)
|
async Task encryptAndAddAttachmentAsync(AttachmentView model, Attachment attachment)
|
||||||
{
|
{
|
||||||
var attachment = new Attachment
|
await EncryptObjPropertyAsync(model, attachment, new HashSet<string>
|
||||||
{
|
|
||||||
Id = model.Id,
|
|
||||||
Size = model.Size,
|
|
||||||
SizeName = model.SizeName,
|
|
||||||
Url = model.Url
|
|
||||||
};
|
|
||||||
var task = EncryptObjPropertyAsync(model, attachment, new HashSet<string>
|
|
||||||
{
|
{
|
||||||
"FileName"
|
"FileName"
|
||||||
}, key).ContinueWith(async (t) =>
|
}, key);
|
||||||
{
|
|
||||||
if(model.Key != null)
|
if(model.Key != null)
|
||||||
{
|
{
|
||||||
attachment.Key = await _cryptoService.EncryptAsync(model.Key.Key, key);
|
attachment.Key = await _cryptoService.EncryptAsync(model.Key.Key, key);
|
||||||
}
|
}
|
||||||
encAttachments.Add(attachment);
|
encAttachments.Add(attachment);
|
||||||
});
|
}
|
||||||
tasks.Add(task);
|
foreach(var model in attachmentsModel)
|
||||||
|
{
|
||||||
|
tasks.Add(encryptAndAddAttachmentAsync(model, new Attachment
|
||||||
|
{
|
||||||
|
Id = model.Id,
|
||||||
|
Size = model.Size,
|
||||||
|
SizeName = model.SizeName,
|
||||||
|
Url = model.Url
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
return encAttachments;
|
cipher.Attachments = encAttachments;
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task EncryptCipherDataAsync(Cipher cipher, CipherView model, SymmetricCryptoKey key)
|
private async Task EncryptCipherDataAsync(Cipher cipher, CipherView model, SymmetricCryptoKey key)
|
||||||
|
@ -1007,14 +1006,25 @@ namespace Bit.Core.Services
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<List<Field>> EncryptFieldsAsync(List<FieldView> fieldsModel, SymmetricCryptoKey key)
|
private async Task EncryptFieldsAsync(List<FieldView> fieldsModel, SymmetricCryptoKey key,
|
||||||
|
Cipher cipher)
|
||||||
{
|
{
|
||||||
if(!fieldsModel?.Any() ?? true)
|
if(!fieldsModel?.Any() ?? true)
|
||||||
{
|
{
|
||||||
return null;
|
cipher.Fields = null;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
var encFields = new List<Field>();
|
var encFields = new List<Field>();
|
||||||
|
async Task encryptAndAddFieldAsync(FieldView model, Field field)
|
||||||
|
{
|
||||||
|
await EncryptObjPropertyAsync(model, field, new HashSet<string>
|
||||||
|
{
|
||||||
|
"Name",
|
||||||
|
"Value"
|
||||||
|
}, key);
|
||||||
|
encFields.Add(field);
|
||||||
|
}
|
||||||
foreach(var model in fieldsModel)
|
foreach(var model in fieldsModel)
|
||||||
{
|
{
|
||||||
var field = new Field
|
var field = new Field
|
||||||
|
@ -1026,46 +1036,38 @@ namespace Bit.Core.Services
|
||||||
{
|
{
|
||||||
model.Value = "false";
|
model.Value = "false";
|
||||||
}
|
}
|
||||||
var task = EncryptObjPropertyAsync(model, field, new HashSet<string>
|
tasks.Add(encryptAndAddFieldAsync(model, field));
|
||||||
{
|
|
||||||
"Name",
|
|
||||||
"Value"
|
|
||||||
}, key).ContinueWith((t) =>
|
|
||||||
{
|
|
||||||
encFields.Add(field);
|
|
||||||
});
|
|
||||||
tasks.Add(task);
|
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
return encFields;
|
cipher.Fields = encFields;
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<List<PasswordHistory>> EncryptPasswordHistoriesAsync(List<PasswordHistoryView> phModels,
|
private async Task EncryptPasswordHistoriesAsync(List<PasswordHistoryView> phModels,
|
||||||
SymmetricCryptoKey key)
|
SymmetricCryptoKey key, Cipher cipher)
|
||||||
{
|
{
|
||||||
if(!phModels?.Any() ?? true)
|
if(!phModels?.Any() ?? true)
|
||||||
{
|
{
|
||||||
return null;
|
cipher.PasswordHistory = null;
|
||||||
}
|
}
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
var encPhs = new List<PasswordHistory>();
|
var encPhs = new List<PasswordHistory>();
|
||||||
foreach(var model in phModels)
|
async Task encryptAndAddHistoryAsync(PasswordHistoryView model, PasswordHistory ph)
|
||||||
{
|
{
|
||||||
var ph = new PasswordHistory
|
await EncryptObjPropertyAsync(model, ph, new HashSet<string>
|
||||||
{
|
|
||||||
LastUsedDate = model.LastUsedDate
|
|
||||||
};
|
|
||||||
var task = EncryptObjPropertyAsync(model, ph, new HashSet<string>
|
|
||||||
{
|
{
|
||||||
"Password"
|
"Password"
|
||||||
}, key).ContinueWith((t) =>
|
}, key);
|
||||||
{
|
|
||||||
encPhs.Add(ph);
|
encPhs.Add(ph);
|
||||||
});
|
}
|
||||||
tasks.Add(task);
|
foreach(var model in phModels)
|
||||||
|
{
|
||||||
|
tasks.Add(encryptAndAddHistoryAsync(model, new PasswordHistory
|
||||||
|
{
|
||||||
|
LastUsedDate = model.LastUsedDate
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
return encPhs;
|
cipher.PasswordHistory = encPhs;
|
||||||
}
|
}
|
||||||
|
|
||||||
private class CipherLocaleComparer : IComparer<CipherView>
|
private class CipherLocaleComparer : IComparer<CipherView>
|
||||||
|
|
|
@ -67,10 +67,15 @@ namespace Bit.Core.Services
|
||||||
return new List<CollectionView>();
|
return new List<CollectionView>();
|
||||||
}
|
}
|
||||||
var decCollections = new List<CollectionView>();
|
var decCollections = new List<CollectionView>();
|
||||||
|
async Task decryptAndAddCollectionAsync(Collection collection)
|
||||||
|
{
|
||||||
|
var c = await collection.DecryptAsync();
|
||||||
|
decCollections.Add(c);
|
||||||
|
}
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
foreach(var collection in collections)
|
foreach(var collection in collections)
|
||||||
{
|
{
|
||||||
tasks.Add(collection.DecryptAsync().ContinueWith(async c => decCollections.Add(await c)));
|
tasks.Add(decryptAndAddCollectionAsync(collection));
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
return decCollections.OrderBy(c => c, new CollectionLocaleComparer(_i18nService)).ToList();
|
return decCollections.OrderBy(c => c, new CollectionLocaleComparer(_i18nService)).ToList();
|
||||||
|
|
|
@ -92,11 +92,16 @@ namespace Bit.Core.Services
|
||||||
throw new Exception("No key.");
|
throw new Exception("No key.");
|
||||||
}
|
}
|
||||||
var decFolders = new List<FolderView>();
|
var decFolders = new List<FolderView>();
|
||||||
|
async Task decryptAndAddFolderAsync(Folder folder)
|
||||||
|
{
|
||||||
|
var f = await folder.DecryptAsync();
|
||||||
|
decFolders.Add(f);
|
||||||
|
}
|
||||||
var tasks = new List<Task>();
|
var tasks = new List<Task>();
|
||||||
var folders = await GetAllAsync();
|
var folders = await GetAllAsync();
|
||||||
foreach(var folder in folders)
|
foreach(var folder in folders)
|
||||||
{
|
{
|
||||||
tasks.Add(folder.DecryptAsync().ContinueWith(async f => decFolders.Add(await f)));
|
tasks.Add(decryptAndAddFolderAsync(folder));
|
||||||
}
|
}
|
||||||
await Task.WhenAll(tasks);
|
await Task.WhenAll(tasks);
|
||||||
decFolders = decFolders.OrderBy(f => f, new FolderLocaleComparer(_i18nService)).ToList();
|
decFolders = decFolders.OrderBy(f => f, new FolderLocaleComparer(_i18nService)).ToList();
|
||||||
|
|
Loading…
Reference in a new issue