re-worked message sending

This commit is contained in:
Kyle Spearrin 2019-04-19 12:29:37 -04:00
parent 4b7366e9b3
commit 7c1549bb95
8 changed files with 79 additions and 21 deletions

View file

@ -44,8 +44,8 @@ namespace Bit.Droid
var liteDbStorage = new LiteDbStorageService(Path.Combine(documentsPath, "bitwarden.db"));
var deviceActionService = new DeviceActionService();
var localizeService = new LocalizeService();
var broadcasterService = new MobileBroadcasterService();
var messagingService = new MobileMessagingService();
var broadcasterService = new BroadcasterService();
var messagingService = new MobileBroadcasterMessagingService(broadcasterService);
var i18nService = new MobileI18nService(localizeService.GetCurrentCultureInfo());
var secureStorageService = new SecureStorageService();
var cryptoPrimitiveService = new CryptoPrimitiveService();

View file

@ -44,21 +44,25 @@ namespace Bit.App
});
ServiceContainer.Resolve<MobilePlatformUtilsService>("platformUtilsService").Init();
_broadcasterService.Subscribe<DialogDetails>("showDialog", async (details) =>
_broadcasterService.Subscribe(nameof(App), async (message) =>
{
var confirmed = true;
var confirmText = string.IsNullOrWhiteSpace(details.ConfirmText) ?
AppResources.Ok : details.ConfirmText;
if(!string.IsNullOrWhiteSpace(details.CancelText))
if(message.Command == "showDialog")
{
confirmed = await MainPage.DisplayAlert(details.Title, details.Text, confirmText,
details.CancelText);
var details = message.Data as DialogDetails;
var confirmed = true;
var confirmText = string.IsNullOrWhiteSpace(details.ConfirmText) ?
AppResources.Ok : details.ConfirmText;
if(!string.IsNullOrWhiteSpace(details.CancelText))
{
confirmed = await MainPage.DisplayAlert(details.Title, details.Text, confirmText,
details.CancelText);
}
else
{
await MainPage.DisplayAlert(details.Title, details.Text, details.ConfirmText);
}
_messagingService.Send("showDialogResolve", new Tuple<int, bool>(details.DialogId, confirmed));
}
else
{
await MainPage.DisplayAlert(details.Title, details.Text, details.ConfirmText);
}
_messagingService.Send("showDialogResolve", new Tuple<int, bool>(details.DialogId, confirmed));
});
}

View file

@ -1,11 +1,12 @@
using System;
using Bit.Core.Models.Domain;
using System;
namespace Bit.Core.Abstractions
{
public interface IBroadcasterService
{
void Send<T>(T message, string id = null);
void Subscribe<T>(string id, Action<T> messageCallback);
void Send(Message message, string id = null);
void Subscribe(string id, Action<Message> messageCallback);
void Unsubscribe(string id);
}
}

View file

@ -2,6 +2,6 @@
{
public interface IMessagingService
{
void Send<T>(string subscriber, T arg = default(T));
void Send(string subscriber, object arg = null);
}
}

View file

@ -0,0 +1,8 @@
namespace Bit.Core.Models.Domain
{
public class Message
{
public string Command { get; set; }
public object Data { get; set; }
}
}

View file

@ -140,7 +140,7 @@ namespace Bit.Core.Services
public void LogOut(Action callback)
{
callback.Invoke();
_messagingService.Send<object>("loggedOut");
_messagingService.Send("loggedOut");
}
public List<TwoFactorProvider> GetSupportedTwoFactorProviders()
@ -312,7 +312,7 @@ namespace Bit.Core.Services
await _cryptoService.SetEncPrivateKeyAsync(tokenResponse.PrivateKey);
}
_messagingService.Send<object>("loggedIn");
_messagingService.Send("loggedIn");
return result;
}

View file

@ -0,0 +1,45 @@
using Bit.Core.Abstractions;
using Bit.Core.Models.Domain;
using System;
using System.Collections.Generic;
namespace Bit.App.Services
{
public class BroadcasterService : IBroadcasterService
{
private readonly Dictionary<string, Action<Message>> _subscribers = new Dictionary<string, Action<Message>>();
public void Send(Message message, string id = null)
{
if(!string.IsNullOrWhiteSpace(id))
{
if(_subscribers.ContainsKey(id))
{
_subscribers[id].Invoke(message);
}
return;
}
foreach(var sub in _subscribers)
{
sub.Value.Invoke(message);
}
}
public void Subscribe(string id, Action<Message> messageCallback)
{
if(_subscribers.ContainsKey(id))
{
return;
}
_subscribers.Add(id, messageCallback);
}
public void Unsubscribe(string id)
{
if(_subscribers.ContainsKey(id))
{
_subscribers.Remove(id);
}
}
}
}

View file

@ -255,7 +255,7 @@ namespace Bit.Core.Services
private void SyncStarted()
{
SyncInProgress = true;
_messagingService.Send<object>("syncStarted");
_messagingService.Send("syncStarted");
}
private bool SyncCompleted(bool successfully)