@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.
Files changed (148) hide show
  1. package/CHANGELOG.md +22 -3
  2. package/dist/NotificationServicesController/NotificationServicesController.cjs +70 -78
  3. package/dist/NotificationServicesController/NotificationServicesController.cjs.map +1 -1
  4. package/dist/NotificationServicesController/NotificationServicesController.d.cts +10 -34
  5. package/dist/NotificationServicesController/NotificationServicesController.d.cts.map +1 -1
  6. package/dist/NotificationServicesController/NotificationServicesController.d.mts +10 -34
  7. package/dist/NotificationServicesController/NotificationServicesController.d.mts.map +1 -1
  8. package/dist/NotificationServicesController/NotificationServicesController.mjs +71 -79
  9. package/dist/NotificationServicesController/NotificationServicesController.mjs.map +1 -1
  10. package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.cjs +1 -1
  11. package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.cjs.map +1 -1
  12. package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.d.cts.map +1 -1
  13. package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.d.mts.map +1 -1
  14. package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.mjs +1 -1
  15. package/dist/NotificationServicesController/__fixtures__/mock-notification-user-storage.mjs.map +1 -1
  16. package/dist/NotificationServicesController/__fixtures__/mockAddresses.cjs +6 -0
  17. package/dist/NotificationServicesController/__fixtures__/mockAddresses.cjs.map +1 -0
  18. package/dist/NotificationServicesController/__fixtures__/mockAddresses.d.cts +3 -0
  19. package/dist/NotificationServicesController/__fixtures__/mockAddresses.d.cts.map +1 -0
  20. package/dist/NotificationServicesController/__fixtures__/mockAddresses.d.mts +3 -0
  21. package/dist/NotificationServicesController/__fixtures__/mockAddresses.d.mts.map +1 -0
  22. package/dist/NotificationServicesController/__fixtures__/mockAddresses.mjs +3 -0
  23. package/dist/NotificationServicesController/__fixtures__/mockAddresses.mjs.map +1 -0
  24. package/dist/NotificationServicesController/index.cjs +1 -0
  25. package/dist/NotificationServicesController/index.cjs.map +1 -1
  26. package/dist/NotificationServicesController/index.d.cts +1 -0
  27. package/dist/NotificationServicesController/index.d.cts.map +1 -1
  28. package/dist/NotificationServicesController/index.d.mts +1 -0
  29. package/dist/NotificationServicesController/index.d.mts.map +1 -1
  30. package/dist/NotificationServicesController/index.mjs +1 -0
  31. package/dist/NotificationServicesController/index.mjs.map +1 -1
  32. package/dist/NotificationServicesController/services/onchain-notifications.cjs +1 -0
  33. package/dist/NotificationServicesController/services/onchain-notifications.cjs.map +1 -1
  34. package/dist/NotificationServicesController/services/onchain-notifications.d.cts.map +1 -1
  35. package/dist/NotificationServicesController/services/onchain-notifications.d.mts.map +1 -1
  36. package/dist/NotificationServicesController/services/onchain-notifications.mjs +2 -1
  37. package/dist/NotificationServicesController/services/onchain-notifications.mjs.map +1 -1
  38. package/dist/NotificationServicesController/utils/utils.cjs +28 -2
  39. package/dist/NotificationServicesController/utils/utils.cjs.map +1 -1
  40. package/dist/NotificationServicesController/utils/utils.d.cts +11 -1
  41. package/dist/NotificationServicesController/utils/utils.d.cts.map +1 -1
  42. package/dist/NotificationServicesController/utils/utils.d.mts +11 -1
  43. package/dist/NotificationServicesController/utils/utils.d.mts.map +1 -1
  44. package/dist/NotificationServicesController/utils/utils.mjs +26 -1
  45. package/dist/NotificationServicesController/utils/utils.mjs.map +1 -1
  46. package/dist/NotificationServicesPushController/NotificationServicesPushController.cjs +97 -57
  47. package/dist/NotificationServicesPushController/NotificationServicesPushController.cjs.map +1 -1
  48. package/dist/NotificationServicesPushController/NotificationServicesPushController.d.cts +19 -24
  49. package/dist/NotificationServicesPushController/NotificationServicesPushController.d.cts.map +1 -1
  50. package/dist/NotificationServicesPushController/NotificationServicesPushController.d.mts +19 -24
  51. package/dist/NotificationServicesPushController/NotificationServicesPushController.d.mts.map +1 -1
  52. package/dist/NotificationServicesPushController/NotificationServicesPushController.mjs +98 -58
  53. package/dist/NotificationServicesPushController/NotificationServicesPushController.mjs.map +1 -1
  54. package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.cjs +14 -0
  55. package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.cjs.map +1 -0
  56. package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.d.cts +3 -0
  57. package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.d.cts.map +1 -0
  58. package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.d.mts +3 -0
  59. package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.d.mts.map +1 -0
  60. package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.mjs +10 -0
  61. package/dist/NotificationServicesPushController/__fixtures__/mockMessenger.mjs.map +1 -0
  62. package/dist/NotificationServicesPushController/__fixtures__/mockServices.cjs +1 -13
  63. package/dist/NotificationServicesPushController/__fixtures__/mockServices.cjs.map +1 -1
  64. package/dist/NotificationServicesPushController/__fixtures__/mockServices.d.cts +0 -1
  65. package/dist/NotificationServicesPushController/__fixtures__/mockServices.d.cts.map +1 -1
  66. package/dist/NotificationServicesPushController/__fixtures__/mockServices.d.mts +0 -1
  67. package/dist/NotificationServicesPushController/__fixtures__/mockServices.d.mts.map +1 -1
  68. package/dist/NotificationServicesPushController/__fixtures__/mockServices.mjs +1 -12
  69. package/dist/NotificationServicesPushController/__fixtures__/mockServices.mjs.map +1 -1
  70. package/dist/NotificationServicesPushController/services/services.cjs +19 -93
  71. package/dist/NotificationServicesPushController/services/services.cjs.map +1 -1
  72. package/dist/NotificationServicesPushController/services/services.d.cts +5 -29
  73. package/dist/NotificationServicesPushController/services/services.d.cts.map +1 -1
  74. package/dist/NotificationServicesPushController/services/services.d.mts +5 -29
  75. package/dist/NotificationServicesPushController/services/services.d.mts.map +1 -1
  76. package/dist/NotificationServicesPushController/services/services.mjs +18 -94
  77. package/dist/NotificationServicesPushController/services/services.mjs.map +1 -1
  78. package/dist/NotificationServicesPushController/types/index.cjs.map +1 -1
  79. package/dist/NotificationServicesPushController/types/index.d.cts +1 -0
  80. package/dist/NotificationServicesPushController/types/index.d.cts.map +1 -1
  81. package/dist/NotificationServicesPushController/types/index.d.mts +1 -0
  82. package/dist/NotificationServicesPushController/types/index.d.mts.map +1 -1
  83. package/dist/NotificationServicesPushController/types/index.mjs.map +1 -1
  84. package/dist/NotificationServicesPushController/{services/push/index.cjs → types/push-service-interface.cjs} +1 -1
  85. package/dist/NotificationServicesPushController/types/push-service-interface.cjs.map +1 -0
  86. package/dist/NotificationServicesPushController/types/push-service-interface.d.cts +30 -0
  87. package/dist/NotificationServicesPushController/types/push-service-interface.d.cts.map +1 -0
  88. package/dist/NotificationServicesPushController/types/push-service-interface.d.mts +30 -0
  89. package/dist/NotificationServicesPushController/types/push-service-interface.d.mts.map +1 -0
  90. package/dist/NotificationServicesPushController/types/push-service-interface.mjs +2 -0
  91. package/dist/NotificationServicesPushController/types/push-service-interface.mjs.map +1 -0
  92. package/dist/NotificationServicesPushController/utils/get-notification-message.cjs +1 -19
  93. package/dist/NotificationServicesPushController/utils/get-notification-message.cjs.map +1 -1
  94. package/dist/NotificationServicesPushController/utils/get-notification-message.d.cts +0 -7
  95. package/dist/NotificationServicesPushController/utils/get-notification-message.d.cts.map +1 -1
  96. package/dist/NotificationServicesPushController/utils/get-notification-message.d.mts +0 -7
  97. package/dist/NotificationServicesPushController/utils/get-notification-message.d.mts.map +1 -1
  98. package/dist/NotificationServicesPushController/utils/get-notification-message.mjs +0 -17
  99. package/dist/NotificationServicesPushController/utils/get-notification-message.mjs.map +1 -1
  100. package/dist/NotificationServicesPushController/web/index.cjs +8 -0
  101. package/dist/NotificationServicesPushController/web/index.cjs.map +1 -0
  102. package/dist/NotificationServicesPushController/web/index.d.cts +2 -0
  103. package/dist/NotificationServicesPushController/web/index.d.cts.map +1 -0
  104. package/dist/NotificationServicesPushController/web/index.d.mts +2 -0
  105. package/dist/NotificationServicesPushController/web/index.d.mts.map +1 -0
  106. package/dist/NotificationServicesPushController/web/index.mjs +2 -0
  107. package/dist/NotificationServicesPushController/web/index.mjs.map +1 -0
  108. package/dist/NotificationServicesPushController/web/push-utils.cjs +170 -0
  109. package/dist/NotificationServicesPushController/web/push-utils.cjs.map +1 -0
  110. package/dist/NotificationServicesPushController/web/push-utils.d.cts +37 -0
  111. package/dist/NotificationServicesPushController/web/push-utils.d.cts.map +1 -0
  112. package/dist/NotificationServicesPushController/web/push-utils.d.mts +37 -0
  113. package/dist/NotificationServicesPushController/web/push-utils.d.mts.map +1 -0
  114. package/dist/NotificationServicesPushController/web/push-utils.mjs +168 -0
  115. package/dist/NotificationServicesPushController/web/push-utils.mjs.map +1 -0
  116. package/dist/shared/index.cjs +19 -0
  117. package/dist/shared/index.cjs.map +1 -0
  118. package/dist/shared/index.d.cts +3 -0
  119. package/dist/shared/index.d.cts.map +1 -0
  120. package/dist/shared/index.d.mts +3 -0
  121. package/dist/shared/index.d.mts.map +1 -0
  122. package/dist/shared/index.mjs +3 -0
  123. package/dist/shared/index.mjs.map +1 -0
  124. package/dist/shared/is-onchain-notification.cjs +22 -0
  125. package/dist/shared/is-onchain-notification.cjs.map +1 -0
  126. package/dist/shared/is-onchain-notification.d.cts +9 -0
  127. package/dist/shared/is-onchain-notification.d.cts.map +1 -0
  128. package/dist/shared/is-onchain-notification.d.mts +9 -0
  129. package/dist/shared/is-onchain-notification.d.mts.map +1 -0
  130. package/dist/shared/is-onchain-notification.mjs +18 -0
  131. package/dist/shared/is-onchain-notification.mjs.map +1 -0
  132. package/package.json +14 -4
  133. package/push-services/web/package.json +9 -0
  134. package/dist/NotificationServicesPushController/constants.cjs +0 -14
  135. package/dist/NotificationServicesPushController/constants.cjs.map +0 -1
  136. package/dist/NotificationServicesPushController/constants.d.cts +0 -11
  137. package/dist/NotificationServicesPushController/constants.d.cts.map +0 -1
  138. package/dist/NotificationServicesPushController/constants.d.mts +0 -11
  139. package/dist/NotificationServicesPushController/constants.d.mts.map +0 -1
  140. package/dist/NotificationServicesPushController/constants.mjs +0 -11
  141. package/dist/NotificationServicesPushController/constants.mjs.map +0 -1
  142. package/dist/NotificationServicesPushController/services/push/index.cjs.map +0 -1
  143. package/dist/NotificationServicesPushController/services/push/index.d.cts +0 -6
  144. package/dist/NotificationServicesPushController/services/push/index.d.cts.map +0 -1
  145. package/dist/NotificationServicesPushController/services/push/index.d.mts +0 -6
  146. package/dist/NotificationServicesPushController/services/push/index.d.mts.map +0 -1
  147. package/dist/NotificationServicesPushController/services/push/index.mjs +0 -2
  148. 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, _NotificationServicesController_isPushIntegrated, _NotificationServicesController_isPushNotificationsSetup, _NotificationServicesController_isUnlocked, _NotificationServicesController_keyringController, _NotificationServicesController_auth, _NotificationServicesController_storage, _NotificationServicesController_pushNotifications, _NotificationServicesController_accounts, _NotificationServicesController_featureAnnouncementEnv, _NotificationServicesController_registerMessageHandlers, _NotificationServicesController_clearLoadingStates, _NotificationServicesController_assertAuthEnabled, _NotificationServicesController_getValidStorageKeyAndBearerToken, _NotificationServicesController_assertUserStorage, _NotificationServicesController_getUserStorage, _NotificationServicesController_setIsUpdatingMetamaskNotifications, _NotificationServicesController_setIsFetchingMetamaskNotifications, _NotificationServicesController_setIsCheckingAccountsPresence, _NotificationServicesController_updateUpdatingAccountsState, _NotificationServicesController_clearUpdatingAccountsState;
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
- __classPrivateFieldSet(this, _NotificationServicesController_isUnlocked, isUnlocked, "f");
115
+ __classPrivateFieldGet(this, _NotificationServicesController_keyringController, "f").isUnlocked = isUnlocked;
122
116
  this.messagingSystem.subscribe('KeyringController:unlock', () => {
123
- __classPrivateFieldSet(this, _NotificationServicesController_isUnlocked, true, "f");
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
- __classPrivateFieldSet(this, _NotificationServicesController_isUnlocked, false, "f");
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 (UUIDs) => {
172
- if (!__classPrivateFieldGet(this, _NotificationServicesController_isPushIntegrated, "f")) {
173
- return;
174
- }
166
+ disablePushNotifications: async () => {
175
167
  try {
176
- await this.messagingSystem.call('NotificationServicesPushController:disablePushNotifications', UUIDs);
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, _NotificationServicesController_isPushNotificationsSetup, "f")) {
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
- if (__classPrivateFieldGet(this, _NotificationServicesController_isUnlocked, "f")) {
215
- const storage = await __classPrivateFieldGet(this, _NotificationServicesController_instances, "m", _NotificationServicesController_getUserStorage).call(this);
216
- if (!storage) {
217
- return;
197
+ try {
198
+ if (!__classPrivateFieldGet(this, _NotificationServicesController_keyringController, "f").isUnlocked) {
199
+ throw new Error('Keyring is locked');
218
200
  }
219
- const uuids = Utils.getAllUUIDs(storage);
220
- await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").enablePushNotifications(uuids);
221
- __classPrivateFieldSet(this, _NotificationServicesController_isPushNotificationsSetup, true, "f");
201
+ await this.enablePushNotifications();
202
+ __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").isSetup = true;
222
203
  }
223
- else {
224
- await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").subscribeToPushNotifications();
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.map((a) => toChecksumHexAddress(a));
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, _NotificationServicesController_isUnlocked, "f") && !__classPrivateFieldGet(this, _NotificationServicesController_accounts, "f").isNotificationAccountsSetup) {
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
- * Retrieves the current enabled state of MetaMask notifications.
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
- selectIsNotificationServicesEnabled() {
322
- return this.state.isNotificationServicesEnabled;
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
- const isSignedIn = __classPrivateFieldGet(this, _NotificationServicesController_auth, "f").isSignedIn();
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, _NotificationServicesController_instances, "m", _NotificationServicesController_setIsUpdatingMetamaskNotifications).call(this, true);
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 (e) {
469
- log.error('Unable to disable notifications', e);
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
- // Delete these UUIDs from the push notifications
508
- await __classPrivateFieldGet(this, _NotificationServicesController_pushNotifications, "f").disablePushNotifications(UUIDs);
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
- _NotificationServicesController_isPushIntegrated = new WeakMap(), _NotificationServicesController_isPushNotificationsSetup = new WeakMap(), _NotificationServicesController_isUnlocked = new WeakMap(), _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() {
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 {