@metamask-previews/account-tree-controller 0.6.0-preview-b8fffa99 → 0.6.0-preview-ed2a2e6

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 (114) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/AccountTreeController.cjs +86 -25
  3. package/dist/AccountTreeController.cjs.map +1 -1
  4. package/dist/AccountTreeController.d.cts +3 -1
  5. package/dist/AccountTreeController.d.cts.map +1 -1
  6. package/dist/AccountTreeController.d.mts +3 -1
  7. package/dist/AccountTreeController.d.mts.map +1 -1
  8. package/dist/AccountTreeController.mjs +87 -26
  9. package/dist/AccountTreeController.mjs.map +1 -1
  10. package/dist/AccountTreeGroup.cjs +51 -35
  11. package/dist/AccountTreeGroup.cjs.map +1 -1
  12. package/dist/AccountTreeGroup.d.cts +15 -22
  13. package/dist/AccountTreeGroup.d.cts.map +1 -1
  14. package/dist/AccountTreeGroup.d.mts +15 -22
  15. package/dist/AccountTreeGroup.d.mts.map +1 -1
  16. package/dist/AccountTreeGroup.mjs +49 -33
  17. package/dist/AccountTreeGroup.mjs.map +1 -1
  18. package/dist/AccountTreeWallet.cjs +61 -27
  19. package/dist/AccountTreeWallet.cjs.map +1 -1
  20. package/dist/AccountTreeWallet.d.cts +24 -17
  21. package/dist/AccountTreeWallet.d.cts.map +1 -1
  22. package/dist/AccountTreeWallet.d.mts +24 -17
  23. package/dist/AccountTreeWallet.d.mts.map +1 -1
  24. package/dist/AccountTreeWallet.mjs +60 -26
  25. package/dist/AccountTreeWallet.mjs.map +1 -1
  26. package/dist/rules/entropy.cjs +57 -0
  27. package/dist/rules/entropy.cjs.map +1 -0
  28. package/dist/rules/entropy.d.cts +13 -0
  29. package/dist/rules/entropy.d.cts.map +1 -0
  30. package/dist/rules/entropy.d.mts +13 -0
  31. package/dist/rules/entropy.d.mts.map +1 -0
  32. package/dist/rules/entropy.mjs +53 -0
  33. package/dist/rules/entropy.mjs.map +1 -0
  34. package/dist/rules/index.cjs +4 -4
  35. package/dist/rules/index.cjs.map +1 -1
  36. package/dist/rules/index.d.cts +4 -4
  37. package/dist/rules/index.d.cts.map +1 -1
  38. package/dist/rules/index.d.mts +4 -4
  39. package/dist/rules/index.d.mts.map +1 -1
  40. package/dist/rules/index.mjs +4 -4
  41. package/dist/rules/index.mjs.map +1 -1
  42. package/dist/rules/keyring.cjs +80 -0
  43. package/dist/rules/keyring.cjs.map +1 -0
  44. package/dist/rules/keyring.d.cts +20 -0
  45. package/dist/rules/keyring.d.cts.map +1 -0
  46. package/dist/rules/keyring.d.mts +20 -0
  47. package/dist/rules/keyring.d.mts.map +1 -0
  48. package/dist/rules/keyring.mjs +75 -0
  49. package/dist/rules/keyring.mjs.map +1 -0
  50. package/dist/rules/rule.cjs +10 -0
  51. package/dist/rules/rule.cjs.map +1 -0
  52. package/dist/rules/rule.d.cts +42 -0
  53. package/dist/rules/rule.d.cts.map +1 -0
  54. package/dist/rules/rule.d.mts +42 -0
  55. package/dist/rules/rule.d.mts.map +1 -0
  56. package/dist/rules/rule.mjs +6 -0
  57. package/dist/rules/rule.mjs.map +1 -0
  58. package/dist/rules/snap.cjs +53 -0
  59. package/dist/rules/snap.cjs.map +1 -0
  60. package/dist/rules/snap.d.cts +23 -0
  61. package/dist/rules/snap.d.cts.map +1 -0
  62. package/dist/rules/snap.d.mts +23 -0
  63. package/dist/rules/snap.d.mts.map +1 -0
  64. package/dist/rules/snap.mjs +49 -0
  65. package/dist/rules/snap.mjs.map +1 -0
  66. package/dist/types.cjs +3 -0
  67. package/dist/types.cjs.map +1 -0
  68. package/dist/types.d.cts +15 -0
  69. package/dist/types.d.cts.map +1 -0
  70. package/dist/types.d.mts +15 -0
  71. package/dist/types.d.mts.map +1 -0
  72. package/dist/types.mjs +2 -0
  73. package/dist/types.mjs.map +1 -0
  74. package/package.json +3 -3
  75. package/dist/rules/EntropySourceWalletRule.cjs +0 -100
  76. package/dist/rules/EntropySourceWalletRule.cjs.map +0 -1
  77. package/dist/rules/EntropySourceWalletRule.d.cts +0 -19
  78. package/dist/rules/EntropySourceWalletRule.d.cts.map +0 -1
  79. package/dist/rules/EntropySourceWalletRule.d.mts +0 -19
  80. package/dist/rules/EntropySourceWalletRule.d.mts.map +0 -1
  81. package/dist/rules/EntropySourceWalletRule.mjs +0 -95
  82. package/dist/rules/EntropySourceWalletRule.mjs.map +0 -1
  83. package/dist/rules/KeyringWalletRule.cjs +0 -99
  84. package/dist/rules/KeyringWalletRule.cjs.map +0 -1
  85. package/dist/rules/KeyringWalletRule.d.cts +0 -18
  86. package/dist/rules/KeyringWalletRule.d.cts.map +0 -1
  87. package/dist/rules/KeyringWalletRule.d.mts +0 -18
  88. package/dist/rules/KeyringWalletRule.d.mts.map +0 -1
  89. package/dist/rules/KeyringWalletRule.mjs +0 -94
  90. package/dist/rules/KeyringWalletRule.mjs.map +0 -1
  91. package/dist/rules/SnapWalletRule.cjs +0 -70
  92. package/dist/rules/SnapWalletRule.cjs.map +0 -1
  93. package/dist/rules/SnapWalletRule.d.cts +0 -10
  94. package/dist/rules/SnapWalletRule.d.cts.map +0 -1
  95. package/dist/rules/SnapWalletRule.d.mts +0 -10
  96. package/dist/rules/SnapWalletRule.d.mts.map +0 -1
  97. package/dist/rules/SnapWalletRule.mjs +0 -66
  98. package/dist/rules/SnapWalletRule.mjs.map +0 -1
  99. package/dist/rules/WalletRule.cjs +0 -13
  100. package/dist/rules/WalletRule.cjs.map +0 -1
  101. package/dist/rules/WalletRule.d.cts +0 -37
  102. package/dist/rules/WalletRule.d.cts.map +0 -1
  103. package/dist/rules/WalletRule.d.mts +0 -37
  104. package/dist/rules/WalletRule.d.mts.map +0 -1
  105. package/dist/rules/WalletRule.mjs +0 -9
  106. package/dist/rules/WalletRule.mjs.map +0 -1
  107. package/dist/rules/utils.cjs +0 -15
  108. package/dist/rules/utils.cjs.map +0 -1
  109. package/dist/rules/utils.d.cts +0 -11
  110. package/dist/rules/utils.d.cts.map +0 -1
  111. package/dist/rules/utils.d.mts +0 -11
  112. package/dist/rules/utils.d.mts.map +0 -1
  113. package/dist/rules/utils.mjs +0 -11
  114. package/dist/rules/utils.mjs.map +0 -1
@@ -1,19 +0,0 @@
1
- import type { KeyringObject } from "@metamask/keyring-controller";
2
- import type { InternalAccount } from "@metamask/keyring-internal-api";
3
- import type { WalletRuleMatch } from "./WalletRule.mjs";
4
- import { BaseWalletRule } from "./WalletRule.mjs";
5
- import type { AccountTreeControllerMessenger } from "../AccountTreeController.mjs";
6
- import { MutableAccountTreeWallet } from "../AccountTreeWallet.mjs";
7
- export declare class EntropySourceWallet extends MutableAccountTreeWallet {
8
- readonly entropySource: string;
9
- constructor(messenger: AccountTreeControllerMessenger, entropySource: string);
10
- static toAccountWalletId(entropySource: string): `entropy:${string}` | `keyring:${string}` | `snap:${string}`;
11
- static getEntropySourceIndex(keyrings: KeyringObject[], entropySource: string): number;
12
- getDefaultName(): string;
13
- }
14
- export declare class EntropySourceWalletRule extends BaseWalletRule {
15
- #private;
16
- constructor(messenger: AccountTreeControllerMessenger);
17
- match(account: InternalAccount): WalletRuleMatch | undefined;
18
- }
19
- //# sourceMappingURL=EntropySourceWalletRule.d.mts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"EntropySourceWalletRule.d.mts","sourceRoot":"","sources":["../../src/rules/EntropySourceWalletRule.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,qCAAqC;AAElE,OAAO,KAAK,EAAE,eAAe,EAAE,uCAAuC;AAGtE,OAAO,KAAK,EAAE,eAAe,EAAE,yBAAqB;AACpD,OAAO,EAAE,cAAc,EAAE,yBAAqB;AAC9C,OAAO,KAAK,EAAE,8BAA8B,EAAE,qCAAiC;AAC/E,OAAO,EAAE,wBAAwB,EAAE,iCAA6B;AAEhE,qBAAa,mBAAoB,SAAQ,wBAAwB;IAC/D,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;gBAG7B,SAAS,EAAE,8BAA8B,EACzC,aAAa,EAAE,MAAM;IAMvB,MAAM,CAAC,iBAAiB,CAAC,aAAa,EAAE,MAAM;IAI9C,MAAM,CAAC,qBAAqB,CAC1B,QAAQ,EAAE,aAAa,EAAE,EACzB,aAAa,EAAE,MAAM;IAOvB,cAAc,IAAI,MAAM;CAezB;AAED,qBAAa,uBAAwB,SAAQ,cAAc;;gBAG7C,SAAS,EAAE,8BAA8B;IAMrD,KAAK,CAAC,OAAO,EAAE,eAAe,GAAG,eAAe,GAAG,SAAS;CA+D7D"}
@@ -1,95 +0,0 @@
1
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
2
- if (kind === "m") throw new TypeError("Private method is not writable");
3
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
4
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
5
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
6
- };
7
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
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
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
- };
12
- var _EntropySourceWalletRule_wallets;
13
- import { AccountWalletCategory, toAccountWalletId } from "@metamask/account-api";
14
- import { KeyringTypes } from "@metamask/keyring-controller";
15
- import { hasKeyringType } from "./utils.mjs";
16
- import { BaseWalletRule } from "./WalletRule.mjs";
17
- import { MutableAccountTreeWallet } from "../AccountTreeWallet.mjs";
18
- export class EntropySourceWallet extends MutableAccountTreeWallet {
19
- constructor(messenger, entropySource) {
20
- super(messenger, AccountWalletCategory.Entropy, entropySource);
21
- this.entropySource = entropySource;
22
- }
23
- static toAccountWalletId(entropySource) {
24
- return toAccountWalletId(AccountWalletCategory.Entropy, entropySource);
25
- }
26
- static getEntropySourceIndex(keyrings, entropySource) {
27
- return keyrings
28
- .filter((keyring) => keyring.type === KeyringTypes.hd)
29
- .findIndex((keyring) => keyring.metadata.id === entropySource);
30
- }
31
- getDefaultName() {
32
- const { keyrings } = this.messenger.call('KeyringController:getState');
33
- const index = EntropySourceWallet.getEntropySourceIndex(keyrings, this.entropySource);
34
- if (index === -1) {
35
- // NOTE: This should never really fail, as we checked for this precondition
36
- // during rule matching.
37
- throw new Error('Unable to get index for entropy source');
38
- }
39
- return `Wallet ${index + 1}`; // Use human indexing.
40
- }
41
- }
42
- export class EntropySourceWalletRule extends BaseWalletRule {
43
- constructor(messenger) {
44
- super(messenger);
45
- _EntropySourceWalletRule_wallets.set(this, void 0);
46
- __classPrivateFieldSet(this, _EntropySourceWalletRule_wallets, new Map(), "f");
47
- }
48
- match(account) {
49
- let entropySource;
50
- if (hasKeyringType(account, KeyringTypes.hd)) {
51
- // TODO: Maybe use superstruct to validate the structure of HD account since they are not strongly-typed for now?
52
- if (!account.options.entropySource) {
53
- console.warn("! Found an HD account with no entropy source: account won't be associated to its wallet");
54
- return undefined;
55
- }
56
- entropySource = account.options.entropySource;
57
- }
58
- // TODO: For now, we're not checking if the Snap is a preinstalled one, and we probably should...
59
- if (hasKeyringType(account, KeyringTypes.snap) &&
60
- account.metadata.snap?.enabled) {
61
- // Not all Snaps have an entropy-source and options are not typed yet, so we have to check manually here.
62
- if (account.options.entropySource) {
63
- // We blindly trust the `entropySource` for now, but it could be wrong since it comes from a Snap.
64
- entropySource = account.options.entropySource;
65
- }
66
- }
67
- if (!entropySource) {
68
- return undefined;
69
- }
70
- // NOTE: We make this check now, so that we are guaranteed that `getDefaultName` will never fail if we
71
- // pass that point:
72
- // ------------------------------------------------------------------------------------------------------
73
- // We check if we can get the name for that entropy source, if not this means this entropy does not match
74
- // any HD keyrings, thus, is invalid (this account will be grouped by another rule).
75
- const { keyrings } = this.messenger.call('KeyringController:getState');
76
- if (EntropySourceWallet.getEntropySourceIndex(keyrings, entropySource) === -1) {
77
- console.warn('! Tried to name a wallet using an unknown entropy, this should not be possible.');
78
- return undefined;
79
- }
80
- // Check if a wallet already exists for that entropy source.
81
- let wallet = __classPrivateFieldGet(this, _EntropySourceWalletRule_wallets, "f").get(EntropySourceWallet.toAccountWalletId(entropySource));
82
- if (!wallet) {
83
- wallet = new EntropySourceWallet(this.messenger, entropySource);
84
- __classPrivateFieldGet(this, _EntropySourceWalletRule_wallets, "f").set(wallet.id, wallet);
85
- }
86
- // This will automatically creates the group if it's missing.
87
- const group = wallet.addAccount(account);
88
- return {
89
- wallet,
90
- group,
91
- };
92
- }
93
- }
94
- _EntropySourceWalletRule_wallets = new WeakMap();
95
- //# sourceMappingURL=EntropySourceWalletRule.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"EntropySourceWalletRule.mjs","sourceRoot":"","sources":["../../src/rules/EntropySourceWalletRule.ts"],"names":[],"mappings":"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","sourcesContent":["import type { AccountWalletId } from '@metamask/account-api';\nimport {\n AccountWalletCategory,\n toAccountWalletId,\n} from '@metamask/account-api';\nimport type { KeyringObject } from '@metamask/keyring-controller';\nimport { KeyringTypes } from '@metamask/keyring-controller';\nimport type { InternalAccount } from '@metamask/keyring-internal-api';\n\nimport { hasKeyringType } from './utils';\nimport type { WalletRuleMatch } from './WalletRule';\nimport { BaseWalletRule } from './WalletRule';\nimport type { AccountTreeControllerMessenger } from '../AccountTreeController';\nimport { MutableAccountTreeWallet } from '../AccountTreeWallet';\n\nexport class EntropySourceWallet extends MutableAccountTreeWallet {\n readonly entropySource: string;\n\n constructor(\n messenger: AccountTreeControllerMessenger,\n entropySource: string,\n ) {\n super(messenger, AccountWalletCategory.Entropy, entropySource);\n this.entropySource = entropySource;\n }\n\n static toAccountWalletId(entropySource: string) {\n return toAccountWalletId(AccountWalletCategory.Entropy, entropySource);\n }\n\n static getEntropySourceIndex(\n keyrings: KeyringObject[],\n entropySource: string,\n ) {\n return keyrings\n .filter((keyring) => keyring.type === (KeyringTypes.hd as string))\n .findIndex((keyring) => keyring.metadata.id === entropySource);\n }\n\n getDefaultName(): string {\n const { keyrings } = this.messenger.call('KeyringController:getState');\n\n const index = EntropySourceWallet.getEntropySourceIndex(\n keyrings,\n this.entropySource,\n );\n if (index === -1) {\n // NOTE: This should never really fail, as we checked for this precondition\n // during rule matching.\n throw new Error('Unable to get index for entropy source');\n }\n\n return `Wallet ${index + 1}`; // Use human indexing.\n }\n}\n\nexport class EntropySourceWalletRule extends BaseWalletRule {\n readonly #wallets: Map<AccountWalletId, EntropySourceWallet>;\n\n constructor(messenger: AccountTreeControllerMessenger) {\n super(messenger);\n\n this.#wallets = new Map();\n }\n\n match(account: InternalAccount): WalletRuleMatch | undefined {\n let entropySource: string | undefined;\n\n if (hasKeyringType(account, KeyringTypes.hd)) {\n // TODO: Maybe use superstruct to validate the structure of HD account since they are not strongly-typed for now?\n if (!account.options.entropySource) {\n console.warn(\n \"! Found an HD account with no entropy source: account won't be associated to its wallet\",\n );\n return undefined;\n }\n\n entropySource = account.options.entropySource as string;\n }\n\n // TODO: For now, we're not checking if the Snap is a preinstalled one, and we probably should...\n if (\n hasKeyringType(account, KeyringTypes.snap) &&\n account.metadata.snap?.enabled\n ) {\n // Not all Snaps have an entropy-source and options are not typed yet, so we have to check manually here.\n if (account.options.entropySource) {\n // We blindly trust the `entropySource` for now, but it could be wrong since it comes from a Snap.\n entropySource = account.options.entropySource as string;\n }\n }\n\n if (!entropySource) {\n return undefined;\n }\n\n // NOTE: We make this check now, so that we are guaranteed that `getDefaultName` will never fail if we\n // pass that point:\n // ------------------------------------------------------------------------------------------------------\n // We check if we can get the name for that entropy source, if not this means this entropy does not match\n // any HD keyrings, thus, is invalid (this account will be grouped by another rule).\n const { keyrings } = this.messenger.call('KeyringController:getState');\n if (\n EntropySourceWallet.getEntropySourceIndex(keyrings, entropySource) === -1\n ) {\n console.warn(\n '! Tried to name a wallet using an unknown entropy, this should not be possible.',\n );\n return undefined;\n }\n\n // Check if a wallet already exists for that entropy source.\n let wallet = this.#wallets.get(\n EntropySourceWallet.toAccountWalletId(entropySource),\n );\n if (!wallet) {\n wallet = new EntropySourceWallet(this.messenger, entropySource);\n this.#wallets.set(wallet.id, wallet);\n }\n\n // This will automatically creates the group if it's missing.\n const group = wallet.addAccount(account);\n\n return {\n wallet,\n group,\n };\n }\n}\n"]}
@@ -1,99 +0,0 @@
1
- "use strict";
2
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
- if (kind === "m") throw new TypeError("Private method is not writable");
4
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
- };
8
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
- 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");
11
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
- };
13
- var _KeyringWalletRule_wallets;
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.KeyringWalletRule = exports.getAccountWalletNameFromKeyringType = void 0;
16
- const account_api_1 = require("@metamask/account-api");
17
- const keyring_controller_1 = require("@metamask/keyring-controller");
18
- const WalletRule_1 = require("./WalletRule.cjs");
19
- const AccountTreeWallet_1 = require("../AccountTreeWallet.cjs");
20
- /**
21
- * Get wallet name from a keyring type.
22
- *
23
- * @param type - Keyring's type.
24
- * @returns Wallet name.
25
- */
26
- function getAccountWalletNameFromKeyringType(type) {
27
- switch (type) {
28
- case keyring_controller_1.KeyringTypes.simple: {
29
- return 'Imported accounts';
30
- }
31
- case keyring_controller_1.KeyringTypes.trezor: {
32
- return 'Trezor';
33
- }
34
- case keyring_controller_1.KeyringTypes.oneKey: {
35
- return 'OneKey';
36
- }
37
- case keyring_controller_1.KeyringTypes.ledger: {
38
- return 'Ledger';
39
- }
40
- case keyring_controller_1.KeyringTypes.lattice: {
41
- return 'Lattice';
42
- }
43
- case keyring_controller_1.KeyringTypes.qr: {
44
- return 'QR';
45
- }
46
- // Those keyrings should never really be used in such context since they
47
- // should be used by other grouping rules.
48
- case keyring_controller_1.KeyringTypes.hd: {
49
- return 'HD Wallet';
50
- }
51
- case keyring_controller_1.KeyringTypes.snap: {
52
- return 'Snap Wallet';
53
- }
54
- // ------------------------------------------------------------------------
55
- default: {
56
- return 'Unknown';
57
- }
58
- }
59
- }
60
- exports.getAccountWalletNameFromKeyringType = getAccountWalletNameFromKeyringType;
61
- class KeyringTypeWallet extends AccountTreeWallet_1.MutableAccountTreeWallet {
62
- constructor(messenger, type) {
63
- super(messenger, account_api_1.AccountWalletCategory.Keyring, type);
64
- this.type = type;
65
- }
66
- static toAccountWalletId(type) {
67
- return (0, account_api_1.toAccountWalletId)(account_api_1.AccountWalletCategory.Keyring, type);
68
- }
69
- getDefaultName() {
70
- return getAccountWalletNameFromKeyringType(this.type);
71
- }
72
- }
73
- class KeyringWalletRule extends WalletRule_1.BaseWalletRule {
74
- constructor(messenger) {
75
- super(messenger);
76
- _KeyringWalletRule_wallets.set(this, void 0);
77
- __classPrivateFieldSet(this, _KeyringWalletRule_wallets, new Map(), "f");
78
- }
79
- match(account) {
80
- const { type } = account.metadata.keyring;
81
- // We assume that `type` is really a `KeyringTypes`.
82
- const keyringType = type;
83
- // Check if a wallet already exists for that keyring type.
84
- let wallet = __classPrivateFieldGet(this, _KeyringWalletRule_wallets, "f").get(KeyringTypeWallet.toAccountWalletId(keyringType));
85
- if (!wallet) {
86
- wallet = new KeyringTypeWallet(this.messenger, keyringType);
87
- __classPrivateFieldGet(this, _KeyringWalletRule_wallets, "f").set(wallet.id, wallet);
88
- }
89
- // This will automatically creates the group if it's missing.
90
- const group = wallet.addAccount(account);
91
- return {
92
- wallet,
93
- group,
94
- };
95
- }
96
- }
97
- exports.KeyringWalletRule = KeyringWalletRule;
98
- _KeyringWalletRule_wallets = new WeakMap();
99
- //# sourceMappingURL=KeyringWalletRule.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyringWalletRule.cjs","sourceRoot":"","sources":["../../src/rules/KeyringWalletRule.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,uDAG+B;AAC/B,qEAA4D;AAI5D,iDAA8C;AAE9C,gEAAgE;AAEhE;;;;;GAKG;AACH,SAAgB,mCAAmC,CAAC,IAAkB;IACpE,QAAQ,IAAI,EAAE;QACZ,KAAK,iCAAY,CAAC,MAAM,CAAC,CAAC;YACxB,OAAO,mBAAmB,CAAC;SAC5B;QACD,KAAK,iCAAY,CAAC,MAAM,CAAC,CAAC;YACxB,OAAO,QAAQ,CAAC;SACjB;QACD,KAAK,iCAAY,CAAC,MAAM,CAAC,CAAC;YACxB,OAAO,QAAQ,CAAC;SACjB;QACD,KAAK,iCAAY,CAAC,MAAM,CAAC,CAAC;YACxB,OAAO,QAAQ,CAAC;SACjB;QACD,KAAK,iCAAY,CAAC,OAAO,CAAC,CAAC;YACzB,OAAO,SAAS,CAAC;SAClB;QACD,KAAK,iCAAY,CAAC,EAAE,CAAC,CAAC;YACpB,OAAO,IAAI,CAAC;SACb;QACD,wEAAwE;QACxE,0CAA0C;QAC1C,KAAK,iCAAY,CAAC,EAAE,CAAC,CAAC;YACpB,OAAO,WAAW,CAAC;SACpB;QACD,KAAK,iCAAY,CAAC,IAAI,CAAC,CAAC;YACtB,OAAO,aAAa,CAAC;SACtB;QACD,2EAA2E;QAC3E,OAAO,CAAC,CAAC;YACP,OAAO,SAAS,CAAC;SAClB;KACF;AACH,CAAC;AAjCD,kFAiCC;AAED,MAAM,iBAAkB,SAAQ,4CAAwB;IAGtD,YAAY,SAAyC,EAAE,IAAkB;QACvE,KAAK,CAAC,SAAS,EAAE,mCAAqB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,IAAkB;QACzC,OAAO,IAAA,+BAAiB,EAAC,mCAAqB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAChE,CAAC;IAED,cAAc;QACZ,OAAO,mCAAmC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxD,CAAC;CACF;AAED,MAAa,iBAAkB,SAAQ,2BAAc;IAGnD,YAAY,SAAyC;QACnD,KAAK,CAAC,SAAS,CAAC,CAAC;QAHV,6CAAkD;QAKzD,uBAAA,IAAI,8BAAY,IAAI,GAAG,EAAE,MAAA,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,OAAwB;QAC5B,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC;QAC1C,oDAAoD;QACpD,MAAM,WAAW,GAAG,IAAoB,CAAC;QAEzC,0DAA0D;QAC1D,IAAI,MAAM,GAAG,uBAAA,IAAI,kCAAS,CAAC,GAAG,CAC5B,iBAAiB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CACjD,CAAC;QACF,IAAI,CAAC,MAAM,EAAE;YACX,MAAM,GAAG,IAAI,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;YAC5D,uBAAA,IAAI,kCAAS,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;SACtC;QAED,6DAA6D;QAC7D,MAAM,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEzC,OAAO;YACL,MAAM;YACN,KAAK;SACN,CAAC;IACJ,CAAC;CACF;AA/BD,8CA+BC","sourcesContent":["import type { AccountWalletId } from '@metamask/account-api';\nimport {\n AccountWalletCategory,\n toAccountWalletId,\n} from '@metamask/account-api';\nimport { KeyringTypes } from '@metamask/keyring-controller';\nimport type { InternalAccount } from '@metamask/keyring-internal-api';\n\nimport type { WalletRuleMatch } from './WalletRule';\nimport { BaseWalletRule } from './WalletRule';\nimport type { AccountTreeControllerMessenger } from '../AccountTreeController';\nimport { MutableAccountTreeWallet } from '../AccountTreeWallet';\n\n/**\n * Get wallet name from a keyring type.\n *\n * @param type - Keyring's type.\n * @returns Wallet name.\n */\nexport function getAccountWalletNameFromKeyringType(type: KeyringTypes) {\n switch (type) {\n case KeyringTypes.simple: {\n return 'Imported accounts';\n }\n case KeyringTypes.trezor: {\n return 'Trezor';\n }\n case KeyringTypes.oneKey: {\n return 'OneKey';\n }\n case KeyringTypes.ledger: {\n return 'Ledger';\n }\n case KeyringTypes.lattice: {\n return 'Lattice';\n }\n case KeyringTypes.qr: {\n return 'QR';\n }\n // Those keyrings should never really be used in such context since they\n // should be used by other grouping rules.\n case KeyringTypes.hd: {\n return 'HD Wallet';\n }\n case KeyringTypes.snap: {\n return 'Snap Wallet';\n }\n // ------------------------------------------------------------------------\n default: {\n return 'Unknown';\n }\n }\n}\n\nclass KeyringTypeWallet extends MutableAccountTreeWallet {\n readonly type: KeyringTypes;\n\n constructor(messenger: AccountTreeControllerMessenger, type: KeyringTypes) {\n super(messenger, AccountWalletCategory.Keyring, type);\n this.type = type;\n }\n\n static toAccountWalletId(type: KeyringTypes) {\n return toAccountWalletId(AccountWalletCategory.Keyring, type);\n }\n\n getDefaultName(): string {\n return getAccountWalletNameFromKeyringType(this.type);\n }\n}\n\nexport class KeyringWalletRule extends BaseWalletRule {\n readonly #wallets: Map<AccountWalletId, KeyringTypeWallet>;\n\n constructor(messenger: AccountTreeControllerMessenger) {\n super(messenger);\n\n this.#wallets = new Map();\n }\n\n match(account: InternalAccount): WalletRuleMatch | undefined {\n const { type } = account.metadata.keyring;\n // We assume that `type` is really a `KeyringTypes`.\n const keyringType = type as KeyringTypes;\n\n // Check if a wallet already exists for that keyring type.\n let wallet = this.#wallets.get(\n KeyringTypeWallet.toAccountWalletId(keyringType),\n );\n if (!wallet) {\n wallet = new KeyringTypeWallet(this.messenger, keyringType);\n this.#wallets.set(wallet.id, wallet);\n }\n\n // This will automatically creates the group if it's missing.\n const group = wallet.addAccount(account);\n\n return {\n wallet,\n group,\n };\n }\n}\n"]}
@@ -1,18 +0,0 @@
1
- import { KeyringTypes } from "@metamask/keyring-controller";
2
- import type { InternalAccount } from "@metamask/keyring-internal-api";
3
- import type { WalletRuleMatch } from "./WalletRule.cjs";
4
- import { BaseWalletRule } from "./WalletRule.cjs";
5
- import type { AccountTreeControllerMessenger } from "../AccountTreeController.cjs";
6
- /**
7
- * Get wallet name from a keyring type.
8
- *
9
- * @param type - Keyring's type.
10
- * @returns Wallet name.
11
- */
12
- export declare function getAccountWalletNameFromKeyringType(type: KeyringTypes): "Imported accounts" | "Trezor" | "OneKey" | "Ledger" | "Lattice" | "QR" | "HD Wallet" | "Snap Wallet" | "Unknown";
13
- export declare class KeyringWalletRule extends BaseWalletRule {
14
- #private;
15
- constructor(messenger: AccountTreeControllerMessenger);
16
- match(account: InternalAccount): WalletRuleMatch | undefined;
17
- }
18
- //# sourceMappingURL=KeyringWalletRule.d.cts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyringWalletRule.d.cts","sourceRoot":"","sources":["../../src/rules/KeyringWalletRule.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,YAAY,EAAE,qCAAqC;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,uCAAuC;AAEtE,OAAO,KAAK,EAAE,eAAe,EAAE,yBAAqB;AACpD,OAAO,EAAE,cAAc,EAAE,yBAAqB;AAC9C,OAAO,KAAK,EAAE,8BAA8B,EAAE,qCAAiC;AAG/E;;;;;GAKG;AACH,wBAAgB,mCAAmC,CAAC,IAAI,EAAE,YAAY,qHAiCrE;AAmBD,qBAAa,iBAAkB,SAAQ,cAAc;;gBAGvC,SAAS,EAAE,8BAA8B;IAMrD,KAAK,CAAC,OAAO,EAAE,eAAe,GAAG,eAAe,GAAG,SAAS;CAsB7D"}
@@ -1,18 +0,0 @@
1
- import { KeyringTypes } from "@metamask/keyring-controller";
2
- import type { InternalAccount } from "@metamask/keyring-internal-api";
3
- import type { WalletRuleMatch } from "./WalletRule.mjs";
4
- import { BaseWalletRule } from "./WalletRule.mjs";
5
- import type { AccountTreeControllerMessenger } from "../AccountTreeController.mjs";
6
- /**
7
- * Get wallet name from a keyring type.
8
- *
9
- * @param type - Keyring's type.
10
- * @returns Wallet name.
11
- */
12
- export declare function getAccountWalletNameFromKeyringType(type: KeyringTypes): "Imported accounts" | "Trezor" | "OneKey" | "Ledger" | "Lattice" | "QR" | "HD Wallet" | "Snap Wallet" | "Unknown";
13
- export declare class KeyringWalletRule extends BaseWalletRule {
14
- #private;
15
- constructor(messenger: AccountTreeControllerMessenger);
16
- match(account: InternalAccount): WalletRuleMatch | undefined;
17
- }
18
- //# sourceMappingURL=KeyringWalletRule.d.mts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyringWalletRule.d.mts","sourceRoot":"","sources":["../../src/rules/KeyringWalletRule.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,YAAY,EAAE,qCAAqC;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,uCAAuC;AAEtE,OAAO,KAAK,EAAE,eAAe,EAAE,yBAAqB;AACpD,OAAO,EAAE,cAAc,EAAE,yBAAqB;AAC9C,OAAO,KAAK,EAAE,8BAA8B,EAAE,qCAAiC;AAG/E;;;;;GAKG;AACH,wBAAgB,mCAAmC,CAAC,IAAI,EAAE,YAAY,qHAiCrE;AAmBD,qBAAa,iBAAkB,SAAQ,cAAc;;gBAGvC,SAAS,EAAE,8BAA8B;IAMrD,KAAK,CAAC,OAAO,EAAE,eAAe,GAAG,eAAe,GAAG,SAAS;CAsB7D"}
@@ -1,94 +0,0 @@
1
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
2
- if (kind === "m") throw new TypeError("Private method is not writable");
3
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
4
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
5
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
6
- };
7
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
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
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
- };
12
- var _KeyringWalletRule_wallets;
13
- import { AccountWalletCategory, toAccountWalletId } from "@metamask/account-api";
14
- import { KeyringTypes } from "@metamask/keyring-controller";
15
- import { BaseWalletRule } from "./WalletRule.mjs";
16
- import { MutableAccountTreeWallet } from "../AccountTreeWallet.mjs";
17
- /**
18
- * Get wallet name from a keyring type.
19
- *
20
- * @param type - Keyring's type.
21
- * @returns Wallet name.
22
- */
23
- export function getAccountWalletNameFromKeyringType(type) {
24
- switch (type) {
25
- case KeyringTypes.simple: {
26
- return 'Imported accounts';
27
- }
28
- case KeyringTypes.trezor: {
29
- return 'Trezor';
30
- }
31
- case KeyringTypes.oneKey: {
32
- return 'OneKey';
33
- }
34
- case KeyringTypes.ledger: {
35
- return 'Ledger';
36
- }
37
- case KeyringTypes.lattice: {
38
- return 'Lattice';
39
- }
40
- case KeyringTypes.qr: {
41
- return 'QR';
42
- }
43
- // Those keyrings should never really be used in such context since they
44
- // should be used by other grouping rules.
45
- case KeyringTypes.hd: {
46
- return 'HD Wallet';
47
- }
48
- case KeyringTypes.snap: {
49
- return 'Snap Wallet';
50
- }
51
- // ------------------------------------------------------------------------
52
- default: {
53
- return 'Unknown';
54
- }
55
- }
56
- }
57
- class KeyringTypeWallet extends MutableAccountTreeWallet {
58
- constructor(messenger, type) {
59
- super(messenger, AccountWalletCategory.Keyring, type);
60
- this.type = type;
61
- }
62
- static toAccountWalletId(type) {
63
- return toAccountWalletId(AccountWalletCategory.Keyring, type);
64
- }
65
- getDefaultName() {
66
- return getAccountWalletNameFromKeyringType(this.type);
67
- }
68
- }
69
- export class KeyringWalletRule extends BaseWalletRule {
70
- constructor(messenger) {
71
- super(messenger);
72
- _KeyringWalletRule_wallets.set(this, void 0);
73
- __classPrivateFieldSet(this, _KeyringWalletRule_wallets, new Map(), "f");
74
- }
75
- match(account) {
76
- const { type } = account.metadata.keyring;
77
- // We assume that `type` is really a `KeyringTypes`.
78
- const keyringType = type;
79
- // Check if a wallet already exists for that keyring type.
80
- let wallet = __classPrivateFieldGet(this, _KeyringWalletRule_wallets, "f").get(KeyringTypeWallet.toAccountWalletId(keyringType));
81
- if (!wallet) {
82
- wallet = new KeyringTypeWallet(this.messenger, keyringType);
83
- __classPrivateFieldGet(this, _KeyringWalletRule_wallets, "f").set(wallet.id, wallet);
84
- }
85
- // This will automatically creates the group if it's missing.
86
- const group = wallet.addAccount(account);
87
- return {
88
- wallet,
89
- group,
90
- };
91
- }
92
- }
93
- _KeyringWalletRule_wallets = new WeakMap();
94
- //# sourceMappingURL=KeyringWalletRule.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyringWalletRule.mjs","sourceRoot":"","sources":["../../src/rules/KeyringWalletRule.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EACL,qBAAqB,EACrB,iBAAiB,EAClB,8BAA8B;AAC/B,OAAO,EAAE,YAAY,EAAE,qCAAqC;AAI5D,OAAO,EAAE,cAAc,EAAE,yBAAqB;AAE9C,OAAO,EAAE,wBAAwB,EAAE,iCAA6B;AAEhE;;;;;GAKG;AACH,MAAM,UAAU,mCAAmC,CAAC,IAAkB;IACpE,QAAQ,IAAI,EAAE;QACZ,KAAK,YAAY,CAAC,MAAM,CAAC,CAAC;YACxB,OAAO,mBAAmB,CAAC;SAC5B;QACD,KAAK,YAAY,CAAC,MAAM,CAAC,CAAC;YACxB,OAAO,QAAQ,CAAC;SACjB;QACD,KAAK,YAAY,CAAC,MAAM,CAAC,CAAC;YACxB,OAAO,QAAQ,CAAC;SACjB;QACD,KAAK,YAAY,CAAC,MAAM,CAAC,CAAC;YACxB,OAAO,QAAQ,CAAC;SACjB;QACD,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC;YACzB,OAAO,SAAS,CAAC;SAClB;QACD,KAAK,YAAY,CAAC,EAAE,CAAC,CAAC;YACpB,OAAO,IAAI,CAAC;SACb;QACD,wEAAwE;QACxE,0CAA0C;QAC1C,KAAK,YAAY,CAAC,EAAE,CAAC,CAAC;YACpB,OAAO,WAAW,CAAC;SACpB;QACD,KAAK,YAAY,CAAC,IAAI,CAAC,CAAC;YACtB,OAAO,aAAa,CAAC;SACtB;QACD,2EAA2E;QAC3E,OAAO,CAAC,CAAC;YACP,OAAO,SAAS,CAAC;SAClB;KACF;AACH,CAAC;AAED,MAAM,iBAAkB,SAAQ,wBAAwB;IAGtD,YAAY,SAAyC,EAAE,IAAkB;QACvE,KAAK,CAAC,SAAS,EAAE,qBAAqB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,IAAkB;QACzC,OAAO,iBAAiB,CAAC,qBAAqB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAChE,CAAC;IAED,cAAc;QACZ,OAAO,mCAAmC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxD,CAAC;CACF;AAED,MAAM,OAAO,iBAAkB,SAAQ,cAAc;IAGnD,YAAY,SAAyC;QACnD,KAAK,CAAC,SAAS,CAAC,CAAC;QAHV,6CAAkD;QAKzD,uBAAA,IAAI,8BAAY,IAAI,GAAG,EAAE,MAAA,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,OAAwB;QAC5B,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC;QAC1C,oDAAoD;QACpD,MAAM,WAAW,GAAG,IAAoB,CAAC;QAEzC,0DAA0D;QAC1D,IAAI,MAAM,GAAG,uBAAA,IAAI,kCAAS,CAAC,GAAG,CAC5B,iBAAiB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CACjD,CAAC;QACF,IAAI,CAAC,MAAM,EAAE;YACX,MAAM,GAAG,IAAI,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;YAC5D,uBAAA,IAAI,kCAAS,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;SACtC;QAED,6DAA6D;QAC7D,MAAM,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEzC,OAAO;YACL,MAAM;YACN,KAAK;SACN,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { AccountWalletId } from '@metamask/account-api';\nimport {\n AccountWalletCategory,\n toAccountWalletId,\n} from '@metamask/account-api';\nimport { KeyringTypes } from '@metamask/keyring-controller';\nimport type { InternalAccount } from '@metamask/keyring-internal-api';\n\nimport type { WalletRuleMatch } from './WalletRule';\nimport { BaseWalletRule } from './WalletRule';\nimport type { AccountTreeControllerMessenger } from '../AccountTreeController';\nimport { MutableAccountTreeWallet } from '../AccountTreeWallet';\n\n/**\n * Get wallet name from a keyring type.\n *\n * @param type - Keyring's type.\n * @returns Wallet name.\n */\nexport function getAccountWalletNameFromKeyringType(type: KeyringTypes) {\n switch (type) {\n case KeyringTypes.simple: {\n return 'Imported accounts';\n }\n case KeyringTypes.trezor: {\n return 'Trezor';\n }\n case KeyringTypes.oneKey: {\n return 'OneKey';\n }\n case KeyringTypes.ledger: {\n return 'Ledger';\n }\n case KeyringTypes.lattice: {\n return 'Lattice';\n }\n case KeyringTypes.qr: {\n return 'QR';\n }\n // Those keyrings should never really be used in such context since they\n // should be used by other grouping rules.\n case KeyringTypes.hd: {\n return 'HD Wallet';\n }\n case KeyringTypes.snap: {\n return 'Snap Wallet';\n }\n // ------------------------------------------------------------------------\n default: {\n return 'Unknown';\n }\n }\n}\n\nclass KeyringTypeWallet extends MutableAccountTreeWallet {\n readonly type: KeyringTypes;\n\n constructor(messenger: AccountTreeControllerMessenger, type: KeyringTypes) {\n super(messenger, AccountWalletCategory.Keyring, type);\n this.type = type;\n }\n\n static toAccountWalletId(type: KeyringTypes) {\n return toAccountWalletId(AccountWalletCategory.Keyring, type);\n }\n\n getDefaultName(): string {\n return getAccountWalletNameFromKeyringType(this.type);\n }\n}\n\nexport class KeyringWalletRule extends BaseWalletRule {\n readonly #wallets: Map<AccountWalletId, KeyringTypeWallet>;\n\n constructor(messenger: AccountTreeControllerMessenger) {\n super(messenger);\n\n this.#wallets = new Map();\n }\n\n match(account: InternalAccount): WalletRuleMatch | undefined {\n const { type } = account.metadata.keyring;\n // We assume that `type` is really a `KeyringTypes`.\n const keyringType = type as KeyringTypes;\n\n // Check if a wallet already exists for that keyring type.\n let wallet = this.#wallets.get(\n KeyringTypeWallet.toAccountWalletId(keyringType),\n );\n if (!wallet) {\n wallet = new KeyringTypeWallet(this.messenger, keyringType);\n this.#wallets.set(wallet.id, wallet);\n }\n\n // This will automatically creates the group if it's missing.\n const group = wallet.addAccount(account);\n\n return {\n wallet,\n group,\n };\n }\n}\n"]}
@@ -1,70 +0,0 @@
1
- "use strict";
2
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
- if (kind === "m") throw new TypeError("Private method is not writable");
4
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
- };
8
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
- 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");
11
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
- };
13
- var _SnapWalletRule_wallets;
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.SnapWalletRule = void 0;
16
- const account_api_1 = require("@metamask/account-api");
17
- const keyring_controller_1 = require("@metamask/keyring-controller");
18
- const snaps_utils_1 = require("@metamask/snaps-utils");
19
- const utils_1 = require("./utils.cjs");
20
- const WalletRule_1 = require("./WalletRule.cjs");
21
- const AccountTreeWallet_1 = require("../AccountTreeWallet.cjs");
22
- class SnapWallet extends AccountTreeWallet_1.MutableAccountTreeWallet {
23
- constructor(messenger, snapId) {
24
- super(messenger, account_api_1.AccountWalletCategory.Snap, snapId);
25
- this.snapId = snapId;
26
- }
27
- static toAccountWalletId(snapId) {
28
- return (0, account_api_1.toAccountWalletId)(account_api_1.AccountWalletCategory.Snap, snapId);
29
- }
30
- getDefaultName() {
31
- const snap = this.messenger.call('SnapController:get', this.snapId);
32
- const snapName = snap
33
- ? // TODO: Handle localization here, but that's a "client thing", so we don't have a `core` controller
34
- // to refer to.
35
- snap.manifest.proposedName
36
- : (0, snaps_utils_1.stripSnapPrefix)(this.snapId);
37
- return snapName;
38
- }
39
- }
40
- class SnapWalletRule extends WalletRule_1.BaseWalletRule {
41
- constructor(messenger) {
42
- super(messenger);
43
- _SnapWalletRule_wallets.set(this, void 0);
44
- __classPrivateFieldSet(this, _SnapWalletRule_wallets, new Map(), "f");
45
- }
46
- match(account) {
47
- if ((0, utils_1.hasKeyringType)(account, keyring_controller_1.KeyringTypes.snap) &&
48
- account.metadata.snap &&
49
- account.metadata.snap.enabled) {
50
- const { id } = account.metadata.snap;
51
- const snapId = id;
52
- // Check if a wallet already exists for that Snap ID.
53
- let wallet = __classPrivateFieldGet(this, _SnapWalletRule_wallets, "f").get(SnapWallet.toAccountWalletId(snapId));
54
- if (!wallet) {
55
- wallet = new SnapWallet(this.messenger, snapId);
56
- __classPrivateFieldGet(this, _SnapWalletRule_wallets, "f").set(wallet.id, wallet);
57
- }
58
- // This will automatically creates the group if it's missing.
59
- const group = wallet.addAccount(account);
60
- return {
61
- wallet,
62
- group,
63
- };
64
- }
65
- return undefined;
66
- }
67
- }
68
- exports.SnapWalletRule = SnapWalletRule;
69
- _SnapWalletRule_wallets = new WeakMap();
70
- //# sourceMappingURL=SnapWalletRule.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SnapWalletRule.cjs","sourceRoot":"","sources":["../../src/rules/SnapWalletRule.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,uDAG+B;AAC/B,qEAA4D;AAG5D,uDAAwD;AAExD,uCAAyC;AAEzC,iDAA8C;AAE9C,gEAAgE;AAEhE,MAAM,UAAW,SAAQ,4CAAwB;IAG/C,YAAY,SAAyC,EAAE,MAAc;QACnE,KAAK,CAAC,SAAS,EAAE,mCAAqB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,MAAc;QACrC,OAAO,IAAA,+BAAiB,EAAC,mCAAqB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC/D,CAAC;IAED,cAAc;QACZ,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACpE,MAAM,QAAQ,GAAG,IAAI;YACnB,CAAC,CAAC,oGAAoG;gBACpG,eAAe;gBACf,IAAI,CAAC,QAAQ,CAAC,YAAY;YAC5B,CAAC,CAAC,IAAA,6BAAe,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEjC,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AAED,MAAa,cAAe,SAAQ,2BAAc;IAGhD,YAAY,SAAyC;QACnD,KAAK,CAAC,SAAS,CAAC,CAAC;QAHV,0CAA2C;QAKlD,uBAAA,IAAI,2BAAY,IAAI,GAAG,EAAE,MAAA,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,OAAwB;QAC5B,IACE,IAAA,sBAAc,EAAC,OAAO,EAAE,iCAAY,CAAC,IAAI,CAAC;YAC1C,OAAO,CAAC,QAAQ,CAAC,IAAI;YACrB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAC7B;YACA,MAAM,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;YACrC,MAAM,MAAM,GAAG,EAAY,CAAC;YAE5B,qDAAqD;YACrD,IAAI,MAAM,GAAG,uBAAA,IAAI,+BAAS,CAAC,GAAG,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC;YACrE,IAAI,CAAC,MAAM,EAAE;gBACX,MAAM,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;gBAChD,uBAAA,IAAI,+BAAS,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;aACtC;YAED,6DAA6D;YAC7D,MAAM,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAEzC,OAAO;gBACL,MAAM;gBACN,KAAK;aACN,CAAC;SACH;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AApCD,wCAoCC","sourcesContent":["import type { AccountWalletId } from '@metamask/account-api';\nimport {\n AccountWalletCategory,\n toAccountWalletId,\n} from '@metamask/account-api';\nimport { KeyringTypes } from '@metamask/keyring-controller';\nimport type { InternalAccount } from '@metamask/keyring-internal-api';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport { stripSnapPrefix } from '@metamask/snaps-utils';\n\nimport { hasKeyringType } from './utils';\nimport type { WalletRuleMatch } from './WalletRule';\nimport { BaseWalletRule } from './WalletRule';\nimport type { AccountTreeControllerMessenger } from '../AccountTreeController';\nimport { MutableAccountTreeWallet } from '../AccountTreeWallet';\n\nclass SnapWallet extends MutableAccountTreeWallet {\n readonly snapId: SnapId;\n\n constructor(messenger: AccountTreeControllerMessenger, snapId: SnapId) {\n super(messenger, AccountWalletCategory.Snap, snapId);\n this.snapId = snapId;\n }\n\n static toAccountWalletId(snapId: SnapId) {\n return toAccountWalletId(AccountWalletCategory.Snap, snapId);\n }\n\n getDefaultName(): string {\n const snap = this.messenger.call('SnapController:get', this.snapId);\n const snapName = snap\n ? // TODO: Handle localization here, but that's a \"client thing\", so we don't have a `core` controller\n // to refer to.\n snap.manifest.proposedName\n : stripSnapPrefix(this.snapId);\n\n return snapName;\n }\n}\n\nexport class SnapWalletRule extends BaseWalletRule {\n readonly #wallets: Map<AccountWalletId, SnapWallet>;\n\n constructor(messenger: AccountTreeControllerMessenger) {\n super(messenger);\n\n this.#wallets = new Map();\n }\n\n match(account: InternalAccount): WalletRuleMatch | undefined {\n if (\n hasKeyringType(account, KeyringTypes.snap) &&\n account.metadata.snap &&\n account.metadata.snap.enabled\n ) {\n const { id } = account.metadata.snap;\n const snapId = id as SnapId;\n\n // Check if a wallet already exists for that Snap ID.\n let wallet = this.#wallets.get(SnapWallet.toAccountWalletId(snapId));\n if (!wallet) {\n wallet = new SnapWallet(this.messenger, snapId);\n this.#wallets.set(wallet.id, wallet);\n }\n\n // This will automatically creates the group if it's missing.\n const group = wallet.addAccount(account);\n\n return {\n wallet,\n group,\n };\n }\n\n return undefined;\n }\n}\n"]}
@@ -1,10 +0,0 @@
1
- import type { InternalAccount } from "@metamask/keyring-internal-api";
2
- import type { WalletRuleMatch } from "./WalletRule.cjs";
3
- import { BaseWalletRule } from "./WalletRule.cjs";
4
- import type { AccountTreeControllerMessenger } from "../AccountTreeController.cjs";
5
- export declare class SnapWalletRule extends BaseWalletRule {
6
- #private;
7
- constructor(messenger: AccountTreeControllerMessenger);
8
- match(account: InternalAccount): WalletRuleMatch | undefined;
9
- }
10
- //# sourceMappingURL=SnapWalletRule.d.cts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SnapWalletRule.d.cts","sourceRoot":"","sources":["../../src/rules/SnapWalletRule.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,eAAe,EAAE,uCAAuC;AAKtE,OAAO,KAAK,EAAE,eAAe,EAAE,yBAAqB;AACpD,OAAO,EAAE,cAAc,EAAE,yBAAqB;AAC9C,OAAO,KAAK,EAAE,8BAA8B,EAAE,qCAAiC;AA2B/E,qBAAa,cAAe,SAAQ,cAAc;;gBAGpC,SAAS,EAAE,8BAA8B;IAMrD,KAAK,CAAC,OAAO,EAAE,eAAe,GAAG,eAAe,GAAG,SAAS;CA2B7D"}
@@ -1,10 +0,0 @@
1
- import type { InternalAccount } from "@metamask/keyring-internal-api";
2
- import type { WalletRuleMatch } from "./WalletRule.mjs";
3
- import { BaseWalletRule } from "./WalletRule.mjs";
4
- import type { AccountTreeControllerMessenger } from "../AccountTreeController.mjs";
5
- export declare class SnapWalletRule extends BaseWalletRule {
6
- #private;
7
- constructor(messenger: AccountTreeControllerMessenger);
8
- match(account: InternalAccount): WalletRuleMatch | undefined;
9
- }
10
- //# sourceMappingURL=SnapWalletRule.d.mts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SnapWalletRule.d.mts","sourceRoot":"","sources":["../../src/rules/SnapWalletRule.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,eAAe,EAAE,uCAAuC;AAKtE,OAAO,KAAK,EAAE,eAAe,EAAE,yBAAqB;AACpD,OAAO,EAAE,cAAc,EAAE,yBAAqB;AAC9C,OAAO,KAAK,EAAE,8BAA8B,EAAE,qCAAiC;AA2B/E,qBAAa,cAAe,SAAQ,cAAc;;gBAGpC,SAAS,EAAE,8BAA8B;IAMrD,KAAK,CAAC,OAAO,EAAE,eAAe,GAAG,eAAe,GAAG,SAAS;CA2B7D"}
@@ -1,66 +0,0 @@
1
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
2
- if (kind === "m") throw new TypeError("Private method is not writable");
3
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
4
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
5
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
6
- };
7
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
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
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
- };
12
- var _SnapWalletRule_wallets;
13
- import { AccountWalletCategory, toAccountWalletId } from "@metamask/account-api";
14
- import { KeyringTypes } from "@metamask/keyring-controller";
15
- import { stripSnapPrefix } from "@metamask/snaps-utils";
16
- import { hasKeyringType } from "./utils.mjs";
17
- import { BaseWalletRule } from "./WalletRule.mjs";
18
- import { MutableAccountTreeWallet } from "../AccountTreeWallet.mjs";
19
- class SnapWallet extends MutableAccountTreeWallet {
20
- constructor(messenger, snapId) {
21
- super(messenger, AccountWalletCategory.Snap, snapId);
22
- this.snapId = snapId;
23
- }
24
- static toAccountWalletId(snapId) {
25
- return toAccountWalletId(AccountWalletCategory.Snap, snapId);
26
- }
27
- getDefaultName() {
28
- const snap = this.messenger.call('SnapController:get', this.snapId);
29
- const snapName = snap
30
- ? // TODO: Handle localization here, but that's a "client thing", so we don't have a `core` controller
31
- // to refer to.
32
- snap.manifest.proposedName
33
- : stripSnapPrefix(this.snapId);
34
- return snapName;
35
- }
36
- }
37
- export class SnapWalletRule extends BaseWalletRule {
38
- constructor(messenger) {
39
- super(messenger);
40
- _SnapWalletRule_wallets.set(this, void 0);
41
- __classPrivateFieldSet(this, _SnapWalletRule_wallets, new Map(), "f");
42
- }
43
- match(account) {
44
- if (hasKeyringType(account, KeyringTypes.snap) &&
45
- account.metadata.snap &&
46
- account.metadata.snap.enabled) {
47
- const { id } = account.metadata.snap;
48
- const snapId = id;
49
- // Check if a wallet already exists for that Snap ID.
50
- let wallet = __classPrivateFieldGet(this, _SnapWalletRule_wallets, "f").get(SnapWallet.toAccountWalletId(snapId));
51
- if (!wallet) {
52
- wallet = new SnapWallet(this.messenger, snapId);
53
- __classPrivateFieldGet(this, _SnapWalletRule_wallets, "f").set(wallet.id, wallet);
54
- }
55
- // This will automatically creates the group if it's missing.
56
- const group = wallet.addAccount(account);
57
- return {
58
- wallet,
59
- group,
60
- };
61
- }
62
- return undefined;
63
- }
64
- }
65
- _SnapWalletRule_wallets = new WeakMap();
66
- //# sourceMappingURL=SnapWalletRule.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SnapWalletRule.mjs","sourceRoot":"","sources":["../../src/rules/SnapWalletRule.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EACL,qBAAqB,EACrB,iBAAiB,EAClB,8BAA8B;AAC/B,OAAO,EAAE,YAAY,EAAE,qCAAqC;AAG5D,OAAO,EAAE,eAAe,EAAE,8BAA8B;AAExD,OAAO,EAAE,cAAc,EAAE,oBAAgB;AAEzC,OAAO,EAAE,cAAc,EAAE,yBAAqB;AAE9C,OAAO,EAAE,wBAAwB,EAAE,iCAA6B;AAEhE,MAAM,UAAW,SAAQ,wBAAwB;IAG/C,YAAY,SAAyC,EAAE,MAAc;QACnE,KAAK,CAAC,SAAS,EAAE,qBAAqB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,MAAc;QACrC,OAAO,iBAAiB,CAAC,qBAAqB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC/D,CAAC;IAED,cAAc;QACZ,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACpE,MAAM,QAAQ,GAAG,IAAI;YACnB,CAAC,CAAC,oGAAoG;gBACpG,eAAe;gBACf,IAAI,CAAC,QAAQ,CAAC,YAAY;YAC5B,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEjC,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AAED,MAAM,OAAO,cAAe,SAAQ,cAAc;IAGhD,YAAY,SAAyC;QACnD,KAAK,CAAC,SAAS,CAAC,CAAC;QAHV,0CAA2C;QAKlD,uBAAA,IAAI,2BAAY,IAAI,GAAG,EAAE,MAAA,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,OAAwB;QAC5B,IACE,cAAc,CAAC,OAAO,EAAE,YAAY,CAAC,IAAI,CAAC;YAC1C,OAAO,CAAC,QAAQ,CAAC,IAAI;YACrB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAC7B;YACA,MAAM,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;YACrC,MAAM,MAAM,GAAG,EAAY,CAAC;YAE5B,qDAAqD;YACrD,IAAI,MAAM,GAAG,uBAAA,IAAI,+BAAS,CAAC,GAAG,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC;YACrE,IAAI,CAAC,MAAM,EAAE;gBACX,MAAM,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;gBAChD,uBAAA,IAAI,+BAAS,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;aACtC;YAED,6DAA6D;YAC7D,MAAM,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAEzC,OAAO;gBACL,MAAM;gBACN,KAAK;aACN,CAAC;SACH;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;CACF","sourcesContent":["import type { AccountWalletId } from '@metamask/account-api';\nimport {\n AccountWalletCategory,\n toAccountWalletId,\n} from '@metamask/account-api';\nimport { KeyringTypes } from '@metamask/keyring-controller';\nimport type { InternalAccount } from '@metamask/keyring-internal-api';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport { stripSnapPrefix } from '@metamask/snaps-utils';\n\nimport { hasKeyringType } from './utils';\nimport type { WalletRuleMatch } from './WalletRule';\nimport { BaseWalletRule } from './WalletRule';\nimport type { AccountTreeControllerMessenger } from '../AccountTreeController';\nimport { MutableAccountTreeWallet } from '../AccountTreeWallet';\n\nclass SnapWallet extends MutableAccountTreeWallet {\n readonly snapId: SnapId;\n\n constructor(messenger: AccountTreeControllerMessenger, snapId: SnapId) {\n super(messenger, AccountWalletCategory.Snap, snapId);\n this.snapId = snapId;\n }\n\n static toAccountWalletId(snapId: SnapId) {\n return toAccountWalletId(AccountWalletCategory.Snap, snapId);\n }\n\n getDefaultName(): string {\n const snap = this.messenger.call('SnapController:get', this.snapId);\n const snapName = snap\n ? // TODO: Handle localization here, but that's a \"client thing\", so we don't have a `core` controller\n // to refer to.\n snap.manifest.proposedName\n : stripSnapPrefix(this.snapId);\n\n return snapName;\n }\n}\n\nexport class SnapWalletRule extends BaseWalletRule {\n readonly #wallets: Map<AccountWalletId, SnapWallet>;\n\n constructor(messenger: AccountTreeControllerMessenger) {\n super(messenger);\n\n this.#wallets = new Map();\n }\n\n match(account: InternalAccount): WalletRuleMatch | undefined {\n if (\n hasKeyringType(account, KeyringTypes.snap) &&\n account.metadata.snap &&\n account.metadata.snap.enabled\n ) {\n const { id } = account.metadata.snap;\n const snapId = id as SnapId;\n\n // Check if a wallet already exists for that Snap ID.\n let wallet = this.#wallets.get(SnapWallet.toAccountWalletId(snapId));\n if (!wallet) {\n wallet = new SnapWallet(this.messenger, snapId);\n this.#wallets.set(wallet.id, wallet);\n }\n\n // This will automatically creates the group if it's missing.\n const group = wallet.addAccount(account);\n\n return {\n wallet,\n group,\n };\n }\n\n return undefined;\n }\n}\n"]}
@@ -1,13 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BaseWalletRule = void 0;
4
- /**
5
- * Abstract base class for {@link WalletRule}.
6
- */
7
- class BaseWalletRule {
8
- constructor(messenger) {
9
- this.messenger = messenger;
10
- }
11
- }
12
- exports.BaseWalletRule = BaseWalletRule;
13
- //# sourceMappingURL=WalletRule.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"WalletRule.cjs","sourceRoot":"","sources":["../../src/rules/WalletRule.ts"],"names":[],"mappings":";;;AAgCA;;GAEG;AACH,MAAsB,cAAc;IAGlC,YAAY,SAAyC;QACnD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;CAGF;AARD,wCAQC","sourcesContent":["import type { InternalAccount } from '@metamask/keyring-internal-api';\nimport type { AccountTreeControllerMessenger } from 'src/AccountTreeController';\n\nimport type { AccountTreeGroup } from '../AccountTreeGroup';\nimport type { AccountTreeWallet } from '../AccountTreeWallet';\n\nexport type WalletRuleMatch = {\n wallet: AccountTreeWallet;\n group: AccountTreeGroup;\n};\n\n/**\n * A rule that can be used to group account in their proper account wallet/group.\n */\nexport type WalletRule = {\n /**\n * Apply the rule and check if the account matches.\n *\n * If the account matches, then the rule will return a {@link WalletRuleMatch} which means\n * this account needs to be grouped within a wallet associated with this rule.\n *\n * If a wallet already exists for this account (based on {@link WalletRuleMatch}) then\n * the account will be added to that wallet instance into its proper group (different for\n * every wallets).\n *\n * @param account - The account to match.\n * @returns A {@link WalletRuleMatch} if this account is part of that rule/wallet, returns\n * `undefined` otherwise.\n */\n match(account: InternalAccount): WalletRuleMatch | undefined;\n};\n\n/**\n * Abstract base class for {@link WalletRule}.\n */\nexport abstract class BaseWalletRule implements WalletRule {\n protected readonly messenger: AccountTreeControllerMessenger;\n\n constructor(messenger: AccountTreeControllerMessenger) {\n this.messenger = messenger;\n }\n\n abstract match(account: InternalAccount): WalletRuleMatch | undefined;\n}\n"]}