1
0
mirror of https://github.com/bitwarden/mobile synced 2025-01-18 20:09:44 +01:00

push notification registration for iOS

This commit is contained in:
Kyle Spearrin 2016-06-28 00:55:53 -04:00
parent 3506383733
commit 818b1c426f
3 changed files with 23 additions and 4 deletions

View File

@ -6,5 +6,8 @@
public const string SettingPinUnlockOn = "pinUnlockOn";
public const string SettingLockSeconds = "lockSeconds";
public const string SettingLastBackgroundedDate = "lastBackgroundedDate";
public const string PushPromptShown = "initialPushPromptShown";
}
}

View File

@ -10,6 +10,8 @@ using Bit.App.Resources;
using Xamarin.Forms;
using XLabs.Ioc;
using Bit.App.Utilities;
using PushNotification.Plugin.Abstractions;
using Plugin.Settings.Abstractions;
namespace Bit.App.Pages
{
@ -19,6 +21,8 @@ namespace Bit.App.Pages
private readonly ISiteService _siteService;
private readonly IUserDialogs _userDialogs;
private readonly IClipboardService _clipboardService;
private readonly IPushNotification _pushNotification;
private readonly ISettings _settings;
private readonly bool _favorites;
public VaultListSitesPage(bool favorites)
@ -28,6 +32,8 @@ namespace Bit.App.Pages
_siteService = Resolver.Resolve<ISiteService>();
_userDialogs = Resolver.Resolve<IUserDialogs>();
_clipboardService = Resolver.Resolve<IClipboardService>();
_pushNotification = Resolver.Resolve<IPushNotification>();
_settings = Resolver.Resolve<ISettings>();
Init();
}
@ -59,10 +65,21 @@ namespace Bit.App.Pages
Content = listView;
}
protected override void OnAppearing()
protected async override void OnAppearing()
{
base.OnAppearing();
LoadFoldersAsync().Wait();
if(Device.OS == TargetPlatform.iOS && !_favorites)
{
if(!_settings.GetValueOrDefault<bool>(Constants.PushPromptShown))
{
_settings.AddOrUpdateValue(Constants.PushPromptShown, true);
await _userDialogs.AlertAsync("bitwarden keeps your vault automatically synced by using push notifications. For the best possible experience, please select \"Ok\" on the following prompt when asked to enable push notifications.", "Enable Automatic Syncing", "Ok, got it!");
}
_pushNotification.Register();
}
}
private async Task LoadFoldersAsync()

View File

@ -33,7 +33,7 @@ namespace Bit.App.Services
Debug.WriteLine("Message Arrived: {0}", JsonConvert.SerializeObject(values));
}
public void OnRegistered(string token, DeviceType deviceType)
public async void OnRegistered(string token, DeviceType deviceType)
{
Debug.WriteLine(string.Format("Push Notification - Device Registered - Token : {0}", token));
@ -42,8 +42,7 @@ namespace Bit.App.Services
return;
}
var response = _deviceApiRepository.PutTokenAsync(_appIdService.AppId, new Models.Api.DeviceTokenRequest(token))
.GetAwaiter().GetResult();
var response = await _deviceApiRepository.PutTokenAsync(_appIdService.AppId, new Models.Api.DeviceTokenRequest(token));
if(response.Succeeded)
{
Debug.WriteLine("Registered device with server.");