@metamask/gator-permissions-controller 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +17 -0
- package/LICENSE +20 -0
- package/README.md +38 -0
- package/dist/GatorPermissionsController.cjs +240 -0
- package/dist/GatorPermissionsController.cjs.map +1 -0
- package/dist/GatorPermissionsController.d.cts +139 -0
- package/dist/GatorPermissionsController.d.cts.map +1 -0
- package/dist/GatorPermissionsController.d.mts +139 -0
- package/dist/GatorPermissionsController.d.mts.map +1 -0
- package/dist/GatorPermissionsController.mjs +236 -0
- package/dist/GatorPermissionsController.mjs.map +1 -0
- package/dist/errors.cjs +54 -0
- package/dist/errors.cjs.map +1 -0
- package/dist/errors.d.cts +40 -0
- package/dist/errors.d.cts.map +1 -0
- package/dist/errors.d.mts +40 -0
- package/dist/errors.d.mts.map +1 -0
- package/dist/errors.mjs +46 -0
- package/dist/errors.mjs.map +1 -0
- package/dist/index.cjs +12 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +6 -0
- package/dist/index.d.cts.map +1 -0
- package/dist/index.d.mts +6 -0
- package/dist/index.d.mts.map +1 -0
- package/dist/index.mjs +3 -0
- package/dist/index.mjs.map +1 -0
- package/dist/logger.cjs +10 -0
- package/dist/logger.cjs.map +1 -0
- package/dist/logger.d.cts +7 -0
- package/dist/logger.d.cts.map +1 -0
- package/dist/logger.d.mts +7 -0
- package/dist/logger.d.mts.map +1 -0
- package/dist/logger.mjs +7 -0
- package/dist/logger.mjs.map +1 -0
- package/dist/test/mocks.cjs +209 -0
- package/dist/test/mocks.cjs.map +1 -0
- package/dist/test/mocks.d.cts +34 -0
- package/dist/test/mocks.d.cts.map +1 -0
- package/dist/test/mocks.d.mts +34 -0
- package/dist/test/mocks.d.mts.map +1 -0
- package/dist/test/mocks.mjs +200 -0
- package/dist/test/mocks.mjs.map +1 -0
- package/dist/types.cjs +24 -0
- package/dist/types.cjs.map +1 -0
- package/dist/types.d.cts +149 -0
- package/dist/types.d.cts.map +1 -0
- package/dist/types.d.mts +149 -0
- package/dist/types.d.mts.map +1 -0
- package/dist/types.mjs +21 -0
- package/dist/types.mjs.map +1 -0
- package/dist/utils.cjs +46 -0
- package/dist/utils.cjs.map +1 -0
- package/dist/utils.d.cts +16 -0
- package/dist/utils.d.cts.map +1 -0
- package/dist/utils.d.mts +16 -0
- package/dist/utils.d.mts.map +1 -0
- package/dist/utils.mjs +41 -0
- package/dist/utils.mjs.map +1 -0
- package/package.json +85 -0
|
@@ -0,0 +1,209 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.mockGatorPermissionsStorageEntriesFactory = exports.mockCustomPermissionStorageEntry = exports.mockErc20TokenPeriodicStorageEntry = exports.mockErc20TokenStreamStorageEntry = exports.mockNativeTokenPeriodicStorageEntry = exports.mockNativeTokenStreamStorageEntry = void 0;
|
|
4
|
+
const mockNativeTokenStreamStorageEntry = (chainId) => ({
|
|
5
|
+
permissionResponse: {
|
|
6
|
+
chainId: chainId,
|
|
7
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
8
|
+
signer: {
|
|
9
|
+
type: 'account',
|
|
10
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
11
|
+
},
|
|
12
|
+
permission: {
|
|
13
|
+
type: 'native-token-stream',
|
|
14
|
+
isAdjustmentAllowed: true,
|
|
15
|
+
data: {
|
|
16
|
+
maxAmount: '0x22b1c8c1227a0000',
|
|
17
|
+
initialAmount: '0x6f05b59d3b20000',
|
|
18
|
+
amountPerSecond: '0x6f05b59d3b20000',
|
|
19
|
+
startTime: 1747699200,
|
|
20
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
context: '0x00000000',
|
|
24
|
+
dependencyInfo: [
|
|
25
|
+
{
|
|
26
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
27
|
+
factoryData: '0x0000000',
|
|
28
|
+
},
|
|
29
|
+
],
|
|
30
|
+
signerMeta: {
|
|
31
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
siteOrigin: 'http://localhost:8000',
|
|
35
|
+
});
|
|
36
|
+
exports.mockNativeTokenStreamStorageEntry = mockNativeTokenStreamStorageEntry;
|
|
37
|
+
const mockNativeTokenPeriodicStorageEntry = (chainId) => ({
|
|
38
|
+
permissionResponse: {
|
|
39
|
+
chainId: chainId,
|
|
40
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
41
|
+
signer: {
|
|
42
|
+
type: 'account',
|
|
43
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
44
|
+
},
|
|
45
|
+
permission: {
|
|
46
|
+
type: 'native-token-periodic',
|
|
47
|
+
isAdjustmentAllowed: true,
|
|
48
|
+
data: {
|
|
49
|
+
periodAmount: '0x22b1c8c1227a0000',
|
|
50
|
+
periodDuration: 1747699200,
|
|
51
|
+
startTime: 1747699200,
|
|
52
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
context: '0x00000000',
|
|
56
|
+
dependencyInfo: [
|
|
57
|
+
{
|
|
58
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
59
|
+
factoryData: '0x0000000',
|
|
60
|
+
},
|
|
61
|
+
],
|
|
62
|
+
signerMeta: {
|
|
63
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
siteOrigin: 'http://localhost:8000',
|
|
67
|
+
});
|
|
68
|
+
exports.mockNativeTokenPeriodicStorageEntry = mockNativeTokenPeriodicStorageEntry;
|
|
69
|
+
const mockErc20TokenStreamStorageEntry = (chainId) => ({
|
|
70
|
+
permissionResponse: {
|
|
71
|
+
chainId: chainId,
|
|
72
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
73
|
+
signer: {
|
|
74
|
+
type: 'account',
|
|
75
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
76
|
+
},
|
|
77
|
+
permission: {
|
|
78
|
+
type: 'erc20-token-stream',
|
|
79
|
+
isAdjustmentAllowed: true,
|
|
80
|
+
data: {
|
|
81
|
+
initialAmount: '0x22b1c8c1227a0000',
|
|
82
|
+
maxAmount: '0x6f05b59d3b20000',
|
|
83
|
+
amountPerSecond: '0x6f05b59d3b20000',
|
|
84
|
+
startTime: 1747699200,
|
|
85
|
+
tokenAddress: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
86
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
context: '0x00000000',
|
|
90
|
+
dependencyInfo: [
|
|
91
|
+
{
|
|
92
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
93
|
+
factoryData: '0x0000000',
|
|
94
|
+
},
|
|
95
|
+
],
|
|
96
|
+
signerMeta: {
|
|
97
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
98
|
+
},
|
|
99
|
+
},
|
|
100
|
+
siteOrigin: 'http://localhost:8000',
|
|
101
|
+
});
|
|
102
|
+
exports.mockErc20TokenStreamStorageEntry = mockErc20TokenStreamStorageEntry;
|
|
103
|
+
const mockErc20TokenPeriodicStorageEntry = (chainId) => ({
|
|
104
|
+
permissionResponse: {
|
|
105
|
+
chainId: chainId,
|
|
106
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
107
|
+
signer: {
|
|
108
|
+
type: 'account',
|
|
109
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
110
|
+
},
|
|
111
|
+
permission: {
|
|
112
|
+
type: 'erc20-token-periodic',
|
|
113
|
+
isAdjustmentAllowed: true,
|
|
114
|
+
data: {
|
|
115
|
+
periodAmount: '0x22b1c8c1227a0000',
|
|
116
|
+
periodDuration: 1747699200,
|
|
117
|
+
startTime: 1747699200,
|
|
118
|
+
tokenAddress: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
119
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
120
|
+
},
|
|
121
|
+
},
|
|
122
|
+
context: '0x00000000',
|
|
123
|
+
dependencyInfo: [
|
|
124
|
+
{
|
|
125
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
126
|
+
factoryData: '0x0000000',
|
|
127
|
+
},
|
|
128
|
+
],
|
|
129
|
+
signerMeta: {
|
|
130
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
131
|
+
},
|
|
132
|
+
},
|
|
133
|
+
siteOrigin: 'http://localhost:8000',
|
|
134
|
+
});
|
|
135
|
+
exports.mockErc20TokenPeriodicStorageEntry = mockErc20TokenPeriodicStorageEntry;
|
|
136
|
+
const mockCustomPermissionStorageEntry = (chainId, data) => ({
|
|
137
|
+
permissionResponse: {
|
|
138
|
+
chainId: chainId,
|
|
139
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
140
|
+
signer: {
|
|
141
|
+
type: 'account',
|
|
142
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
143
|
+
},
|
|
144
|
+
permission: {
|
|
145
|
+
type: 'custom',
|
|
146
|
+
isAdjustmentAllowed: true,
|
|
147
|
+
data: {
|
|
148
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
149
|
+
...data,
|
|
150
|
+
},
|
|
151
|
+
},
|
|
152
|
+
context: '0x00000000',
|
|
153
|
+
dependencyInfo: [
|
|
154
|
+
{
|
|
155
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
156
|
+
factoryData: '0x0000000',
|
|
157
|
+
},
|
|
158
|
+
],
|
|
159
|
+
signerMeta: {
|
|
160
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
161
|
+
},
|
|
162
|
+
},
|
|
163
|
+
siteOrigin: 'http://localhost:8000',
|
|
164
|
+
});
|
|
165
|
+
exports.mockCustomPermissionStorageEntry = mockCustomPermissionStorageEntry;
|
|
166
|
+
/**
|
|
167
|
+
* Creates a mock gator permissions storage entry
|
|
168
|
+
*
|
|
169
|
+
* @param config - The config for the mock gator permissions storage entries.
|
|
170
|
+
* @returns Mock gator permissions storage entry
|
|
171
|
+
*/
|
|
172
|
+
/**
|
|
173
|
+
* Creates mock gator permissions storage entries with unique expiry times
|
|
174
|
+
*
|
|
175
|
+
* @param config - The config for the mock gator permissions storage entries.
|
|
176
|
+
* @returns Mock gator permissions storage entries
|
|
177
|
+
*/
|
|
178
|
+
function mockGatorPermissionsStorageEntriesFactory(config) {
|
|
179
|
+
const result = [];
|
|
180
|
+
Object.entries(config).forEach(([chainId, counts]) => {
|
|
181
|
+
if (counts.custom.count !== counts.custom.data.length) {
|
|
182
|
+
throw new Error('Custom permission count and data length mismatch');
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* Creates a number of entries with unique expiry times
|
|
186
|
+
*
|
|
187
|
+
* @param count - The number of entries to create.
|
|
188
|
+
* @param createEntry - The function to create an entry.
|
|
189
|
+
*/
|
|
190
|
+
const createEntries = (count, createEntry) => {
|
|
191
|
+
for (let i = 0; i < count; i++) {
|
|
192
|
+
const entry = createEntry();
|
|
193
|
+
result.push(entry);
|
|
194
|
+
}
|
|
195
|
+
};
|
|
196
|
+
createEntries(counts.nativeTokenStream, () => (0, exports.mockNativeTokenStreamStorageEntry)(chainId));
|
|
197
|
+
createEntries(counts.nativeTokenPeriodic, () => (0, exports.mockNativeTokenPeriodicStorageEntry)(chainId));
|
|
198
|
+
createEntries(counts.erc20TokenStream, () => (0, exports.mockErc20TokenStreamStorageEntry)(chainId));
|
|
199
|
+
createEntries(counts.erc20TokenPeriodic, () => (0, exports.mockErc20TokenPeriodicStorageEntry)(chainId));
|
|
200
|
+
// Create custom entries
|
|
201
|
+
for (let i = 0; i < counts.custom.count; i++) {
|
|
202
|
+
const entry = (0, exports.mockCustomPermissionStorageEntry)(chainId, counts.custom.data[i]);
|
|
203
|
+
result.push(entry);
|
|
204
|
+
}
|
|
205
|
+
});
|
|
206
|
+
return result;
|
|
207
|
+
}
|
|
208
|
+
exports.mockGatorPermissionsStorageEntriesFactory = mockGatorPermissionsStorageEntriesFactory;
|
|
209
|
+
//# sourceMappingURL=mocks.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mocks.cjs","sourceRoot":"","sources":["../../src/test/mocks.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n AccountSigner,\n Erc20TokenPeriodicPermission,\n Erc20TokenStreamPermission,\n NativeTokenPeriodicPermission,\n NativeTokenStreamPermission,\n} from '@metamask/7715-permission-types';\nimport type { Hex } from '@metamask/utils';\n\nimport type {\n CustomPermission,\n PermissionTypesWithCustom,\n StoredGatorPermission,\n} from '../types';\n\nexport const mockNativeTokenStreamStorageEntry = (\n chainId: Hex,\n): StoredGatorPermission<AccountSigner, NativeTokenStreamPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'native-token-stream',\n isAdjustmentAllowed: true,\n data: {\n maxAmount: '0x22b1c8c1227a0000',\n initialAmount: '0x6f05b59d3b20000',\n amountPerSecond: '0x6f05b59d3b20000',\n startTime: 1747699200,\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport const mockNativeTokenPeriodicStorageEntry = (\n chainId: Hex,\n): StoredGatorPermission<AccountSigner, NativeTokenPeriodicPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'native-token-periodic',\n isAdjustmentAllowed: true,\n data: {\n periodAmount: '0x22b1c8c1227a0000',\n periodDuration: 1747699200,\n startTime: 1747699200,\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport const mockErc20TokenStreamStorageEntry = (\n chainId: Hex,\n): StoredGatorPermission<AccountSigner, Erc20TokenStreamPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'erc20-token-stream',\n isAdjustmentAllowed: true,\n data: {\n initialAmount: '0x22b1c8c1227a0000',\n maxAmount: '0x6f05b59d3b20000',\n amountPerSecond: '0x6f05b59d3b20000',\n startTime: 1747699200,\n tokenAddress: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport const mockErc20TokenPeriodicStorageEntry = (\n chainId: Hex,\n): StoredGatorPermission<AccountSigner, Erc20TokenPeriodicPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'erc20-token-periodic',\n isAdjustmentAllowed: true,\n data: {\n periodAmount: '0x22b1c8c1227a0000',\n periodDuration: 1747699200,\n startTime: 1747699200,\n tokenAddress: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport const mockCustomPermissionStorageEntry = (\n chainId: Hex,\n data: Record<string, unknown>,\n): StoredGatorPermission<AccountSigner, CustomPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'custom',\n isAdjustmentAllowed: true,\n data: {\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n ...data,\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport type MockGatorPermissionsStorageEntriesConfig = {\n [chainId: string]: {\n nativeTokenStream: number;\n nativeTokenPeriodic: number;\n erc20TokenStream: number;\n erc20TokenPeriodic: number;\n custom: {\n count: number;\n data: Record<string, unknown>[];\n };\n };\n};\n\n/**\n * Creates a mock gator permissions storage entry\n *\n * @param config - The config for the mock gator permissions storage entries.\n * @returns Mock gator permissions storage entry\n */\n/**\n * Creates mock gator permissions storage entries with unique expiry times\n *\n * @param config - The config for the mock gator permissions storage entries.\n * @returns Mock gator permissions storage entries\n */\nexport function mockGatorPermissionsStorageEntriesFactory(\n config: MockGatorPermissionsStorageEntriesConfig,\n): StoredGatorPermission<AccountSigner, PermissionTypesWithCustom>[] {\n const result: StoredGatorPermission<\n AccountSigner,\n PermissionTypesWithCustom\n >[] = [];\n\n Object.entries(config).forEach(([chainId, counts]) => {\n if (counts.custom.count !== counts.custom.data.length) {\n throw new Error('Custom permission count and data length mismatch');\n }\n\n /**\n * Creates a number of entries with unique expiry times\n *\n * @param count - The number of entries to create.\n * @param createEntry - The function to create an entry.\n */\n const createEntries = (\n count: number,\n createEntry: () => StoredGatorPermission<\n AccountSigner,\n PermissionTypesWithCustom\n >,\n ) => {\n for (let i = 0; i < count; i++) {\n const entry = createEntry();\n result.push(entry);\n }\n };\n\n createEntries(counts.nativeTokenStream, () =>\n mockNativeTokenStreamStorageEntry(chainId as Hex),\n );\n\n createEntries(counts.nativeTokenPeriodic, () =>\n mockNativeTokenPeriodicStorageEntry(chainId as Hex),\n );\n\n createEntries(counts.erc20TokenStream, () =>\n mockErc20TokenStreamStorageEntry(chainId as Hex),\n );\n\n createEntries(counts.erc20TokenPeriodic, () =>\n mockErc20TokenPeriodicStorageEntry(chainId as Hex),\n );\n\n // Create custom entries\n for (let i = 0; i < counts.custom.count; i++) {\n const entry = mockCustomPermissionStorageEntry(\n chainId as Hex,\n counts.custom.data[i],\n );\n result.push(entry);\n }\n });\n\n return result;\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { AccountSigner, Erc20TokenPeriodicPermission, Erc20TokenStreamPermission, NativeTokenPeriodicPermission, NativeTokenStreamPermission } from "@metamask/7715-permission-types";
|
|
2
|
+
import type { Hex } from "@metamask/utils";
|
|
3
|
+
import type { CustomPermission, PermissionTypesWithCustom, StoredGatorPermission } from "../types.cjs";
|
|
4
|
+
export declare const mockNativeTokenStreamStorageEntry: (chainId: Hex) => StoredGatorPermission<AccountSigner, NativeTokenStreamPermission>;
|
|
5
|
+
export declare const mockNativeTokenPeriodicStorageEntry: (chainId: Hex) => StoredGatorPermission<AccountSigner, NativeTokenPeriodicPermission>;
|
|
6
|
+
export declare const mockErc20TokenStreamStorageEntry: (chainId: Hex) => StoredGatorPermission<AccountSigner, Erc20TokenStreamPermission>;
|
|
7
|
+
export declare const mockErc20TokenPeriodicStorageEntry: (chainId: Hex) => StoredGatorPermission<AccountSigner, Erc20TokenPeriodicPermission>;
|
|
8
|
+
export declare const mockCustomPermissionStorageEntry: (chainId: Hex, data: Record<string, unknown>) => StoredGatorPermission<AccountSigner, CustomPermission>;
|
|
9
|
+
export type MockGatorPermissionsStorageEntriesConfig = {
|
|
10
|
+
[chainId: string]: {
|
|
11
|
+
nativeTokenStream: number;
|
|
12
|
+
nativeTokenPeriodic: number;
|
|
13
|
+
erc20TokenStream: number;
|
|
14
|
+
erc20TokenPeriodic: number;
|
|
15
|
+
custom: {
|
|
16
|
+
count: number;
|
|
17
|
+
data: Record<string, unknown>[];
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Creates a mock gator permissions storage entry
|
|
23
|
+
*
|
|
24
|
+
* @param config - The config for the mock gator permissions storage entries.
|
|
25
|
+
* @returns Mock gator permissions storage entry
|
|
26
|
+
*/
|
|
27
|
+
/**
|
|
28
|
+
* Creates mock gator permissions storage entries with unique expiry times
|
|
29
|
+
*
|
|
30
|
+
* @param config - The config for the mock gator permissions storage entries.
|
|
31
|
+
* @returns Mock gator permissions storage entries
|
|
32
|
+
*/
|
|
33
|
+
export declare function mockGatorPermissionsStorageEntriesFactory(config: MockGatorPermissionsStorageEntriesConfig): StoredGatorPermission<AccountSigner, PermissionTypesWithCustom>[];
|
|
34
|
+
//# sourceMappingURL=mocks.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mocks.d.cts","sourceRoot":"","sources":["../../src/test/mocks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,4BAA4B,EAC5B,0BAA0B,EAC1B,6BAA6B,EAC7B,2BAA2B,EAC5B,wCAAwC;AACzC,OAAO,KAAK,EAAE,GAAG,EAAE,wBAAwB;AAE3C,OAAO,KAAK,EACV,gBAAgB,EAChB,yBAAyB,EACzB,qBAAqB,EACtB,qBAAiB;AAElB,eAAO,MAAM,iCAAiC,YACnC,GAAG,KACX,sBAAsB,aAAa,EAAE,2BAA2B,CAgCjE,CAAC;AAEH,eAAO,MAAM,mCAAmC,YACrC,GAAG,KACX,sBAAsB,aAAa,EAAE,6BAA6B,CA+BnE,CAAC;AAEH,eAAO,MAAM,gCAAgC,YAClC,GAAG,KACX,sBAAsB,aAAa,EAAE,0BAA0B,CAiChE,CAAC;AAEH,eAAO,MAAM,kCAAkC,YACpC,GAAG,KACX,sBAAsB,aAAa,EAAE,4BAA4B,CAgClE,CAAC;AAEH,eAAO,MAAM,gCAAgC,YAClC,GAAG,QACN,OAAO,MAAM,EAAE,OAAO,CAAC,KAC5B,sBAAsB,aAAa,EAAE,gBAAgB,CA6BtD,CAAC;AAEH,MAAM,MAAM,wCAAwC,GAAG;IACrD,CAAC,OAAO,EAAE,MAAM,GAAG;QACjB,iBAAiB,EAAE,MAAM,CAAC;QAC1B,mBAAmB,EAAE,MAAM,CAAC;QAC5B,gBAAgB,EAAE,MAAM,CAAC;QACzB,kBAAkB,EAAE,MAAM,CAAC;QAC3B,MAAM,EAAE;YACN,KAAK,EAAE,MAAM,CAAC;YACd,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;SACjC,CAAC;KACH,CAAC;CACH,CAAC;AAEF;;;;;GAKG;AACH;;;;;GAKG;AACH,wBAAgB,yCAAyC,CACvD,MAAM,EAAE,wCAAwC,GAC/C,qBAAqB,CAAC,aAAa,EAAE,yBAAyB,CAAC,EAAE,CAyDnE"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { AccountSigner, Erc20TokenPeriodicPermission, Erc20TokenStreamPermission, NativeTokenPeriodicPermission, NativeTokenStreamPermission } from "@metamask/7715-permission-types";
|
|
2
|
+
import type { Hex } from "@metamask/utils";
|
|
3
|
+
import type { CustomPermission, PermissionTypesWithCustom, StoredGatorPermission } from "../types.mjs";
|
|
4
|
+
export declare const mockNativeTokenStreamStorageEntry: (chainId: Hex) => StoredGatorPermission<AccountSigner, NativeTokenStreamPermission>;
|
|
5
|
+
export declare const mockNativeTokenPeriodicStorageEntry: (chainId: Hex) => StoredGatorPermission<AccountSigner, NativeTokenPeriodicPermission>;
|
|
6
|
+
export declare const mockErc20TokenStreamStorageEntry: (chainId: Hex) => StoredGatorPermission<AccountSigner, Erc20TokenStreamPermission>;
|
|
7
|
+
export declare const mockErc20TokenPeriodicStorageEntry: (chainId: Hex) => StoredGatorPermission<AccountSigner, Erc20TokenPeriodicPermission>;
|
|
8
|
+
export declare const mockCustomPermissionStorageEntry: (chainId: Hex, data: Record<string, unknown>) => StoredGatorPermission<AccountSigner, CustomPermission>;
|
|
9
|
+
export type MockGatorPermissionsStorageEntriesConfig = {
|
|
10
|
+
[chainId: string]: {
|
|
11
|
+
nativeTokenStream: number;
|
|
12
|
+
nativeTokenPeriodic: number;
|
|
13
|
+
erc20TokenStream: number;
|
|
14
|
+
erc20TokenPeriodic: number;
|
|
15
|
+
custom: {
|
|
16
|
+
count: number;
|
|
17
|
+
data: Record<string, unknown>[];
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Creates a mock gator permissions storage entry
|
|
23
|
+
*
|
|
24
|
+
* @param config - The config for the mock gator permissions storage entries.
|
|
25
|
+
* @returns Mock gator permissions storage entry
|
|
26
|
+
*/
|
|
27
|
+
/**
|
|
28
|
+
* Creates mock gator permissions storage entries with unique expiry times
|
|
29
|
+
*
|
|
30
|
+
* @param config - The config for the mock gator permissions storage entries.
|
|
31
|
+
* @returns Mock gator permissions storage entries
|
|
32
|
+
*/
|
|
33
|
+
export declare function mockGatorPermissionsStorageEntriesFactory(config: MockGatorPermissionsStorageEntriesConfig): StoredGatorPermission<AccountSigner, PermissionTypesWithCustom>[];
|
|
34
|
+
//# sourceMappingURL=mocks.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mocks.d.mts","sourceRoot":"","sources":["../../src/test/mocks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,4BAA4B,EAC5B,0BAA0B,EAC1B,6BAA6B,EAC7B,2BAA2B,EAC5B,wCAAwC;AACzC,OAAO,KAAK,EAAE,GAAG,EAAE,wBAAwB;AAE3C,OAAO,KAAK,EACV,gBAAgB,EAChB,yBAAyB,EACzB,qBAAqB,EACtB,qBAAiB;AAElB,eAAO,MAAM,iCAAiC,YACnC,GAAG,KACX,sBAAsB,aAAa,EAAE,2BAA2B,CAgCjE,CAAC;AAEH,eAAO,MAAM,mCAAmC,YACrC,GAAG,KACX,sBAAsB,aAAa,EAAE,6BAA6B,CA+BnE,CAAC;AAEH,eAAO,MAAM,gCAAgC,YAClC,GAAG,KACX,sBAAsB,aAAa,EAAE,0BAA0B,CAiChE,CAAC;AAEH,eAAO,MAAM,kCAAkC,YACpC,GAAG,KACX,sBAAsB,aAAa,EAAE,4BAA4B,CAgClE,CAAC;AAEH,eAAO,MAAM,gCAAgC,YAClC,GAAG,QACN,OAAO,MAAM,EAAE,OAAO,CAAC,KAC5B,sBAAsB,aAAa,EAAE,gBAAgB,CA6BtD,CAAC;AAEH,MAAM,MAAM,wCAAwC,GAAG;IACrD,CAAC,OAAO,EAAE,MAAM,GAAG;QACjB,iBAAiB,EAAE,MAAM,CAAC;QAC1B,mBAAmB,EAAE,MAAM,CAAC;QAC5B,gBAAgB,EAAE,MAAM,CAAC;QACzB,kBAAkB,EAAE,MAAM,CAAC;QAC3B,MAAM,EAAE;YACN,KAAK,EAAE,MAAM,CAAC;YACd,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;SACjC,CAAC;KACH,CAAC;CACH,CAAC;AAEF;;;;;GAKG;AACH;;;;;GAKG;AACH,wBAAgB,yCAAyC,CACvD,MAAM,EAAE,wCAAwC,GAC/C,qBAAqB,CAAC,aAAa,EAAE,yBAAyB,CAAC,EAAE,CAyDnE"}
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
export const mockNativeTokenStreamStorageEntry = (chainId) => ({
|
|
2
|
+
permissionResponse: {
|
|
3
|
+
chainId: chainId,
|
|
4
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
5
|
+
signer: {
|
|
6
|
+
type: 'account',
|
|
7
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
8
|
+
},
|
|
9
|
+
permission: {
|
|
10
|
+
type: 'native-token-stream',
|
|
11
|
+
isAdjustmentAllowed: true,
|
|
12
|
+
data: {
|
|
13
|
+
maxAmount: '0x22b1c8c1227a0000',
|
|
14
|
+
initialAmount: '0x6f05b59d3b20000',
|
|
15
|
+
amountPerSecond: '0x6f05b59d3b20000',
|
|
16
|
+
startTime: 1747699200,
|
|
17
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
context: '0x00000000',
|
|
21
|
+
dependencyInfo: [
|
|
22
|
+
{
|
|
23
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
24
|
+
factoryData: '0x0000000',
|
|
25
|
+
},
|
|
26
|
+
],
|
|
27
|
+
signerMeta: {
|
|
28
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
siteOrigin: 'http://localhost:8000',
|
|
32
|
+
});
|
|
33
|
+
export const mockNativeTokenPeriodicStorageEntry = (chainId) => ({
|
|
34
|
+
permissionResponse: {
|
|
35
|
+
chainId: chainId,
|
|
36
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
37
|
+
signer: {
|
|
38
|
+
type: 'account',
|
|
39
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
40
|
+
},
|
|
41
|
+
permission: {
|
|
42
|
+
type: 'native-token-periodic',
|
|
43
|
+
isAdjustmentAllowed: true,
|
|
44
|
+
data: {
|
|
45
|
+
periodAmount: '0x22b1c8c1227a0000',
|
|
46
|
+
periodDuration: 1747699200,
|
|
47
|
+
startTime: 1747699200,
|
|
48
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
context: '0x00000000',
|
|
52
|
+
dependencyInfo: [
|
|
53
|
+
{
|
|
54
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
55
|
+
factoryData: '0x0000000',
|
|
56
|
+
},
|
|
57
|
+
],
|
|
58
|
+
signerMeta: {
|
|
59
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
60
|
+
},
|
|
61
|
+
},
|
|
62
|
+
siteOrigin: 'http://localhost:8000',
|
|
63
|
+
});
|
|
64
|
+
export const mockErc20TokenStreamStorageEntry = (chainId) => ({
|
|
65
|
+
permissionResponse: {
|
|
66
|
+
chainId: chainId,
|
|
67
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
68
|
+
signer: {
|
|
69
|
+
type: 'account',
|
|
70
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
71
|
+
},
|
|
72
|
+
permission: {
|
|
73
|
+
type: 'erc20-token-stream',
|
|
74
|
+
isAdjustmentAllowed: true,
|
|
75
|
+
data: {
|
|
76
|
+
initialAmount: '0x22b1c8c1227a0000',
|
|
77
|
+
maxAmount: '0x6f05b59d3b20000',
|
|
78
|
+
amountPerSecond: '0x6f05b59d3b20000',
|
|
79
|
+
startTime: 1747699200,
|
|
80
|
+
tokenAddress: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
81
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
82
|
+
},
|
|
83
|
+
},
|
|
84
|
+
context: '0x00000000',
|
|
85
|
+
dependencyInfo: [
|
|
86
|
+
{
|
|
87
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
88
|
+
factoryData: '0x0000000',
|
|
89
|
+
},
|
|
90
|
+
],
|
|
91
|
+
signerMeta: {
|
|
92
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
93
|
+
},
|
|
94
|
+
},
|
|
95
|
+
siteOrigin: 'http://localhost:8000',
|
|
96
|
+
});
|
|
97
|
+
export const mockErc20TokenPeriodicStorageEntry = (chainId) => ({
|
|
98
|
+
permissionResponse: {
|
|
99
|
+
chainId: chainId,
|
|
100
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
101
|
+
signer: {
|
|
102
|
+
type: 'account',
|
|
103
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
104
|
+
},
|
|
105
|
+
permission: {
|
|
106
|
+
type: 'erc20-token-periodic',
|
|
107
|
+
isAdjustmentAllowed: true,
|
|
108
|
+
data: {
|
|
109
|
+
periodAmount: '0x22b1c8c1227a0000',
|
|
110
|
+
periodDuration: 1747699200,
|
|
111
|
+
startTime: 1747699200,
|
|
112
|
+
tokenAddress: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
113
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
context: '0x00000000',
|
|
117
|
+
dependencyInfo: [
|
|
118
|
+
{
|
|
119
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
120
|
+
factoryData: '0x0000000',
|
|
121
|
+
},
|
|
122
|
+
],
|
|
123
|
+
signerMeta: {
|
|
124
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
125
|
+
},
|
|
126
|
+
},
|
|
127
|
+
siteOrigin: 'http://localhost:8000',
|
|
128
|
+
});
|
|
129
|
+
export const mockCustomPermissionStorageEntry = (chainId, data) => ({
|
|
130
|
+
permissionResponse: {
|
|
131
|
+
chainId: chainId,
|
|
132
|
+
address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',
|
|
133
|
+
signer: {
|
|
134
|
+
type: 'account',
|
|
135
|
+
data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },
|
|
136
|
+
},
|
|
137
|
+
permission: {
|
|
138
|
+
type: 'custom',
|
|
139
|
+
isAdjustmentAllowed: true,
|
|
140
|
+
data: {
|
|
141
|
+
justification: 'This is a very important request for streaming allowance for some very important thing',
|
|
142
|
+
...data,
|
|
143
|
+
},
|
|
144
|
+
},
|
|
145
|
+
context: '0x00000000',
|
|
146
|
+
dependencyInfo: [
|
|
147
|
+
{
|
|
148
|
+
factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',
|
|
149
|
+
factoryData: '0x0000000',
|
|
150
|
+
},
|
|
151
|
+
],
|
|
152
|
+
signerMeta: {
|
|
153
|
+
delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',
|
|
154
|
+
},
|
|
155
|
+
},
|
|
156
|
+
siteOrigin: 'http://localhost:8000',
|
|
157
|
+
});
|
|
158
|
+
/**
|
|
159
|
+
* Creates a mock gator permissions storage entry
|
|
160
|
+
*
|
|
161
|
+
* @param config - The config for the mock gator permissions storage entries.
|
|
162
|
+
* @returns Mock gator permissions storage entry
|
|
163
|
+
*/
|
|
164
|
+
/**
|
|
165
|
+
* Creates mock gator permissions storage entries with unique expiry times
|
|
166
|
+
*
|
|
167
|
+
* @param config - The config for the mock gator permissions storage entries.
|
|
168
|
+
* @returns Mock gator permissions storage entries
|
|
169
|
+
*/
|
|
170
|
+
export function mockGatorPermissionsStorageEntriesFactory(config) {
|
|
171
|
+
const result = [];
|
|
172
|
+
Object.entries(config).forEach(([chainId, counts]) => {
|
|
173
|
+
if (counts.custom.count !== counts.custom.data.length) {
|
|
174
|
+
throw new Error('Custom permission count and data length mismatch');
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Creates a number of entries with unique expiry times
|
|
178
|
+
*
|
|
179
|
+
* @param count - The number of entries to create.
|
|
180
|
+
* @param createEntry - The function to create an entry.
|
|
181
|
+
*/
|
|
182
|
+
const createEntries = (count, createEntry) => {
|
|
183
|
+
for (let i = 0; i < count; i++) {
|
|
184
|
+
const entry = createEntry();
|
|
185
|
+
result.push(entry);
|
|
186
|
+
}
|
|
187
|
+
};
|
|
188
|
+
createEntries(counts.nativeTokenStream, () => mockNativeTokenStreamStorageEntry(chainId));
|
|
189
|
+
createEntries(counts.nativeTokenPeriodic, () => mockNativeTokenPeriodicStorageEntry(chainId));
|
|
190
|
+
createEntries(counts.erc20TokenStream, () => mockErc20TokenStreamStorageEntry(chainId));
|
|
191
|
+
createEntries(counts.erc20TokenPeriodic, () => mockErc20TokenPeriodicStorageEntry(chainId));
|
|
192
|
+
// Create custom entries
|
|
193
|
+
for (let i = 0; i < counts.custom.count; i++) {
|
|
194
|
+
const entry = mockCustomPermissionStorageEntry(chainId, counts.custom.data[i]);
|
|
195
|
+
result.push(entry);
|
|
196
|
+
}
|
|
197
|
+
});
|
|
198
|
+
return result;
|
|
199
|
+
}
|
|
200
|
+
//# sourceMappingURL=mocks.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mocks.mjs","sourceRoot":"","sources":["../../src/test/mocks.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n AccountSigner,\n Erc20TokenPeriodicPermission,\n Erc20TokenStreamPermission,\n NativeTokenPeriodicPermission,\n NativeTokenStreamPermission,\n} from '@metamask/7715-permission-types';\nimport type { Hex } from '@metamask/utils';\n\nimport type {\n CustomPermission,\n PermissionTypesWithCustom,\n StoredGatorPermission,\n} from '../types';\n\nexport const mockNativeTokenStreamStorageEntry = (\n chainId: Hex,\n): StoredGatorPermission<AccountSigner, NativeTokenStreamPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'native-token-stream',\n isAdjustmentAllowed: true,\n data: {\n maxAmount: '0x22b1c8c1227a0000',\n initialAmount: '0x6f05b59d3b20000',\n amountPerSecond: '0x6f05b59d3b20000',\n startTime: 1747699200,\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport const mockNativeTokenPeriodicStorageEntry = (\n chainId: Hex,\n): StoredGatorPermission<AccountSigner, NativeTokenPeriodicPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'native-token-periodic',\n isAdjustmentAllowed: true,\n data: {\n periodAmount: '0x22b1c8c1227a0000',\n periodDuration: 1747699200,\n startTime: 1747699200,\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport const mockErc20TokenStreamStorageEntry = (\n chainId: Hex,\n): StoredGatorPermission<AccountSigner, Erc20TokenStreamPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'erc20-token-stream',\n isAdjustmentAllowed: true,\n data: {\n initialAmount: '0x22b1c8c1227a0000',\n maxAmount: '0x6f05b59d3b20000',\n amountPerSecond: '0x6f05b59d3b20000',\n startTime: 1747699200,\n tokenAddress: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport const mockErc20TokenPeriodicStorageEntry = (\n chainId: Hex,\n): StoredGatorPermission<AccountSigner, Erc20TokenPeriodicPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'erc20-token-periodic',\n isAdjustmentAllowed: true,\n data: {\n periodAmount: '0x22b1c8c1227a0000',\n periodDuration: 1747699200,\n startTime: 1747699200,\n tokenAddress: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport const mockCustomPermissionStorageEntry = (\n chainId: Hex,\n data: Record<string, unknown>,\n): StoredGatorPermission<AccountSigner, CustomPermission> => ({\n permissionResponse: {\n chainId: chainId as Hex,\n address: '0xB68c70159E9892DdF5659ec42ff9BD2bbC23e778',\n signer: {\n type: 'account',\n data: { address: '0x4f71DA06987BfeDE90aF0b33E1e3e4ffDCEE7a63' },\n },\n permission: {\n type: 'custom',\n isAdjustmentAllowed: true,\n data: {\n justification:\n 'This is a very important request for streaming allowance for some very important thing',\n ...data,\n },\n },\n context: '0x00000000',\n dependencyInfo: [\n {\n factory: '0x69Aa2f9fe1572F1B640E1bbc512f5c3a734fc77c',\n factoryData: '0x0000000',\n },\n ],\n signerMeta: {\n delegationManager: '0xdb9B1e94B5b69Df7e401DDbedE43491141047dB3',\n },\n },\n siteOrigin: 'http://localhost:8000',\n});\n\nexport type MockGatorPermissionsStorageEntriesConfig = {\n [chainId: string]: {\n nativeTokenStream: number;\n nativeTokenPeriodic: number;\n erc20TokenStream: number;\n erc20TokenPeriodic: number;\n custom: {\n count: number;\n data: Record<string, unknown>[];\n };\n };\n};\n\n/**\n * Creates a mock gator permissions storage entry\n *\n * @param config - The config for the mock gator permissions storage entries.\n * @returns Mock gator permissions storage entry\n */\n/**\n * Creates mock gator permissions storage entries with unique expiry times\n *\n * @param config - The config for the mock gator permissions storage entries.\n * @returns Mock gator permissions storage entries\n */\nexport function mockGatorPermissionsStorageEntriesFactory(\n config: MockGatorPermissionsStorageEntriesConfig,\n): StoredGatorPermission<AccountSigner, PermissionTypesWithCustom>[] {\n const result: StoredGatorPermission<\n AccountSigner,\n PermissionTypesWithCustom\n >[] = [];\n\n Object.entries(config).forEach(([chainId, counts]) => {\n if (counts.custom.count !== counts.custom.data.length) {\n throw new Error('Custom permission count and data length mismatch');\n }\n\n /**\n * Creates a number of entries with unique expiry times\n *\n * @param count - The number of entries to create.\n * @param createEntry - The function to create an entry.\n */\n const createEntries = (\n count: number,\n createEntry: () => StoredGatorPermission<\n AccountSigner,\n PermissionTypesWithCustom\n >,\n ) => {\n for (let i = 0; i < count; i++) {\n const entry = createEntry();\n result.push(entry);\n }\n };\n\n createEntries(counts.nativeTokenStream, () =>\n mockNativeTokenStreamStorageEntry(chainId as Hex),\n );\n\n createEntries(counts.nativeTokenPeriodic, () =>\n mockNativeTokenPeriodicStorageEntry(chainId as Hex),\n );\n\n createEntries(counts.erc20TokenStream, () =>\n mockErc20TokenStreamStorageEntry(chainId as Hex),\n );\n\n createEntries(counts.erc20TokenPeriodic, () =>\n mockErc20TokenPeriodicStorageEntry(chainId as Hex),\n );\n\n // Create custom entries\n for (let i = 0; i < counts.custom.count; i++) {\n const entry = mockCustomPermissionStorageEntry(\n chainId as Hex,\n counts.custom.data[i],\n );\n result.push(entry);\n }\n });\n\n return result;\n}\n"]}
|
package/dist/types.cjs
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GatorPermissionsSnapRpcMethod = exports.GatorPermissionsControllerErrorCode = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Enum for the error codes of the gator permissions controller.
|
|
6
|
+
*/
|
|
7
|
+
var GatorPermissionsControllerErrorCode;
|
|
8
|
+
(function (GatorPermissionsControllerErrorCode) {
|
|
9
|
+
GatorPermissionsControllerErrorCode["GatorPermissionsFetchError"] = "gator-permissions-fetch-error";
|
|
10
|
+
GatorPermissionsControllerErrorCode["GatorPermissionsNotEnabled"] = "gator-permissions-not-enabled";
|
|
11
|
+
GatorPermissionsControllerErrorCode["GatorPermissionsProviderError"] = "gator-permissions-provider-error";
|
|
12
|
+
GatorPermissionsControllerErrorCode["GatorPermissionsMapSerializationError"] = "gator-permissions-map-serialization-error";
|
|
13
|
+
})(GatorPermissionsControllerErrorCode || (exports.GatorPermissionsControllerErrorCode = GatorPermissionsControllerErrorCode = {}));
|
|
14
|
+
/**
|
|
15
|
+
* Enum for the RPC methods of the gator permissions provider snap.
|
|
16
|
+
*/
|
|
17
|
+
var GatorPermissionsSnapRpcMethod;
|
|
18
|
+
(function (GatorPermissionsSnapRpcMethod) {
|
|
19
|
+
/**
|
|
20
|
+
* This method is used by the metamask to request a permissions provider to get granted permissions for all sites.
|
|
21
|
+
*/
|
|
22
|
+
GatorPermissionsSnapRpcMethod["PermissionProviderGetGrantedPermissions"] = "permissionsProvider_getGrantedPermissions";
|
|
23
|
+
})(GatorPermissionsSnapRpcMethod || (exports.GatorPermissionsSnapRpcMethod = GatorPermissionsSnapRpcMethod = {}));
|
|
24
|
+
//# sourceMappingURL=types.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.cjs","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":";;;AAaA;;GAEG;AACH,IAAY,mCAKX;AALD,WAAY,mCAAmC;IAC7C,mGAA4D,CAAA;IAC5D,mGAA4D,CAAA;IAC5D,yGAAkE,CAAA;IAClE,0HAAmF,CAAA;AACrF,CAAC,EALW,mCAAmC,mDAAnC,mCAAmC,QAK9C;AAED;;GAEG;AACH,IAAY,6BAKX;AALD,WAAY,6BAA6B;IACvC;;OAEG;IACH,sHAAqF,CAAA;AACvF,CAAC,EALW,6BAA6B,6CAA7B,6BAA6B,QAKxC","sourcesContent":["import type {\n PermissionTypes,\n Signer,\n BasePermission,\n NativeTokenStreamPermission,\n NativeTokenPeriodicPermission,\n Erc20TokenStreamPermission,\n Erc20TokenPeriodicPermission,\n Rule,\n MetaMaskBasePermissionData,\n} from '@metamask/7715-permission-types';\nimport type { Hex } from '@metamask/utils';\n\n/**\n * Enum for the error codes of the gator permissions controller.\n */\nexport enum GatorPermissionsControllerErrorCode {\n GatorPermissionsFetchError = 'gator-permissions-fetch-error',\n GatorPermissionsNotEnabled = 'gator-permissions-not-enabled',\n GatorPermissionsProviderError = 'gator-permissions-provider-error',\n GatorPermissionsMapSerializationError = 'gator-permissions-map-serialization-error',\n}\n\n/**\n * Enum for the RPC methods of the gator permissions provider snap.\n */\nexport enum GatorPermissionsSnapRpcMethod {\n /**\n * This method is used by the metamask to request a permissions provider to get granted permissions for all sites.\n */\n PermissionProviderGetGrantedPermissions = 'permissionsProvider_getGrantedPermissions',\n}\n\n/**\n * Represents a custom permission that are not of the standard ERC-7715 permission types.\n */\nexport type CustomPermission = BasePermission & {\n type: 'custom';\n data: MetaMaskBasePermissionData & Record<string, unknown>;\n};\n\n/**\n * Represents the type of the ERC-7715 permissions that can be granted including custom permissions.\n */\nexport type PermissionTypesWithCustom = PermissionTypes | CustomPermission;\n\n/**\n * Represents a ERC-7715 permission request.\n *\n * @template Signer - The type of the signer provided, either an AccountSigner or WalletSigner.\n * @template Permission - The type of the permission provided.\n */\nexport type PermissionRequest<\n TSigner extends Signer,\n TPermission extends PermissionTypesWithCustom,\n> = {\n /**\n * hex-encoding of uint256 defined the chain with EIP-155\n */\n chainId: Hex;\n\n /**\n *\n * The account being targeted for this permission request.\n * It is optional to let the user choose which account to grant permission from.\n */\n address?: Hex;\n\n /**\n * An account that is associated with the recipient of the granted 7715 permission or alternatively the wallet will manage the session.\n */\n signer: TSigner;\n\n /**\n * Defines the allowed behavior the signer can do on behalf of the account.\n */\n permission: TPermission;\n\n rules?: Rule[] | null;\n};\n\n/**\n * Represents a ERC-7715 permission response.\n *\n * @template Signer - The type of the signer provided, either an AccountSigner or WalletSigner.\n * @template Permission - The type of the permission provided.\n */\nexport type PermissionResponse<\n TSigner extends Signer,\n TPermission extends PermissionTypesWithCustom,\n> = PermissionRequest<TSigner, TPermission> & {\n /**\n * Is a catch-all to identify a permission for revoking permissions or submitting\n * Defined in ERC-7710.\n */\n context: Hex;\n\n /**\n * The dependencyInfo field is required and contains information needed to deploy accounts.\n * Each entry specifies a factory contract and its associated deployment data.\n * If no account deployment is needed when redeeming the permission, this array must be empty.\n * When non-empty, DApps MUST deploy the accounts by calling the factory contract with factoryData as the calldata.\n * Defined in ERC-4337.\n */\n dependencyInfo: {\n factory: Hex;\n factoryData: Hex;\n }[];\n\n /**\n * If the signer type is account then delegationManager is required as defined in ERC-7710.\n */\n signerMeta: {\n delegationManager: Hex;\n };\n};\n\n/**\n * Represents a sanitized version of the PermissionResponse type.\n * Some fields have been removed but the fields are still present in profile sync.\n *\n * @template Signer - The type of the signer provided, either an AccountSigner or WalletSigner.\n * @template Permission - The type of the permission provided.\n */\nexport type PermissionResponseSanitized<\n TSigner extends Signer,\n TPermission extends PermissionTypesWithCustom,\n> = Omit<\n PermissionResponse<TSigner, TPermission>,\n 'dependencyInfo' | 'signer' | 'rules'\n>;\n\n/**\n * Represents a gator ERC-7715 granted(ie. signed by an user account) permission entry that is stored in profile sync.\n *\n * @template Signer - The type of the signer provided, either an AccountSigner or WalletSigner.\n * @template Permission - The type of the permission provided\n */\nexport type StoredGatorPermission<\n TSigner extends Signer,\n TPermission extends PermissionTypesWithCustom,\n> = {\n permissionResponse: PermissionResponse<TSigner, TPermission>;\n siteOrigin: string;\n};\n\n/**\n * Represents a sanitized version of the StoredGatorPermission type. Some fields have been removed but the fields are still present in profile sync.\n *\n * @template Signer - The type of the signer provided, either an AccountSigner or WalletSigner.\n * @template Permission - The type of the permission provided.\n */\nexport type StoredGatorPermissionSanitized<\n TSigner extends Signer,\n TPermission extends PermissionTypesWithCustom,\n> = {\n permissionResponse: PermissionResponseSanitized<TSigner, TPermission>;\n siteOrigin: string;\n};\n\n/**\n * Represents a map of gator permissions by chainId and permission type.\n */\nexport type GatorPermissionsMap = {\n 'native-token-stream': {\n [chainId: Hex]: StoredGatorPermissionSanitized<\n Signer,\n NativeTokenStreamPermission\n >[];\n };\n 'native-token-periodic': {\n [chainId: Hex]: StoredGatorPermissionSanitized<\n Signer,\n NativeTokenPeriodicPermission\n >[];\n };\n 'erc20-token-stream': {\n [chainId: Hex]: StoredGatorPermissionSanitized<\n Signer,\n Erc20TokenStreamPermission\n >[];\n };\n 'erc20-token-periodic': {\n [chainId: Hex]: StoredGatorPermissionSanitized<\n Signer,\n Erc20TokenPeriodicPermission\n >[];\n };\n other: {\n [chainId: Hex]: StoredGatorPermissionSanitized<Signer, CustomPermission>[];\n };\n};\n\n/**\n * Represents the supported permission type(e.g. 'native-token-stream', 'native-token-periodic', 'erc20-token-stream', 'erc20-token-periodic') of the gator permissions map.\n */\nexport type SupportedGatorPermissionType = keyof GatorPermissionsMap;\n\n/**\n * Represents a map of gator permissions for a given permission type with key of chainId. The value being an array of gator permissions for that chainId.\n */\nexport type GatorPermissionsMapByPermissionType<\n TPermissionType extends SupportedGatorPermissionType,\n> = GatorPermissionsMap[TPermissionType];\n\n/**\n * Represents an array of gator permissions for a given permission type and chainId.\n */\nexport type GatorPermissionsListByPermissionTypeAndChainId<\n TPermissionType extends SupportedGatorPermissionType,\n> = GatorPermissionsMap[TPermissionType][Hex];\n"]}
|