@metamask/notification-services-controller 0.21.0 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +22 -3
- package/dist/NotificationServicesController/NotificationServicesController.cjs +70 -78
- package/dist/NotificationServicesController/NotificationServicesController.cjs.map +1 -1
- package/dist/NotificationServicesController/NotificationServicesController.d.cts +10 -34
- package/dist/NotificationServicesController/NotificationServicesController.d.cts.map +1 -1
- package/dist/NotificationServicesController/NotificationServicesController.d.mts +10 -34
- package/dist/NotificationServicesController/NotificationServicesController.d.mts.map +1 -1
- package/dist/NotificationServicesController/NotificationServicesController.mjs +71 -79
- package/dist/NotificationServicesController/NotificationServicesController.mjs.map +1 -1
- package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.cjs +1 -1
- package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.cjs.map +1 -1
- package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.d.cts.map +1 -1
- package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.d.mts.map +1 -1
- package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.mjs +1 -1
- package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.mjs.map +1 -1
- package/dist/NotificationServicesController/__fixtures__/mockAddresses.cjs +6 -0
- package/dist/NotificationServicesController/__fixtures__/mockAddresses.cjs.map +1 -0
- package/dist/NotificationServicesController/__fixtures__/mockAddresses.d.cts +3 -0
- package/dist/NotificationServicesController/__fixtures__/mockAddresses.d.cts.map +1 -0
- package/dist/NotificationServicesController/__fixtures__/mockAddresses.d.mts +3 -0
- package/dist/NotificationServicesController/__fixtures__/mockAddresses.d.mts.map +1 -0
- package/dist/NotificationServicesController/__fixtures__/mockAddresses.mjs +3 -0
- package/dist/NotificationServicesController/__fixtures__/mockAddresses.mjs.map +1 -0
- package/dist/NotificationServicesController/index.cjs +1 -0
- package/dist/NotificationServicesController/index.cjs.map +1 -1
- package/dist/NotificationServicesController/index.d.cts +1 -0
- package/dist/NotificationServicesController/index.d.cts.map +1 -1
- package/dist/NotificationServicesController/index.d.mts +1 -0
- package/dist/NotificationServicesController/index.d.mts.map +1 -1
- package/dist/NotificationServicesController/index.mjs +1 -0
- package/dist/NotificationServicesController/index.mjs.map +1 -1
- package/dist/NotificationServicesController/services/onchain-notifications.cjs +1 -0
- package/dist/NotificationServicesController/services/onchain-notifications.cjs.map +1 -1
- package/dist/NotificationServicesController/services/onchain-notifications.d.cts.map +1 -1
- package/dist/NotificationServicesController/services/onchain-notifications.d.mts.map +1 -1
- package/dist/NotificationServicesController/services/onchain-notifications.mjs +2 -1
- package/dist/NotificationServicesController/services/onchain-notifications.mjs.map +1 -1
- package/dist/NotificationServicesController/utils/utils.cjs +28 -2
- package/dist/NotificationServicesController/utils/utils.cjs.map +1 -1
- package/dist/NotificationServicesController/utils/utils.d.cts +11 -1
- package/dist/NotificationServicesController/utils/utils.d.cts.map +1 -1
- package/dist/NotificationServicesController/utils/utils.d.mts +11 -1
- package/dist/NotificationServicesController/utils/utils.d.mts.map +1 -1
- package/dist/NotificationServicesController/utils/utils.mjs +26 -1
- package/dist/NotificationServicesController/utils/utils.mjs.map +1 -1
- package/dist/NotificationServicesPushController/NotificationServicesPushController.cjs +97 -57
- package/dist/NotificationServicesPushController/NotificationServicesPushController.cjs.map +1 -1
- package/dist/NotificationServicesPushController/NotificationServicesPushController.d.cts +19 -24
- package/dist/NotificationServicesPushController/NotificationServicesPushController.d.cts.map +1 -1
- package/dist/NotificationServicesPushController/NotificationServicesPushController.d.mts +19 -24
- package/dist/NotificationServicesPushController/NotificationServicesPushController.d.mts.map +1 -1
- package/dist/NotificationServicesPushController/NotificationServicesPushController.mjs +98 -58
- package/dist/NotificationServicesPushController/NotificationServicesPushController.mjs.map +1 -1
- package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.cjs +14 -0
- package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.cjs.map +1 -0
- package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.d.cts +3 -0
- package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.d.cts.map +1 -0
- package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.d.mts +3 -0
- package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.d.mts.map +1 -0
- package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.mjs +10 -0
- package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.mjs.map +1 -0
- package/dist/NotificationServicesPushController/__fixtures__/mockServices.cjs +1 -13
- package/dist/NotificationServicesPushController/__fixtures__/mockServices.cjs.map +1 -1
- package/dist/NotificationServicesPushController/__fixtures__/mockServices.d.cts +0 -1
- package/dist/NotificationServicesPushController/__fixtures__/mockServices.d.cts.map +1 -1
- package/dist/NotificationServicesPushController/__fixtures__/mockServices.d.mts +0 -1
- package/dist/NotificationServicesPushController/__fixtures__/mockServices.d.mts.map +1 -1
- package/dist/NotificationServicesPushController/__fixtures__/mockServices.mjs +1 -12
- package/dist/NotificationServicesPushController/__fixtures__/mockServices.mjs.map +1 -1
- package/dist/NotificationServicesPushController/services/services.cjs +19 -93
- package/dist/NotificationServicesPushController/services/services.cjs.map +1 -1
- package/dist/NotificationServicesPushController/services/services.d.cts +5 -29
- package/dist/NotificationServicesPushController/services/services.d.cts.map +1 -1
- package/dist/NotificationServicesPushController/services/services.d.mts +5 -29
- package/dist/NotificationServicesPushController/services/services.d.mts.map +1 -1
- package/dist/NotificationServicesPushController/services/services.mjs +18 -94
- package/dist/NotificationServicesPushController/services/services.mjs.map +1 -1
- package/dist/NotificationServicesPushController/types/index.cjs.map +1 -1
- package/dist/NotificationServicesPushController/types/index.d.cts +1 -0
- package/dist/NotificationServicesPushController/types/index.d.cts.map +1 -1
- package/dist/NotificationServicesPushController/types/index.d.mts +1 -0
- package/dist/NotificationServicesPushController/types/index.d.mts.map +1 -1
- package/dist/NotificationServicesPushController/types/index.mjs.map +1 -1
- package/dist/NotificationServicesPushController/{services/push/index.cjs → types/push-service-interface.cjs} +1 -1
- package/dist/NotificationServicesPushController/types/push-service-interface.cjs.map +1 -0
- package/dist/NotificationServicesPushController/types/push-service-interface.d.cts +30 -0
- package/dist/NotificationServicesPushController/types/push-service-interface.d.cts.map +1 -0
- package/dist/NotificationServicesPushController/types/push-service-interface.d.mts +30 -0
- package/dist/NotificationServicesPushController/types/push-service-interface.d.mts.map +1 -0
- package/dist/NotificationServicesPushController/types/push-service-interface.mjs +2 -0
- package/dist/NotificationServicesPushController/types/push-service-interface.mjs.map +1 -0
- package/dist/NotificationServicesPushController/utils/get-notification-message.cjs +1 -19
- package/dist/NotificationServicesPushController/utils/get-notification-message.cjs.map +1 -1
- package/dist/NotificationServicesPushController/utils/get-notification-message.d.cts +0 -7
- package/dist/NotificationServicesPushController/utils/get-notification-message.d.cts.map +1 -1
- package/dist/NotificationServicesPushController/utils/get-notification-message.d.mts +0 -7
- package/dist/NotificationServicesPushController/utils/get-notification-message.d.mts.map +1 -1
- package/dist/NotificationServicesPushController/utils/get-notification-message.mjs +0 -17
- package/dist/NotificationServicesPushController/utils/get-notification-message.mjs.map +1 -1
- package/dist/NotificationServicesPushController/web/index.cjs +8 -0
- package/dist/NotificationServicesPushController/web/index.cjs.map +1 -0
- package/dist/NotificationServicesPushController/web/index.d.cts +2 -0
- package/dist/NotificationServicesPushController/web/index.d.cts.map +1 -0
- package/dist/NotificationServicesPushController/web/index.d.mts +2 -0
- package/dist/NotificationServicesPushController/web/index.d.mts.map +1 -0
- package/dist/NotificationServicesPushController/web/index.mjs +2 -0
- package/dist/NotificationServicesPushController/web/index.mjs.map +1 -0
- package/dist/NotificationServicesPushController/web/push-utils.cjs +170 -0
- package/dist/NotificationServicesPushController/web/push-utils.cjs.map +1 -0
- package/dist/NotificationServicesPushController/web/push-utils.d.cts +37 -0
- package/dist/NotificationServicesPushController/web/push-utils.d.cts.map +1 -0
- package/dist/NotificationServicesPushController/web/push-utils.d.mts +37 -0
- package/dist/NotificationServicesPushController/web/push-utils.d.mts.map +1 -0
- package/dist/NotificationServicesPushController/web/push-utils.mjs +168 -0
- package/dist/NotificationServicesPushController/web/push-utils.mjs.map +1 -0
- package/dist/shared/index.cjs +19 -0
- package/dist/shared/index.cjs.map +1 -0
- package/dist/shared/index.d.cts +3 -0
- package/dist/shared/index.d.cts.map +1 -0
- package/dist/shared/index.d.mts +3 -0
- package/dist/shared/index.d.mts.map +1 -0
- package/dist/shared/index.mjs +3 -0
- package/dist/shared/index.mjs.map +1 -0
- package/dist/shared/is-onchain-notification.cjs +22 -0
- package/dist/shared/is-onchain-notification.cjs.map +1 -0
- package/dist/shared/is-onchain-notification.d.cts +9 -0
- package/dist/shared/is-onchain-notification.d.cts.map +1 -0
- package/dist/shared/is-onchain-notification.d.mts +9 -0
- package/dist/shared/is-onchain-notification.d.mts.map +1 -0
- package/dist/shared/is-onchain-notification.mjs +18 -0
- package/dist/shared/is-onchain-notification.mjs.map +1 -0
- package/package.json +14 -4
- package/push-services/web/package.json +9 -0
- package/dist/NotificationServicesPushController/constants.cjs +0 -14
- package/dist/NotificationServicesPushController/constants.cjs.map +0 -1
- package/dist/NotificationServicesPushController/constants.d.cts +0 -11
- package/dist/NotificationServicesPushController/constants.d.cts.map +0 -1
- package/dist/NotificationServicesPushController/constants.d.mts +0 -11
- package/dist/NotificationServicesPushController/constants.d.mts.map +0 -1
- package/dist/NotificationServicesPushController/constants.mjs +0 -11
- package/dist/NotificationServicesPushController/constants.mjs.map +0 -1
- package/dist/NotificationServicesPushController/services/push/index.cjs.map +0 -1
- package/dist/NotificationServicesPushController/services/push/index.d.cts +0 -6
- package/dist/NotificationServicesPushController/services/push/index.d.cts.map +0 -1
- package/dist/NotificationServicesPushController/services/push/index.d.mts +0 -6
- package/dist/NotificationServicesPushController/services/push/index.d.mts.map +0 -1
- package/dist/NotificationServicesPushController/services/push/index.mjs +0 -2
- package/dist/NotificationServicesPushController/services/push/index.mjs.map +0 -1
|
@@ -9,7 +9,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
9
9
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
10
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
11
|
};
|
|
12
|
-
var _NotificationServicesController_instances,
|
|
12
|
+
var _NotificationServicesController_instances, _NotificationServicesController_keyringController, _NotificationServicesController_auth, _NotificationServicesController_storage, _NotificationServicesController_pushNotifications, _NotificationServicesController_accounts, _NotificationServicesController_featureAnnouncementEnv, _NotificationServicesController_registerMessageHandlers, _NotificationServicesController_clearLoadingStates, _NotificationServicesController_assertAuthEnabled, _NotificationServicesController_enableAuth, _NotificationServicesController_getValidStorageKeyAndBearerToken, _NotificationServicesController_assertUserStorage, _NotificationServicesController_getUserStorage, _NotificationServicesController_setIsUpdatingMetamaskNotifications, _NotificationServicesController_setIsFetchingMetamaskNotifications, _NotificationServicesController_setIsCheckingAccountsPresence, _NotificationServicesController_updateUpdatingAccountsState, _NotificationServicesController_clearUpdatingAccountsState;
|
|
13
13
|
function $importDefault(module) {
|
|
14
14
|
if (module?.__esModule) {
|
|
15
15
|
return module.default;
|
|
@@ -17,7 +17,7 @@ function $importDefault(module) {
|
|
|
17
17
|
return module;
|
|
18
18
|
}
|
|
19
19
|
import { BaseController } from "@metamask/base-controller";
|
|
20
|
-
import { toChecksumHexAddress } from "@metamask/controller-utils";
|
|
20
|
+
import { isValidHexAddress, toChecksumHexAddress } from "@metamask/controller-utils";
|
|
21
21
|
import { assert } from "@metamask/utils";
|
|
22
22
|
import $log from "loglevel";
|
|
23
23
|
const log = $importDefault($log);
|
|
@@ -108,26 +108,20 @@ class NotificationServicesController extends BaseController {
|
|
|
108
108
|
state: { ...defaultState, ...state },
|
|
109
109
|
});
|
|
110
110
|
_NotificationServicesController_instances.add(this);
|
|
111
|
-
// Temporary boolean as push notifications are not yet enabled on mobile
|
|
112
|
-
_NotificationServicesController_isPushIntegrated.set(this, true);
|
|
113
|
-
// Flag to check is notifications have been setup when the browser/extension is initialized.
|
|
114
|
-
// We want to re-initialize push notifications when the browser/extension is refreshed
|
|
115
|
-
// To ensure we subscribe to the most up-to-date notifications
|
|
116
|
-
_NotificationServicesController_isPushNotificationsSetup.set(this, false);
|
|
117
|
-
_NotificationServicesController_isUnlocked.set(this, false);
|
|
118
111
|
_NotificationServicesController_keyringController.set(this, {
|
|
112
|
+
isUnlocked: false,
|
|
119
113
|
setupLockedStateSubscriptions: (onUnlock) => {
|
|
120
114
|
const { isUnlocked } = this.messagingSystem.call('KeyringController:getState');
|
|
121
|
-
|
|
115
|
+
__classPrivateFieldGet(this, _NotificationServicesController_keyringController, "f").isUnlocked = isUnlocked;
|
|
122
116
|
this.messagingSystem.subscribe('KeyringController:unlock', () => {
|
|
123
|
-
|
|
117
|
+
__classPrivateFieldGet(this, _NotificationServicesController_keyringController, "f").isUnlocked = true;
|
|
124
118
|
// messaging system cannot await promises
|
|
125
119
|
// we don't need to wait for a result on this.
|
|
126
120
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
127
121
|
onUnlock();
|
|
128
122
|
});
|
|
129
123
|
this.messagingSystem.subscribe('KeyringController:lock', () => {
|
|
130
|
-
|
|
124
|
+
__classPrivateFieldGet(this, _NotificationServicesController_keyringController, "f").isUnlocked = false;
|
|
131
125
|
});
|
|
132
126
|
},
|
|
133
127
|
});
|
|
@@ -154,13 +148,14 @@ class NotificationServicesController extends BaseController {
|
|
|
154
148
|
},
|
|
155
149
|
});
|
|
156
150
|
_NotificationServicesController_pushNotifications.set(this, {
|
|
151
|
+
// Flag to check is notifications have been setup when the browser/extension is initialized.
|
|
152
|
+
// We want to re-initialize push notifications when the browser/extension is refreshed
|
|
153
|
+
// To ensure we subscribe to the most up-to-date notifications
|
|
154
|
+
isSetup: false,
|
|
157
155
|
subscribeToPushNotifications: async () => {
|
|
158
156
|
await this.messagingSystem.call('NotificationServicesPushController:subscribeToPushNotifications');
|
|
159
157
|
},
|
|
160
158
|
enablePushNotifications: async (UUIDs) => {
|
|
161
|
-
if (!__classPrivateFieldGet(this, _NotificationServicesController_isPushIntegrated, "f")) {
|
|
162
|
-
return;
|
|
163
|
-
}
|
|
164
159
|
try {
|
|
165
160
|
await this.messagingSystem.call('NotificationServicesPushController:enablePushNotifications', UUIDs);
|
|
166
161
|
}
|
|
@@ -168,21 +163,15 @@ class NotificationServicesController extends BaseController {
|
|
|
168
163
|
log.error('Silently failed to enable push notifications', e);
|
|
169
164
|
}
|
|
170
165
|
},
|
|
171
|
-
disablePushNotifications: async (
|
|
172
|
-
if (!__classPrivateFieldGet(this, _NotificationServicesController_isPushIntegrated, "f")) {
|
|
173
|
-
return;
|
|
174
|
-
}
|
|
166
|
+
disablePushNotifications: async () => {
|
|
175
167
|
try {
|
|
176
|
-
await this.messagingSystem.call('NotificationServicesPushController:disablePushNotifications'
|
|
168
|
+
await this.messagingSystem.call('NotificationServicesPushController:disablePushNotifications');
|
|
177
169
|
}
|
|
178
170
|
catch (e) {
|
|
179
171
|
log.error('Silently failed to disable push notifications', e);
|
|
180
172
|
}
|
|
181
173
|
},
|
|
182
174
|
updatePushNotifications: async (UUIDs) => {
|
|
183
|
-
if (!__classPrivateFieldGet(this, _NotificationServicesController_isPushIntegrated, "f")) {
|
|
184
|
-
return;
|
|
185
|
-
}
|
|
186
175
|
try {
|
|
187
176
|
await this.messagingSystem.call('NotificationServicesPushController:updateTriggerPushNotifications', UUIDs);
|
|
188
177
|
}
|
|
@@ -191,37 +180,33 @@ class NotificationServicesController extends BaseController {
|
|
|
191
180
|
}
|
|
192
181
|
},
|
|
193
182
|
subscribe: () => {
|
|
194
|
-
if (!__classPrivateFieldGet(this, _NotificationServicesController_isPushIntegrated, "f")) {
|
|
195
|
-
return;
|
|
196
|
-
}
|
|
197
183
|
this.messagingSystem.subscribe('NotificationServicesPushController:onNewNotifications', (notification) => {
|
|
198
184
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
199
185
|
this.updateMetamaskNotificationsList(notification);
|
|
200
186
|
});
|
|
201
187
|
},
|
|
202
188
|
initializePushNotifications: async () => {
|
|
203
|
-
if (!__classPrivateFieldGet(this, _NotificationServicesController_isPushIntegrated, "f")) {
|
|
204
|
-
return;
|
|
205
|
-
}
|
|
206
189
|
if (!this.state.isNotificationServicesEnabled) {
|
|
207
190
|
return;
|
|
208
191
|
}
|
|
209
|
-
if (__classPrivateFieldGet(this,
|
|
192
|
+
if (__classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").isSetup) {
|
|
210
193
|
return;
|
|
211
194
|
}
|
|
212
195
|
// If wallet is unlocked, we can create a fresh push subscription
|
|
213
196
|
// Otherwise we can subscribe to original subscription
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
return;
|
|
197
|
+
try {
|
|
198
|
+
if (!__classPrivateFieldGet(this, _NotificationServicesController_keyringController, "f").isUnlocked) {
|
|
199
|
+
throw new Error('Keyring is locked');
|
|
218
200
|
}
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
__classPrivateFieldSet(this, _NotificationServicesController_isPushNotificationsSetup, true, "f");
|
|
201
|
+
await this.enablePushNotifications();
|
|
202
|
+
__classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").isSetup = true;
|
|
222
203
|
}
|
|
223
|
-
|
|
224
|
-
await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f")
|
|
204
|
+
catch {
|
|
205
|
+
await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f")
|
|
206
|
+
.subscribeToPushNotifications()
|
|
207
|
+
.catch(() => {
|
|
208
|
+
// do nothing
|
|
209
|
+
});
|
|
225
210
|
}
|
|
226
211
|
},
|
|
227
212
|
});
|
|
@@ -236,7 +221,9 @@ class NotificationServicesController extends BaseController {
|
|
|
236
221
|
listAccounts: async () => {
|
|
237
222
|
// Get previous and current account sets
|
|
238
223
|
const nonChecksumAccounts = await this.messagingSystem.call('KeyringController:getAccounts');
|
|
239
|
-
const accounts = nonChecksumAccounts
|
|
224
|
+
const accounts = nonChecksumAccounts
|
|
225
|
+
.map((a) => toChecksumHexAddress(a))
|
|
226
|
+
.filter((a) => isValidHexAddress(a));
|
|
240
227
|
const currentAccountsSet = new Set(accounts);
|
|
241
228
|
const prevAccountsSet = new Set(this.state.subscriptionAccountsSeen);
|
|
242
229
|
// Invalid value you cannot have zero accounts
|
|
@@ -267,7 +254,8 @@ class NotificationServicesController extends BaseController {
|
|
|
267
254
|
* @returns result from list accounts
|
|
268
255
|
*/
|
|
269
256
|
initialize: async () => {
|
|
270
|
-
if (__classPrivateFieldGet(this,
|
|
257
|
+
if (__classPrivateFieldGet(this, _NotificationServicesController_keyringController, "f").isUnlocked &&
|
|
258
|
+
!__classPrivateFieldGet(this, _NotificationServicesController_accounts, "f").isNotificationAccountsSetup) {
|
|
271
259
|
await __classPrivateFieldGet(this, _NotificationServicesController_accounts, "f").listAccounts();
|
|
272
260
|
__classPrivateFieldGet(this, _NotificationServicesController_accounts, "f").isNotificationAccountsSetup = true;
|
|
273
261
|
}
|
|
@@ -295,7 +283,6 @@ class NotificationServicesController extends BaseController {
|
|
|
295
283
|
},
|
|
296
284
|
});
|
|
297
285
|
_NotificationServicesController_featureAnnouncementEnv.set(this, void 0);
|
|
298
|
-
__classPrivateFieldSet(this, _NotificationServicesController_isPushIntegrated, env.isPushIntegrated ?? true, "f");
|
|
299
286
|
__classPrivateFieldSet(this, _NotificationServicesController_featureAnnouncementEnv, env.featureAnnouncements, "f");
|
|
300
287
|
__classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_registerMessageHandlers).call(this);
|
|
301
288
|
__classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_clearLoadingStates).call(this);
|
|
@@ -311,15 +298,22 @@ class NotificationServicesController extends BaseController {
|
|
|
311
298
|
__classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").subscribe();
|
|
312
299
|
}
|
|
313
300
|
/**
|
|
314
|
-
*
|
|
315
|
-
*
|
|
316
|
-
* This method directly returns the boolean value of `isMetamaskNotificationsEnabled`
|
|
317
|
-
* from the controller's state, indicating whether MetaMask notifications are currently enabled.
|
|
318
|
-
*
|
|
319
|
-
* @returns The enabled state of MetaMask notifications.
|
|
301
|
+
* Public method to expose enabling push notifications
|
|
320
302
|
*/
|
|
321
|
-
|
|
322
|
-
|
|
303
|
+
async enablePushNotifications() {
|
|
304
|
+
await __classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_enableAuth).call(this);
|
|
305
|
+
const storage = await __classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_getUserStorage).call(this);
|
|
306
|
+
if (!storage) {
|
|
307
|
+
throw new Error('Unable to get triggers');
|
|
308
|
+
}
|
|
309
|
+
const uuids = Utils.getAllUUIDs(storage);
|
|
310
|
+
await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").enablePushNotifications(uuids);
|
|
311
|
+
}
|
|
312
|
+
/**
|
|
313
|
+
* Public method to expose disabling push notifications
|
|
314
|
+
*/
|
|
315
|
+
async disablePushNotifications() {
|
|
316
|
+
await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").disablePushNotifications();
|
|
323
317
|
}
|
|
324
318
|
async checkAccountsPresence(accounts) {
|
|
325
319
|
try {
|
|
@@ -425,10 +419,7 @@ class NotificationServicesController extends BaseController {
|
|
|
425
419
|
async enableMetamaskNotifications() {
|
|
426
420
|
try {
|
|
427
421
|
__classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_setIsUpdatingMetamaskNotifications).call(this, true);
|
|
428
|
-
|
|
429
|
-
if (!isSignedIn) {
|
|
430
|
-
await __classPrivateFieldGet(this, _NotificationServicesController_auth, "f").signIn();
|
|
431
|
-
}
|
|
422
|
+
await __classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_enableAuth).call(this);
|
|
432
423
|
await this.createOnChainTriggers();
|
|
433
424
|
}
|
|
434
425
|
catch (e) {
|
|
@@ -448,30 +439,25 @@ class NotificationServicesController extends BaseController {
|
|
|
448
439
|
* @throws {Error} If the user is not authenticated or if there is an error during the process.
|
|
449
440
|
*/
|
|
450
441
|
async disableNotificationServices() {
|
|
442
|
+
__classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_setIsUpdatingMetamaskNotifications).call(this, true);
|
|
443
|
+
// Attempt Disable Push Notifications
|
|
451
444
|
try {
|
|
452
|
-
__classPrivateFieldGet(this,
|
|
453
|
-
// Disable Push Notifications
|
|
454
|
-
const userStorage = await __classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_getUserStorage).call(this);
|
|
455
|
-
__classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_assertUserStorage).call(this, userStorage);
|
|
456
|
-
const UUIDs = Utils.getAllUUIDs(userStorage);
|
|
457
|
-
await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").disablePushNotifications(UUIDs);
|
|
458
|
-
const snapNotifications = this.state.metamaskNotificationsList.filter((notification) => notification.type === TRIGGER_TYPES.SNAP);
|
|
459
|
-
// Clear Notification States (toggles and list)
|
|
460
|
-
this.update((state) => {
|
|
461
|
-
state.isNotificationServicesEnabled = false;
|
|
462
|
-
state.isFeatureAnnouncementsEnabled = false;
|
|
463
|
-
// reassigning the notifications list with just snaps
|
|
464
|
-
// since the disable shouldn't affect snaps notifications
|
|
465
|
-
state.metamaskNotificationsList = snapNotifications;
|
|
466
|
-
});
|
|
445
|
+
await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").disablePushNotifications();
|
|
467
446
|
}
|
|
468
|
-
catch
|
|
469
|
-
|
|
470
|
-
throw new Error('Unable to disable notifications');
|
|
471
|
-
}
|
|
472
|
-
finally {
|
|
473
|
-
__classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_setIsUpdatingMetamaskNotifications).call(this, false);
|
|
447
|
+
catch {
|
|
448
|
+
// Do nothing
|
|
474
449
|
}
|
|
450
|
+
// Update State: remove non-permitted notifications & disable flags
|
|
451
|
+
const snapNotifications = this.state.metamaskNotificationsList.filter((notification) => notification.type === TRIGGER_TYPES.SNAP);
|
|
452
|
+
this.update((state) => {
|
|
453
|
+
state.isNotificationServicesEnabled = false;
|
|
454
|
+
state.isFeatureAnnouncementsEnabled = false;
|
|
455
|
+
// reassigning the notifications list with just snaps
|
|
456
|
+
// since the disable shouldn't affect snaps notifications
|
|
457
|
+
state.metamaskNotificationsList = snapNotifications;
|
|
458
|
+
});
|
|
459
|
+
// Finish Updating State
|
|
460
|
+
__classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_setIsUpdatingMetamaskNotifications).call(this, false);
|
|
475
461
|
}
|
|
476
462
|
/**
|
|
477
463
|
* Deletes on-chain triggers associated with a specific account.
|
|
@@ -504,8 +490,9 @@ class NotificationServicesController extends BaseController {
|
|
|
504
490
|
}
|
|
505
491
|
// Delete these UUIDs (Mutates User Storage)
|
|
506
492
|
await OnChainNotifications.deleteOnChainTriggers(userStorage, storageKey, bearerToken, UUIDs);
|
|
507
|
-
//
|
|
508
|
-
|
|
493
|
+
// Update Push Notifications with new list of IDs
|
|
494
|
+
const remainingTriggerIds = Utils.getAllUUIDs(userStorage);
|
|
495
|
+
await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").updatePushNotifications(remainingTriggerIds);
|
|
509
496
|
// Update User Storage
|
|
510
497
|
await __classPrivateFieldGet(this, _NotificationServicesController_storage, "f").setNotificationStorage(JSON.stringify(userStorage));
|
|
511
498
|
return userStorage;
|
|
@@ -796,10 +783,9 @@ class NotificationServicesController extends BaseController {
|
|
|
796
783
|
}
|
|
797
784
|
}
|
|
798
785
|
}
|
|
799
|
-
|
|
786
|
+
_NotificationServicesController_keyringController = new WeakMap(), _NotificationServicesController_auth = new WeakMap(), _NotificationServicesController_storage = new WeakMap(), _NotificationServicesController_pushNotifications = new WeakMap(), _NotificationServicesController_accounts = new WeakMap(), _NotificationServicesController_featureAnnouncementEnv = new WeakMap(), _NotificationServicesController_instances = new WeakSet(), _NotificationServicesController_registerMessageHandlers = function _NotificationServicesController_registerMessageHandlers() {
|
|
800
787
|
this.messagingSystem.registerActionHandler(`${controllerName}:updateMetamaskNotificationsList`, this.updateMetamaskNotificationsList.bind(this));
|
|
801
788
|
this.messagingSystem.registerActionHandler(`${controllerName}:disableNotificationServices`, this.disableNotificationServices.bind(this));
|
|
802
|
-
this.messagingSystem.registerActionHandler(`${controllerName}:selectIsNotificationServicesEnabled`, this.selectIsNotificationServicesEnabled.bind(this));
|
|
803
789
|
this.messagingSystem.registerActionHandler(`${controllerName}:getNotificationsByType`, this.getNotificationsByType.bind(this));
|
|
804
790
|
this.messagingSystem.registerActionHandler(`${controllerName}:deleteNotificationsById`, this.deleteNotificationsById.bind(this));
|
|
805
791
|
}, _NotificationServicesController_clearLoadingStates = function _NotificationServicesController_clearLoadingStates() {
|
|
@@ -816,6 +802,11 @@ _NotificationServicesController_isPushIntegrated = new WeakMap(), _NotificationS
|
|
|
816
802
|
});
|
|
817
803
|
throw new Error('User is not signed in.');
|
|
818
804
|
}
|
|
805
|
+
}, _NotificationServicesController_enableAuth = async function _NotificationServicesController_enableAuth() {
|
|
806
|
+
const isSignedIn = __classPrivateFieldGet(this, _NotificationServicesController_auth, "f").isSignedIn();
|
|
807
|
+
if (!isSignedIn) {
|
|
808
|
+
await __classPrivateFieldGet(this, _NotificationServicesController_auth, "f").signIn();
|
|
809
|
+
}
|
|
819
810
|
}, _NotificationServicesController_getValidStorageKeyAndBearerToken = async function _NotificationServicesController_getValidStorageKeyAndBearerToken() {
|
|
820
811
|
__classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_assertAuthEnabled).call(this);
|
|
821
812
|
const bearerToken = await __classPrivateFieldGet(this, _NotificationServicesController_auth, "f").getBearerToken();
|
|
@@ -845,6 +836,7 @@ async function _NotificationServicesController_getUserStorage() {
|
|
|
845
836
|
}
|
|
846
837
|
try {
|
|
847
838
|
const userStorage = JSON.parse(userStorageString);
|
|
839
|
+
Utils.cleanUserStorage(userStorage);
|
|
848
840
|
return userStorage;
|
|
849
841
|
}
|
|
850
842
|
catch {
|