@sentio/sdk 0.1.14 → 0.2.14
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/dist/base-processor-template.d.ts +19 -0
- package/dist/base-processor-template.js +80 -0
- package/dist/base-processor-template.js.map +1 -0
- package/dist/base-processor.d.ts +7 -18
- package/dist/base-processor.js +69 -28
- package/dist/base-processor.js.map +1 -1
- package/dist/bind-options.d.ts +16 -0
- package/dist/bind-options.js +20 -0
- package/dist/bind-options.js.map +1 -0
- package/dist/cli/build.d.ts +3 -1
- package/dist/cli/build.js +100 -17
- package/dist/cli/build.js.map +1 -1
- package/dist/cli/cli.d.ts +1 -2
- package/dist/cli/cli.js +9 -15
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/config.d.ts +7 -1
- package/dist/cli/config.js +4 -1
- package/dist/cli/config.js.map +1 -1
- package/dist/cli/solana-code-gen.d.ts +2 -0
- package/dist/cli/solana-code-gen.js +19 -0
- package/dist/cli/solana-code-gen.js.map +1 -0
- package/dist/cli/upload.js +4 -2
- package/dist/cli/upload.js.map +1 -1
- package/dist/gen/processor/protos/processor.d.ts +50 -3
- package/dist/gen/processor/protos/processor.js +244 -52
- package/dist/gen/processor/protos/processor.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.js +5 -1
- package/dist/index.js.map +1 -1
- package/dist/numberish.test.d.ts +1 -0
- package/dist/numberish.test.js +9 -0
- package/dist/numberish.test.js.map +1 -0
- package/dist/provider.d.ts +1 -1
- package/dist/provider.js +3 -0
- package/dist/provider.js.map +1 -1
- package/dist/service.d.ts +4 -1
- package/dist/service.js +90 -47
- package/dist/service.js.map +1 -1
- package/dist/solana-processor.d.ts +6 -6
- package/dist/solana-processor.js +5 -20
- package/dist/solana-processor.js.map +1 -1
- package/dist/target-ethers-sentio/codegen.js +46 -15
- package/dist/target-ethers-sentio/codegen.js.map +1 -1
- package/dist/test-case/clean-test.d.ts +1 -0
- package/dist/test-case/clean-test.js +11 -0
- package/dist/test-case/clean-test.js.map +1 -0
- package/dist/test-case/erc20.js +22 -6
- package/dist/test-case/erc20.js.map +1 -1
- package/dist/test-case/erc20.test.d.ts +1 -0
- package/dist/test-case/erc20.test.js +173 -0
- package/dist/test-case/erc20.test.js.map +1 -0
- package/dist/test-case/mirrorworld.d.ts +1 -4
- package/dist/test-case/mirrorworld.js +37 -57
- package/dist/test-case/mirrorworld.js.map +1 -1
- package/dist/test-case/solana.test.d.ts +1 -0
- package/dist/test-case/solana.test.js +56 -0
- package/dist/test-case/solana.test.js.map +1 -0
- package/dist/test-case/types/erc20_processor.d.ts +9 -8
- package/dist/test-case/types/erc20_processor.js +38 -14
- package/dist/test-case/types/erc20_processor.js.map +1 -1
- package/dist/test-case/types/game_wallet_processor.d.ts +107 -0
- package/dist/test-case/types/game_wallet_processor.js +102 -0
- package/dist/test-case/types/game_wallet_processor.js.map +1 -0
- package/dist/test-case/types/wormhole_processor.d.ts +16 -0
- package/dist/test-case/types/wormhole_processor.js +192 -0
- package/dist/test-case/types/wormhole_processor.js.map +1 -0
- package/dist/test-case/wormhole-token-bridge.d.ts +1 -0
- package/dist/test-case/wormhole-token-bridge.js +7 -0
- package/dist/test-case/wormhole-token-bridge.js.map +1 -0
- package/package.json +5 -3
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// TODO move out of this package
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
20
|
+
if (mod && mod.__esModule) return mod;
|
|
21
|
+
var result = {};
|
|
22
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
23
|
+
__setModuleDefault(result, mod);
|
|
24
|
+
return result;
|
|
25
|
+
};
|
|
26
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
27
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
28
|
+
};
|
|
29
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
30
|
+
const chai_1 = require("chai");
|
|
31
|
+
const __1 = require("..");
|
|
32
|
+
const path = __importStar(require("path"));
|
|
33
|
+
const fs = __importStar(require("fs-extra"));
|
|
34
|
+
const long_1 = __importDefault(require("long"));
|
|
35
|
+
const clean_test_1 = require("./clean-test");
|
|
36
|
+
describe('Test Server with Example', () => {
|
|
37
|
+
const service = new __1.ProcessorServiceImpl(undefined);
|
|
38
|
+
const testContext = {};
|
|
39
|
+
before(async () => {
|
|
40
|
+
(0, clean_test_1.cleanTest)();
|
|
41
|
+
const fullPath = path.resolve('chains-config.json');
|
|
42
|
+
const chainsConfig = fs.readJsonSync(fullPath);
|
|
43
|
+
(0, __1.setProvider)(chainsConfig);
|
|
44
|
+
require('./erc20');
|
|
45
|
+
await service.start({}, testContext);
|
|
46
|
+
});
|
|
47
|
+
it('check configuration', async () => {
|
|
48
|
+
const config = await service.getConfig({}, testContext);
|
|
49
|
+
(0, chai_1.expect)(config.contractConfigs).length(4);
|
|
50
|
+
// check auto rename
|
|
51
|
+
(0, chai_1.expect)(config.contractConfigs?.[2].contract?.name).equals('Erc20');
|
|
52
|
+
(0, chai_1.expect)(config.contractConfigs?.[3].contract?.name).equals('Erc20_1');
|
|
53
|
+
});
|
|
54
|
+
it('Check block dispatch', async () => {
|
|
55
|
+
const raw = toRaw(blockData);
|
|
56
|
+
const request = {
|
|
57
|
+
block: {
|
|
58
|
+
raw: raw,
|
|
59
|
+
},
|
|
60
|
+
chainId: '1',
|
|
61
|
+
};
|
|
62
|
+
const res = await service.processBlock(request, testContext);
|
|
63
|
+
(0, chai_1.expect)(res.result?.counters).length(0);
|
|
64
|
+
(0, chai_1.expect)(res.result?.histograms).length(1);
|
|
65
|
+
(0, chai_1.expect)(res.result?.histograms?.[0].metricValue?.bigInt).equals('10');
|
|
66
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
67
|
+
const histogram = res.result.histograms[0];
|
|
68
|
+
(0, chai_1.expect)(histogram.metadata?.blockNumber?.toString()).equals('14373295');
|
|
69
|
+
// Different chainId should be dispatch to other
|
|
70
|
+
const request2 = {
|
|
71
|
+
block: {
|
|
72
|
+
raw: raw,
|
|
73
|
+
},
|
|
74
|
+
chainId: '56',
|
|
75
|
+
};
|
|
76
|
+
const res2 = await service.processBlock(request2, testContext);
|
|
77
|
+
(0, chai_1.expect)(res2.result?.counters).length(0);
|
|
78
|
+
(0, chai_1.expect)(res2.result?.histograms).length(1);
|
|
79
|
+
(0, chai_1.expect)(res2.result?.histograms?.[0].metricValue?.bigInt).equals('20');
|
|
80
|
+
});
|
|
81
|
+
it('Check log dispatch', async () => {
|
|
82
|
+
const raw = toRaw(logData);
|
|
83
|
+
const request = {
|
|
84
|
+
logs: [],
|
|
85
|
+
};
|
|
86
|
+
const binding = __1.LogBinding.fromPartial({
|
|
87
|
+
handlerId: 0,
|
|
88
|
+
log: {
|
|
89
|
+
raw: raw,
|
|
90
|
+
},
|
|
91
|
+
});
|
|
92
|
+
request.logs.push(binding);
|
|
93
|
+
// just faked some logs here
|
|
94
|
+
const binding2 = __1.LogBinding.fromPartial({
|
|
95
|
+
handlerId: 1,
|
|
96
|
+
log: {
|
|
97
|
+
raw: raw,
|
|
98
|
+
},
|
|
99
|
+
});
|
|
100
|
+
request.logs.push(binding2);
|
|
101
|
+
const res = await service.processLog(request, testContext);
|
|
102
|
+
(0, chai_1.expect)(res.result?.counters).length(2);
|
|
103
|
+
(0, chai_1.expect)(res.result?.counters?.[0].metricValue?.bigInt).equals('1');
|
|
104
|
+
(0, chai_1.expect)(res.result?.counters?.[0].metadata?.chainId).equals('1');
|
|
105
|
+
(0, chai_1.expect)(res.result?.counters?.[1].metricValue?.bigInt).equals('2');
|
|
106
|
+
(0, chai_1.expect)(res.result?.counters?.[1].metadata?.chainId).equals('56');
|
|
107
|
+
(0, chai_1.expect)(res.result?.histograms).length(0);
|
|
108
|
+
(0, chai_1.expect)(res.configUpdated).equals(true);
|
|
109
|
+
const config = await service.getConfig({}, testContext);
|
|
110
|
+
(0, chai_1.expect)(config.contractConfigs).length(5); //config increased
|
|
111
|
+
(0, chai_1.expect)(config.contractConfigs?.[4].contract?.name).equals('dynamic');
|
|
112
|
+
});
|
|
113
|
+
it('Check template instantiate', async () => {
|
|
114
|
+
let originLen = (await service.getConfig({}, testContext)).contractConfigs?.length;
|
|
115
|
+
if (originLen === undefined) {
|
|
116
|
+
originLen = 0;
|
|
117
|
+
}
|
|
118
|
+
const request = {
|
|
119
|
+
instances: [
|
|
120
|
+
{
|
|
121
|
+
contract: {
|
|
122
|
+
address: 'dynamic2',
|
|
123
|
+
name: 'dynamic2',
|
|
124
|
+
chainId: '1',
|
|
125
|
+
abi: '',
|
|
126
|
+
},
|
|
127
|
+
startBlock: long_1.default.ZERO,
|
|
128
|
+
endBlock: long_1.default.ZERO,
|
|
129
|
+
templateId: 0,
|
|
130
|
+
},
|
|
131
|
+
],
|
|
132
|
+
};
|
|
133
|
+
await service.instantiateTemplate(request, testContext);
|
|
134
|
+
const config = await service.getConfig({}, testContext);
|
|
135
|
+
(0, chai_1.expect)(config.contractConfigs).length(originLen + 1);
|
|
136
|
+
(0, chai_1.expect)(config.contractConfigs?.[originLen].contract?.name).equals('dynamic2');
|
|
137
|
+
(0, chai_1.expect)(config.templateInstances).length(2);
|
|
138
|
+
});
|
|
139
|
+
const blockData = {
|
|
140
|
+
hash: '0x2b9b7cce1f17f3b7e1f3c2472cc806a07bee3f0baca07d021350950d81d73a42',
|
|
141
|
+
parentHash: '0xd538332875124ce30a6674926ae6befa2358ac0a03c70d60c24e74ad7bdf2505',
|
|
142
|
+
number: 14373295,
|
|
143
|
+
timestamp: 1647106437,
|
|
144
|
+
nonce: '0x73bcaf422fe98f49',
|
|
145
|
+
difficulty: null,
|
|
146
|
+
miner: '0x829BD824B016326A401d083B33D092293333A830',
|
|
147
|
+
extraData: '0xe4b883e5bda9e7a59ee4bb99e9b1bc493421',
|
|
148
|
+
};
|
|
149
|
+
const logData = {
|
|
150
|
+
blockNumber: 14213252,
|
|
151
|
+
blockHash: '0x83d646fac9350b281def8c4c37626f9d8efc95df801287b848c719edf35cdbaf',
|
|
152
|
+
transactionIndex: 347,
|
|
153
|
+
removed: false,
|
|
154
|
+
address: '0x1E4EDE388cbc9F4b5c79681B7f94d36a11ABEBC9',
|
|
155
|
+
data: '0x00000000000000000000000000000000000000000000009a71db64810aaa0000',
|
|
156
|
+
topics: [
|
|
157
|
+
'0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef',
|
|
158
|
+
'0x0000000000000000000000000000000000000000000000000000000000000000',
|
|
159
|
+
'0x000000000000000000000000b329e39ebefd16f40d38f07643652ce17ca5bac1',
|
|
160
|
+
],
|
|
161
|
+
transactionHash: '0x93355e0cb2c3490cb8a747029ff2dc8cdbde2407025b8391398436955afae303',
|
|
162
|
+
logIndex: 428,
|
|
163
|
+
};
|
|
164
|
+
function toRaw(obj) {
|
|
165
|
+
const logJsonStr = JSON.stringify(obj);
|
|
166
|
+
const raw = new Uint8Array(logJsonStr.length);
|
|
167
|
+
for (let i = 0; i < logJsonStr.length; i++) {
|
|
168
|
+
raw[i] = logJsonStr.charCodeAt(i);
|
|
169
|
+
}
|
|
170
|
+
return raw;
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
//# sourceMappingURL=erc20.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"erc20.test.js","sourceRoot":"","sources":["../../src/test-case/erc20.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,62 +1,42 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
const
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
return new MirrorWorldProcessor(name, address, endpoint);
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
exports.MirrorWorldProcessor = MirrorWorldProcessor;
|
|
17
|
-
MirrorWorldProcessor.bind('F78NhTC9XmP1DKsCBRz5LGdQc4n4yFbj2dURiv7T9gGZ', 'https://api.mainnet-beta.solana.com')
|
|
18
|
-
.onTransaction((txn, ctx) => {
|
|
19
|
-
const instructionCoder = new anchor_1.BorshInstructionCoder(game_wallet_1.game_wallet_idl);
|
|
20
|
-
for (const instruction of txn.transaction.message.instructions) {
|
|
21
|
-
const decodedData = instructionCoder.decode(Buffer.from(bs58_1.default.decode(instruction.data)));
|
|
22
|
-
console.log('instruction name: ' + decodedData?.name);
|
|
23
|
-
if (decodedData) {
|
|
24
|
-
handleDecodedInstruction(decodedData, ctx);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
3
|
+
const game_wallet_processor_1 = require("./types/game_wallet_processor");
|
|
4
|
+
game_wallet_processor_1.GameWalletProcessor.bind('F78NhTC9XmP1DKsCBRz5LGdQc4n4yFbj2dURiv7T9gGZ', 'https://api.mainnet-beta.solana.com')
|
|
5
|
+
.onDistributeWithoutUser((payload, ctx) => {
|
|
6
|
+
const amount = payload.amount.toNumber();
|
|
7
|
+
ctx.meter.Counter('deposit_pool_total_value').add(amount);
|
|
8
|
+
ctx.meter.Counter('deposit_pool_current_value').add(amount);
|
|
9
|
+
ctx.meter.Counter('distribution_pool_total_value').sub(amount);
|
|
27
10
|
})
|
|
28
|
-
.
|
|
29
|
-
const
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
handleDecodedInstruction(decodedData, ctx);
|
|
33
|
-
}
|
|
11
|
+
.onDeposit((payload, ctx) => {
|
|
12
|
+
const amount = payload.amount.toNumber();
|
|
13
|
+
ctx.meter.Counter('deposit_pool_total_value').add(amount);
|
|
14
|
+
ctx.meter.Counter('deposit_pool_current_value').add(amount);
|
|
34
15
|
})
|
|
35
|
-
.
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
}
|
|
16
|
+
.onWithdraw((payload, ctx) => {
|
|
17
|
+
const amount = payload.amount.toNumber();
|
|
18
|
+
ctx.meter.Counter('deposit_pool_total_value').add(amount);
|
|
19
|
+
ctx.meter.Counter('distribution_pool_total_value').sub(amount);
|
|
20
|
+
})
|
|
21
|
+
.onSpend((payload, ctx) => {
|
|
22
|
+
const amount = payload.amount.toNumber();
|
|
23
|
+
ctx.meter.Counter('deposit_pool_total_value').add(amount);
|
|
24
|
+
ctx.meter.Counter('distribution_pool_total_value').sub(amount);
|
|
25
|
+
})
|
|
26
|
+
.onDistribute((payload, ctx) => {
|
|
27
|
+
const amount = payload.amount.toNumber();
|
|
28
|
+
ctx.meter.Counter('deposit_pool_total_value').add(amount);
|
|
29
|
+
ctx.meter.Counter('deposit_pool_current_value').add(amount);
|
|
30
|
+
ctx.meter.Counter('distribution_pool_total_value').sub(amount);
|
|
31
|
+
})
|
|
32
|
+
.onSpendWithoutUser((payload, ctx) => {
|
|
33
|
+
const amount = payload.amount.toNumber();
|
|
34
|
+
ctx.meter.Counter('deposit_pool_total_value').add(amount);
|
|
35
|
+
ctx.meter.Counter('deposit_pool_current_value').sub(amount);
|
|
36
|
+
})
|
|
37
|
+
.onAddDistributeSupply((payload, ctx) => {
|
|
38
|
+
const amount = payload.amount.toNumber();
|
|
39
|
+
ctx.meter.Counter('distribution_pool_total_value').add(amount);
|
|
40
|
+
})
|
|
41
|
+
.startSlot(142700000);
|
|
62
42
|
//# sourceMappingURL=mirrorworld.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mirrorworld.js","sourceRoot":"","sources":["../../src/test-case/mirrorworld.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"mirrorworld.js","sourceRoot":"","sources":["../../src/test-case/mirrorworld.ts"],"names":[],"mappings":";;AACA,yEAAmE;AAEnE,2CAAmB,CAAC,IAAI,CAAC,8CAA8C,EAAE,qCAAqC,CAAC;KAC5G,uBAAuB,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE;IACxC,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IACxC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACzD,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAC3D,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;AAChE,CAAC,CAAC;KACD,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE;IAC1B,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IACxC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACzD,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;AAC7D,CAAC,CAAC;KACD,UAAU,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE;IAC3B,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IACxC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACzD,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;AAChE,CAAC,CAAC;KACD,OAAO,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE;IACxB,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IACxC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACzD,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;AAChE,CAAC,CAAC;KACD,YAAY,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE;IAC7B,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IACxC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACzD,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAC3D,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;AAChE,CAAC,CAAC;KACD,kBAAkB,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE;IACnC,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IACxC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACzD,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;AAC7D,CAAC,CAAC;KACD,qBAAqB,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE;IACtC,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IACxC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;AAChE,CAAC,CAAC;KACD,SAAS,CAAC,SAAS,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// TODO move out of this package
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
const chai_1 = require("chai");
|
|
8
|
+
const __1 = require("..");
|
|
9
|
+
const long_1 = __importDefault(require("long"));
|
|
10
|
+
const clean_test_1 = require("./clean-test");
|
|
11
|
+
describe('Test Server with Solana Example', () => {
|
|
12
|
+
const service = new __1.ProcessorServiceImpl(undefined);
|
|
13
|
+
const testContext = {};
|
|
14
|
+
before(async () => {
|
|
15
|
+
(0, clean_test_1.cleanTest)();
|
|
16
|
+
require('./mirrorworld');
|
|
17
|
+
require('./wormhole-token-bridge');
|
|
18
|
+
await service.start({}, testContext);
|
|
19
|
+
});
|
|
20
|
+
it('check configuration ', async () => {
|
|
21
|
+
const config = await service.getConfig({}, testContext);
|
|
22
|
+
(0, chai_1.expect)(config.contractConfigs).length(2);
|
|
23
|
+
});
|
|
24
|
+
it('Check mirrorworld instruction dispatch', async () => {
|
|
25
|
+
const request = {
|
|
26
|
+
instructions: [
|
|
27
|
+
{
|
|
28
|
+
instructionData: 'CACadoFwjNvan4GP8gh3Jtm1qdeoKX5j2SbSNEiB',
|
|
29
|
+
slot: long_1.default.fromNumber(0),
|
|
30
|
+
programAccountId: 'F78NhTC9XmP1DKsCBRz5LGdQc4n4yFbj2dURiv7T9gGZ',
|
|
31
|
+
},
|
|
32
|
+
],
|
|
33
|
+
};
|
|
34
|
+
const res = await service.processInstruction(request, testContext);
|
|
35
|
+
(0, chai_1.expect)(res.result?.counters).length(3);
|
|
36
|
+
(0, chai_1.expect)(res.result?.histograms).length(0);
|
|
37
|
+
(0, chai_1.expect)(res.result?.counters[0].metricValue?.bigInt).equal('5000000000');
|
|
38
|
+
});
|
|
39
|
+
it('Check wormhole token bridge instruction dispatch', async () => {
|
|
40
|
+
const request = {
|
|
41
|
+
instructions: [
|
|
42
|
+
{
|
|
43
|
+
instructionData: '33G5T8yXAQWdH8FX7fTy1mBJ6e4dUKfQWbViSrT7qJjpS8UAA3ftEQx9sNzrkaJm56xtENhDsWf',
|
|
44
|
+
slot: long_1.default.fromNumber(0),
|
|
45
|
+
programAccountId: 'wormDTUJ6AWPNvk59vGQbDvGJmqbDTdgWgAqcLBCgUb',
|
|
46
|
+
},
|
|
47
|
+
],
|
|
48
|
+
};
|
|
49
|
+
const res = await service.processInstruction(request, testContext);
|
|
50
|
+
(0, chai_1.expect)(res.result?.counters).length(1);
|
|
51
|
+
(0, chai_1.expect)(res.result?.histograms).length(0);
|
|
52
|
+
(0, chai_1.expect)(res.result?.counters[0].metadata?.blockNumber.toInt()).equal(0);
|
|
53
|
+
(0, chai_1.expect)(res.result?.counters[0].metricValue?.doubleValue).equal(1000000);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
//# sourceMappingURL=solana.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"solana.test.js","sourceRoot":"","sources":["../../src/test-case/solana.test.ts"],"names":[],"mappings":";AAAA,gCAAgC;;;;;AAEhC,+BAA6B;AAE7B,0BAAoE;AAGpE,gDAAuB;AACvB,6CAAwC;AAExC,QAAQ,CAAC,iCAAiC,EAAE,GAAG,EAAE;IAC/C,MAAM,OAAO,GAAG,IAAI,wBAAoB,CAAC,SAAS,CAAC,CAAA;IACnD,MAAM,WAAW,GAA6B,EAAE,CAAA;IAEhD,MAAM,CAAC,KAAK,IAAI,EAAE;QAChB,IAAA,sBAAS,GAAE,CAAA;QAEX,OAAO,CAAC,eAAe,CAAC,CAAA;QACxB,OAAO,CAAC,yBAAyB,CAAC,CAAA;QAClC,MAAM,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,WAAW,CAAC,CAAA;IACtC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,sBAAsB,EAAE,KAAK,IAAI,EAAE;QACpC,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,SAAS,CAAC,EAAE,EAAE,WAAW,CAAC,CAAA;QACvD,IAAA,aAAM,EAAC,MAAM,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;IAC1C,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,OAAO,GAA8B;YACzC,YAAY,EAAE;gBACZ;oBACE,eAAe,EAAE,0CAA0C;oBAC3D,IAAI,EAAE,cAAI,CAAC,UAAU,CAAC,CAAC,CAAC;oBACxB,gBAAgB,EAAE,8CAA8C;iBACjE;aACF;SACF,CAAA;QACD,MAAM,GAAG,GAAG,MAAM,OAAO,CAAC,kBAAkB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAA;QAClE,IAAA,aAAM,EAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;QACtC,IAAA,aAAM,EAAC,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;QACxC,IAAA,aAAM,EAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;IACzE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,kDAAkD,EAAE,KAAK,IAAI,EAAE;QAChE,MAAM,OAAO,GAA8B;YACzC,YAAY,EAAE;gBACZ;oBACE,eAAe,EAAE,6EAA6E;oBAC9F,IAAI,EAAE,cAAI,CAAC,UAAU,CAAC,CAAC,CAAC;oBACxB,gBAAgB,EAAE,6CAA6C;iBAChE;aACF;SACF,CAAA;QACD,MAAM,GAAG,GAAG,MAAM,OAAO,CAAC,kBAAkB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAA;QAClE,IAAA,aAAM,EAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;QACtC,IAAA,aAAM,EAAC,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;QACxC,IAAA,aAAM,EAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;QACtE,IAAA,aAAM,EAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;IACzE,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Context, BaseProcessor, ContractWrapper, ContractNamer } from "@sentio/sdk";
|
|
1
|
+
import { Context, BindOptions, BaseProcessor, BaseProcessorTemplate, ContractWrapper } from "@sentio/sdk";
|
|
3
2
|
import { PromiseOrValue } from "./common";
|
|
4
3
|
import { Erc20 } from "./index";
|
|
5
4
|
import { ApprovalEvent, ApprovalEventFilter, TransferEvent, TransferEventFilter } from "./Erc20";
|
|
@@ -11,18 +10,20 @@ declare class Erc20ContractWrapper extends ContractWrapper<Erc20> {
|
|
|
11
10
|
totalSupply(): Promise<import("ethers").BigNumber>;
|
|
12
11
|
}
|
|
13
12
|
export declare type Erc20Context = Context<Erc20, Erc20ContractWrapper>;
|
|
13
|
+
export declare class Erc20ProcessorTemplate extends BaseProcessorTemplate<Erc20, Erc20ContractWrapper> {
|
|
14
|
+
bindInternal(options: BindOptions): Erc20Processor;
|
|
15
|
+
onApproval(handler: (event: ApprovalEvent, ctx: Erc20Context) => void, filter?: ApprovalEventFilter | ApprovalEventFilter[]): this;
|
|
16
|
+
onTransfer(handler: (event: TransferEvent, ctx: Erc20Context) => void, filter?: TransferEventFilter | TransferEventFilter[]): this;
|
|
17
|
+
}
|
|
14
18
|
export declare class Erc20Processor extends BaseProcessor<Erc20, Erc20ContractWrapper> {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
onTransfer(handler: (event: TransferEvent, ctx: Erc20Context) => void, filter?: TransferEventFilter | TransferEventFilter[]): Erc20Processor;
|
|
18
|
-
private static templateContract;
|
|
19
|
+
onApproval(handler: (event: ApprovalEvent, ctx: Erc20Context) => void, filter?: ApprovalEventFilter | ApprovalEventFilter[]): this;
|
|
20
|
+
onTransfer(handler: (event: TransferEvent, ctx: Erc20Context) => void, filter?: TransferEventFilter | TransferEventFilter[]): this;
|
|
19
21
|
static filters: {
|
|
20
22
|
"Approval(address,address,uint256)"(owner?: PromiseOrValue<string> | null | undefined, spender?: PromiseOrValue<string> | null | undefined, value?: null | undefined): ApprovalEventFilter;
|
|
21
23
|
Approval(owner?: PromiseOrValue<string> | null | undefined, spender?: PromiseOrValue<string> | null | undefined, value?: null | undefined): ApprovalEventFilter;
|
|
22
24
|
"Transfer(address,address,uint256)"(from?: PromiseOrValue<string> | null | undefined, to?: PromiseOrValue<string> | null | undefined, value?: null | undefined): TransferEventFilter;
|
|
23
25
|
Transfer(from?: PromiseOrValue<string> | null | undefined, to?: PromiseOrValue<string> | null | undefined, value?: null | undefined): TransferEventFilter;
|
|
24
26
|
};
|
|
25
|
-
static
|
|
26
|
-
static bind(address: string, network?: Networkish, name?: string): Erc20Processor;
|
|
27
|
+
static bind(options: BindOptions): Erc20Processor;
|
|
27
28
|
}
|
|
28
29
|
export {};
|
|
@@ -3,9 +3,11 @@
|
|
|
3
3
|
/* tslint:disable */
|
|
4
4
|
/* eslint-disable */
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.Erc20Processor = void 0;
|
|
6
|
+
exports.Erc20Processor = exports.Erc20ProcessorTemplate = void 0;
|
|
7
7
|
const sdk_1 = require("@sentio/sdk");
|
|
8
8
|
const index_1 = require("./index");
|
|
9
|
+
const namer = new sdk_1.ContractNamer("Erc20");
|
|
10
|
+
const templateContract = index_1.Erc20__factory.connect("", sdk_1.DummyProvider);
|
|
9
11
|
class Erc20ContractWrapper extends sdk_1.ContractWrapper {
|
|
10
12
|
constructor(contract) {
|
|
11
13
|
super(contract);
|
|
@@ -25,34 +27,56 @@ class Erc20ContractWrapper extends sdk_1.ContractWrapper {
|
|
|
25
27
|
return this.contract.totalSupply({ blockTag: this.block.number });
|
|
26
28
|
}
|
|
27
29
|
}
|
|
28
|
-
class
|
|
29
|
-
bindInternal(
|
|
30
|
-
const contract = index_1.Erc20__factory.connect(address, (0, sdk_1.getProvider)(network));
|
|
31
|
-
|
|
30
|
+
class Erc20ProcessorTemplate extends sdk_1.BaseProcessorTemplate {
|
|
31
|
+
bindInternal(options) {
|
|
32
|
+
const contract = index_1.Erc20__factory.connect(options.address, (0, sdk_1.getProvider)(options.network));
|
|
33
|
+
const wrapper = new Erc20ContractWrapper(contract);
|
|
34
|
+
if (!options.name) {
|
|
35
|
+
options.name = namer.nextName();
|
|
36
|
+
}
|
|
37
|
+
return new Erc20Processor(options, wrapper);
|
|
38
|
+
}
|
|
39
|
+
onApproval(handler, filter) {
|
|
40
|
+
if (!filter) {
|
|
41
|
+
filter = Erc20Processor.filters.Approval(null, null, null);
|
|
42
|
+
}
|
|
43
|
+
super.onEvent(handler, filter);
|
|
44
|
+
return this;
|
|
32
45
|
}
|
|
46
|
+
onTransfer(handler, filter) {
|
|
47
|
+
if (!filter) {
|
|
48
|
+
filter = Erc20Processor.filters.Transfer(null, null, null);
|
|
49
|
+
}
|
|
50
|
+
super.onEvent(handler, filter);
|
|
51
|
+
return this;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
exports.Erc20ProcessorTemplate = Erc20ProcessorTemplate;
|
|
55
|
+
class Erc20Processor extends sdk_1.BaseProcessor {
|
|
33
56
|
onApproval(handler, filter) {
|
|
34
57
|
if (!filter) {
|
|
35
|
-
filter =
|
|
58
|
+
filter = Erc20Processor.filters.Approval(null, null, null);
|
|
36
59
|
}
|
|
37
60
|
super.onEvent(handler, filter);
|
|
38
61
|
return this;
|
|
39
62
|
}
|
|
40
63
|
onTransfer(handler, filter) {
|
|
41
64
|
if (!filter) {
|
|
42
|
-
filter =
|
|
65
|
+
filter = Erc20Processor.filters.Transfer(null, null, null);
|
|
43
66
|
}
|
|
44
67
|
super.onEvent(handler, filter);
|
|
45
68
|
return this;
|
|
46
69
|
}
|
|
47
|
-
static
|
|
48
|
-
static
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
if (name
|
|
52
|
-
name =
|
|
70
|
+
static filters = templateContract.filters;
|
|
71
|
+
static bind(options) {
|
|
72
|
+
const contract = index_1.Erc20__factory.connect(options.address, (0, sdk_1.getProvider)(options.network));
|
|
73
|
+
const wrapper = new Erc20ContractWrapper(contract);
|
|
74
|
+
if (!options.name) {
|
|
75
|
+
options.name = namer.nextName();
|
|
53
76
|
}
|
|
54
|
-
return new Erc20Processor(
|
|
77
|
+
return new Erc20Processor(options, wrapper);
|
|
55
78
|
}
|
|
56
79
|
}
|
|
57
80
|
exports.Erc20Processor = Erc20Processor;
|
|
81
|
+
// export const Erc20Processor = new Erc20ProcessorTemplate("Erc20")
|
|
58
82
|
//# sourceMappingURL=erc20_processor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"erc20_processor.js","sourceRoot":"","sources":["../../../src/test-case/types/erc20_processor.ts"],"names":[],"mappings":";AAAA,+CAA+C;AAC/C,oBAAoB;AACpB,oBAAoB;;;
|
|
1
|
+
{"version":3,"file":"erc20_processor.js","sourceRoot":"","sources":["../../../src/test-case/types/erc20_processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/// <reference types="bn.js" />
|
|
2
|
+
import { Instruction, BN } from '@project-serum/anchor';
|
|
3
|
+
import { SolanaBaseProcessor, SolanaContext } from "@sentio/sdk";
|
|
4
|
+
export declare class GameWalletProcessor extends SolanaBaseProcessor {
|
|
5
|
+
static bind(address: string, endpoint: string, name?: string): GameWalletProcessor;
|
|
6
|
+
decodeInstruction(ins: string): Instruction | null;
|
|
7
|
+
onInitializeTokenConfig(handler: (args: {
|
|
8
|
+
tokenDecimal: number;
|
|
9
|
+
isPaused: boolean;
|
|
10
|
+
canDeposit: boolean;
|
|
11
|
+
canWithdraw: boolean;
|
|
12
|
+
canSpend: boolean;
|
|
13
|
+
canDistribute: boolean;
|
|
14
|
+
isWithdrawServiceFeeEnable: boolean;
|
|
15
|
+
withdrawServiceFeePercentage: BN;
|
|
16
|
+
isSpendServiceFeeEnable: boolean;
|
|
17
|
+
spendServiceFeePercentage: BN;
|
|
18
|
+
isDistributionServiceFeeEnable: boolean;
|
|
19
|
+
distributionServiceFeePercentage: BN;
|
|
20
|
+
isMinWithdrawEnable: boolean;
|
|
21
|
+
isMaxWithdrawEnable: boolean;
|
|
22
|
+
minWithdraw: BN;
|
|
23
|
+
maxWithdraw: BN;
|
|
24
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
25
|
+
onDeposit(handler: (args: {
|
|
26
|
+
tokenConfigBump: number;
|
|
27
|
+
depositPoolBump: number;
|
|
28
|
+
depositPoolTokenAccountBump: number;
|
|
29
|
+
amount: BN;
|
|
30
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
31
|
+
onWithdraw(handler: (args: {
|
|
32
|
+
tokenConfigBump: number;
|
|
33
|
+
depositPoolBump: number;
|
|
34
|
+
depositPoolTokenAccountBump: number;
|
|
35
|
+
userTokenConfigBump: number;
|
|
36
|
+
amount: BN;
|
|
37
|
+
nonce: BN;
|
|
38
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
39
|
+
onSpend(handler: (args: {
|
|
40
|
+
tokenConfigBump: number;
|
|
41
|
+
depositPoolBump: number;
|
|
42
|
+
depositPoolTokenAccountBump: number;
|
|
43
|
+
userTokenConfigBump: number;
|
|
44
|
+
amount: BN;
|
|
45
|
+
nonce: BN;
|
|
46
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
47
|
+
onSpendWithoutUser(handler: (args: {
|
|
48
|
+
tokenConfigBump: number;
|
|
49
|
+
depositPoolBump: number;
|
|
50
|
+
depositPoolTokenAccountBump: number;
|
|
51
|
+
userTokenConfigBump: number;
|
|
52
|
+
amount: BN;
|
|
53
|
+
nonce: BN;
|
|
54
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
55
|
+
onAddDistributeSupply(handler: (args: {
|
|
56
|
+
tokenConfigBump: number;
|
|
57
|
+
distributionPoolBump: number;
|
|
58
|
+
distributionPoolTokenAccountBump: number;
|
|
59
|
+
amount: BN;
|
|
60
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
61
|
+
onDistribute(handler: (args: {
|
|
62
|
+
tokenConfigBump: number;
|
|
63
|
+
depositPoolBump: number;
|
|
64
|
+
depositPoolTokenAccountBump: number;
|
|
65
|
+
distributionPoolBump: number;
|
|
66
|
+
distributionPoolTokenAccountBump: number;
|
|
67
|
+
amount: BN;
|
|
68
|
+
nonce: BN;
|
|
69
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
70
|
+
onDistributeWithoutUser(handler: (args: {
|
|
71
|
+
tokenConfigBump: number;
|
|
72
|
+
depositPoolBump: number;
|
|
73
|
+
depositPoolTokenAccountBump: number;
|
|
74
|
+
distributionPoolBump: number;
|
|
75
|
+
distributionPoolTokenAccountBump: number;
|
|
76
|
+
amount: BN;
|
|
77
|
+
nonce: BN;
|
|
78
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
79
|
+
onUpdateTokenConfig(handler: (args: {
|
|
80
|
+
tokenConfigBump: number;
|
|
81
|
+
tokenDecimal: number;
|
|
82
|
+
isPaused: boolean;
|
|
83
|
+
canDeposit: boolean;
|
|
84
|
+
canWithdraw: boolean;
|
|
85
|
+
canSpend: boolean;
|
|
86
|
+
canDistribute: boolean;
|
|
87
|
+
isWithdrawServiceFeeEnable: boolean;
|
|
88
|
+
withdrawServiceFeePercentage: BN;
|
|
89
|
+
isSpendServiceFeeEnable: boolean;
|
|
90
|
+
spendServiceFeePercentage: BN;
|
|
91
|
+
isDistributionServiceFeeEnable: boolean;
|
|
92
|
+
distributionServiceFeePercentage: BN;
|
|
93
|
+
isMinWithdrawEnable: boolean;
|
|
94
|
+
isMaxWithdrawEnable: boolean;
|
|
95
|
+
minWithdraw: BN;
|
|
96
|
+
maxWithdraw: BN;
|
|
97
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
98
|
+
onUpdateUserTokenConfig(handler: (args: {
|
|
99
|
+
tokenConfigBump: number;
|
|
100
|
+
userTokenConfigBump: number;
|
|
101
|
+
isActive: boolean;
|
|
102
|
+
canDeposit: boolean;
|
|
103
|
+
canWithdraw: boolean;
|
|
104
|
+
canSpend: boolean;
|
|
105
|
+
canDistribute: boolean;
|
|
106
|
+
}, ctx: SolanaContext) => void): GameWalletProcessor;
|
|
107
|
+
}
|