remove events and refactor of push notifications functions
This commit is contained in:
parent
509047e2b0
commit
e19ece08c7
4 changed files with 25 additions and 35 deletions
|
|
@ -1,11 +1,11 @@
|
|||
'use strict';
|
||||
angular.module('copayApp.services')
|
||||
.factory('pushNotificationsService', function($http, $log, isMobile, profileService, storageService, configService, lodash, isCordova) {
|
||||
.factory('pushNotificationsService', function($http, $log, isMobile, storageService, configService, lodash, isCordova) {
|
||||
var root = {};
|
||||
var defaults = configService.getDefaults();
|
||||
var usePushNotifications = isCordova && !isMobile.Windows();
|
||||
|
||||
root.pushNotificationsInit = function() {
|
||||
root.pushNotificationsInit = function(walletClients) {
|
||||
if (!usePushNotifications) return;
|
||||
|
||||
var push = PushNotification.init(defaults.pushNotifications.config);
|
||||
|
|
@ -13,7 +13,7 @@ angular.module('copayApp.services')
|
|||
push.on('registration', function(data) {
|
||||
$log.debug('Starting push notification registration');
|
||||
storageService.setDeviceToken(data.registrationId, function() {
|
||||
root.enableNotifications();
|
||||
root.enableNotifications(walletsClients);
|
||||
});
|
||||
});
|
||||
|
||||
|
|
@ -33,15 +33,15 @@ angular.module('copayApp.services')
|
|||
});
|
||||
};
|
||||
|
||||
root.enableNotifications = function() {
|
||||
root.enableNotifications = function(walletsClients) {
|
||||
if (!usePushNotifications) return;
|
||||
|
||||
storageService.getDeviceToken(function(err, token) {
|
||||
lodash.forEach(profileService.getWallets(null), function(wallet) {
|
||||
lodash.forEach(walletsClients, function(walletClient) {
|
||||
var opts = {};
|
||||
opts.type = isMobile.iOS() ? "ios" : isMobile.Android() ? "android" : null;
|
||||
opts.token = token;
|
||||
root.subscribe(opts, wallet.id, function(err, response) {
|
||||
root.subscribe(opts, walletClient, function(err, response) {
|
||||
if (err) $log.warn('Subscription error: ' + err.code);
|
||||
else $log.debug('Subscribed to push notifications service: ' + JSON.stringify(response));
|
||||
});
|
||||
|
|
@ -49,29 +49,29 @@ angular.module('copayApp.services')
|
|||
});
|
||||
}
|
||||
|
||||
root.disableNotifications = function() {
|
||||
root.disableNotifications = function(walletsClients) {
|
||||
if (!usePushNotifications) return;
|
||||
|
||||
lodash.forEach(profileService.getWallets(null), function(wallet) {
|
||||
root.unsubscribe(wallet.id, function(err) {
|
||||
lodash.forEach(walletsClients, function(walletClient) {
|
||||
root.unsubscribe(walletClient, function(err) {
|
||||
if (err) $log.warn('Subscription error: ' + err.code);
|
||||
else $log.debug('Unsubscribed from push notifications service');
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
root.subscribe = function(opts, walletId, cb) {
|
||||
root.subscribe = function(opts, walletClient, cb) {
|
||||
if (!usePushNotifications) return;
|
||||
|
||||
var walletClient = profileService.getClient(walletId);
|
||||
walletClient.pushNotificationsSubscribe(opts, function(err, resp) {
|
||||
if (err) return cb(err);
|
||||
return cb(null, resp);
|
||||
});
|
||||
}
|
||||
|
||||
root.unsubscribe = function(walletId, cb) {
|
||||
root.unsubscribe = function(walletClient, cb) {
|
||||
if (!usePushNotifications) return;
|
||||
|
||||
var walletClient = profileService.getClient(walletId);
|
||||
walletClient.pushNotificationsUnsubscribe(function(err) {
|
||||
if (err) return cb(err);
|
||||
return cb(null);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue