@sentio/sdk 0.6.3 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/base-processor-template.d.ts +20 -0
- package/dist/base-processor-template.js +75 -0
- package/dist/base-processor-template.js.map +1 -0
- package/dist/base-processor.d.ts +22 -0
- package/dist/base-processor.js +103 -0
- package/dist/base-processor.js.map +1 -0
- package/dist/bind-options.d.ts +17 -0
- package/dist/bind-options.js +38 -0
- package/dist/bind-options.js.map +1 -0
- package/dist/binds.d.ts +10 -0
- package/dist/binds.js +58 -0
- package/dist/binds.js.map +1 -0
- package/dist/builtin/erc20/index.d.ts +2 -0
- package/dist/builtin/erc20/index.js +22 -0
- package/dist/builtin/erc20/index.js.map +1 -0
- package/dist/builtin/internal/Erc20.d.ts +150 -0
- package/dist/builtin/internal/Erc20.js +3 -0
- package/dist/builtin/internal/Erc20.js.map +1 -0
- package/dist/builtin/internal/common.d.ts +22 -0
- package/dist/builtin/internal/common.js +3 -0
- package/dist/builtin/internal/common.js.map +1 -0
- package/dist/builtin/internal/erc20_processor.d.ts +38 -0
- package/dist/builtin/internal/erc20_processor.js +209 -0
- package/dist/builtin/internal/erc20_processor.js.map +1 -0
- package/dist/builtin/internal/factories/Erc20__factory.d.ts +35 -0
- package/dist/builtin/internal/factories/Erc20__factory.js +216 -0
- package/dist/builtin/internal/factories/Erc20__factory.js.map +1 -0
- package/dist/builtin/internal/factories/index.d.ts +1 -0
- package/dist/builtin/internal/factories/index.js +9 -0
- package/dist/builtin/internal/factories/index.js.map +1 -0
- package/dist/builtin/internal/index.d.ts +3 -0
- package/dist/builtin/internal/index.js +30 -0
- package/dist/builtin/internal/index.js.map +1 -0
- package/dist/cli/build.d.ts +3 -0
- package/dist/cli/build.js +161 -0
- package/dist/cli/build.js.map +1 -0
- package/dist/cli/cli.d.ts +2 -0
- package/dist/cli/cli.js +212 -0
- package/dist/cli/cli.js.map +1 -0
- package/dist/cli/config.d.ts +14 -0
- package/dist/cli/config.js +24 -0
- package/dist/cli/config.js.map +1 -0
- package/dist/cli/key.d.ts +2 -0
- package/dist/cli/key.js +44 -0
- package/dist/cli/key.js.map +1 -0
- 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.d.ts +2 -0
- package/dist/cli/upload.js +76 -0
- package/dist/cli/upload.js.map +1 -0
- package/dist/cli/webpack.config.js +41 -0
- package/dist/context.d.ts +39 -0
- package/dist/context.js +75 -0
- package/dist/context.js.map +1 -0
- package/dist/contract-namer.d.ts +6 -0
- package/dist/contract-namer.js +20 -0
- package/dist/contract-namer.js.map +1 -0
- package/dist/error.d.ts +2 -0
- package/dist/error.js +39 -0
- package/dist/error.js.map +1 -0
- package/dist/gen/builtin.d.ts +6 -0
- package/dist/gen/builtin.js +3 -0
- package/dist/gen/builtin.js.map +1 -0
- package/dist/gen/google/protobuf/empty.d.ts +16 -0
- package/dist/gen/google/protobuf/empty.js +47 -0
- package/dist/gen/google/protobuf/empty.js.map +1 -0
- package/dist/gen/processor/protos/processor.d.ts +598 -0
- package/dist/gen/processor/protos/processor.js +2424 -0
- package/dist/gen/processor/protos/processor.js.map +1 -0
- package/dist/index.d.ts +13 -0
- package/dist/index.js +54 -0
- package/dist/index.js.map +1 -0
- package/dist/meter.d.ts +25 -0
- package/dist/meter.js +114 -0
- package/dist/meter.js.map +1 -0
- package/dist/numberish.d.ts +7 -0
- package/dist/numberish.js +74 -0
- package/dist/numberish.js.map +1 -0
- package/dist/numberish.test.d.ts +1 -0
- package/dist/numberish.test.js +54 -0
- package/dist/numberish.test.js.map +1 -0
- package/dist/processor-runner.d.ts +2 -0
- package/dist/processor-runner.js +67 -0
- package/dist/processor-runner.js.map +1 -0
- package/dist/processor-state.d.ts +16 -0
- package/dist/processor-state.js +20 -0
- package/dist/processor-state.js.map +1 -0
- package/dist/provider.d.ts +5 -0
- package/dist/provider.js +56 -0
- package/dist/provider.js.map +1 -0
- package/dist/service.d.ts +22 -0
- package/dist/service.js +361 -0
- package/dist/service.js.map +1 -0
- package/dist/solana/builtin/spl-token-processor.d.ts +25 -0
- package/dist/solana/builtin/spl-token-processor.js +152 -0
- package/dist/solana/builtin/spl-token-processor.js.map +1 -0
- package/dist/solana-processor.d.ts +28 -0
- package/dist/solana-processor.js +79 -0
- package/dist/solana-processor.js.map +1 -0
- package/dist/target-ethers-sentio/codegen.d.ts +3 -0
- package/dist/target-ethers-sentio/codegen.js +201 -0
- package/dist/target-ethers-sentio/codegen.js.map +1 -0
- package/dist/target-ethers-sentio/index.d.ts +6 -0
- package/dist/target-ethers-sentio/index.js +47 -0
- package/dist/target-ethers-sentio/index.js.map +1 -0
- package/dist/test-case/clean-test.d.ts +1 -0
- package/dist/test-case/clean-test.js +9 -0
- package/dist/test-case/clean-test.js.map +1 -0
- package/dist/test-case/erc20-template.d.ts +1 -0
- package/dist/test-case/erc20-template.js +23 -0
- package/dist/test-case/erc20-template.js.map +1 -0
- package/dist/test-case/erc20-template.test.d.ts +1 -0
- package/dist/test-case/erc20-template.test.js +69 -0
- package/dist/test-case/erc20-template.test.js.map +1 -0
- package/dist/test-case/erc20.d.ts +1 -0
- package/dist/test-case/erc20.js +42 -0
- package/dist/test-case/erc20.js.map +1 -0
- package/dist/test-case/erc20.test.d.ts +1 -0
- package/dist/test-case/erc20.test.js +154 -0
- package/dist/test-case/erc20.test.js.map +1 -0
- package/dist/test-case/mirrorworld.d.ts +1 -0
- package/dist/test-case/mirrorworld.js +42 -0
- package/dist/test-case/mirrorworld.js.map +1 -0
- package/dist/test-case/solana.test.d.ts +1 -0
- package/dist/test-case/solana.test.js +58 -0
- package/dist/test-case/solana.test.js.map +1 -0
- package/dist/test-case/types/game_wallet.d.ts +45 -0
- package/dist/test-case/types/game_wallet.js +1396 -0
- package/dist/test-case/types/game_wallet.js.map +1 -0
- 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/dist/utils/chainmap.d.ts +4 -0
- package/dist/utils/chainmap.js +95 -0
- package/dist/utils/chainmap.js.map +1 -0
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +6 -0
- package/dist/utils/index.js.map +1 -0
- package/package.json +4 -2
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { BoundContractView, Context, ContractView } from './context';
|
|
2
|
+
import { Block } from '@ethersproject/abstract-provider';
|
|
3
|
+
import { BaseContract, EventFilter } from 'ethers';
|
|
4
|
+
import { Event } from '@ethersproject/contracts';
|
|
5
|
+
import { BaseProcessor } from './base-processor';
|
|
6
|
+
import { BindOptions } from './bind-options';
|
|
7
|
+
export declare abstract class BaseProcessorTemplate<TContract extends BaseContract, TBoundTContractView extends BoundContractView<TContract, ContractView<TContract>>> {
|
|
8
|
+
id: number;
|
|
9
|
+
binds: Set<string>;
|
|
10
|
+
blockHandlers: ((block: Block, ctx: Context<TContract, TBoundTContractView>) => void)[];
|
|
11
|
+
eventHandlers: {
|
|
12
|
+
handler: (event: Event, ctx: Context<TContract, TBoundTContractView>) => void;
|
|
13
|
+
filter: EventFilter | EventFilter[];
|
|
14
|
+
}[];
|
|
15
|
+
constructor();
|
|
16
|
+
bind(options: BindOptions): BaseProcessor<TContract, TBoundTContractView> | undefined;
|
|
17
|
+
onEvent(handler: (event: Event, ctx: Context<TContract, TBoundTContractView>) => void, filter: EventFilter | EventFilter[]): this;
|
|
18
|
+
onBlock(handler: (block: Block, ctx: Context<TContract, TBoundTContractView>) => void): this;
|
|
19
|
+
protected abstract bindInternal(options: BindOptions): BaseProcessor<TContract, TBoundTContractView>;
|
|
20
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.BaseProcessorTemplate = void 0;
|
|
7
|
+
const bind_options_1 = require("./bind-options");
|
|
8
|
+
const long_1 = __importDefault(require("long"));
|
|
9
|
+
const providers_1 = require("@ethersproject/providers");
|
|
10
|
+
class BaseProcessorTemplate {
|
|
11
|
+
id;
|
|
12
|
+
binds = new Set();
|
|
13
|
+
blockHandlers = [];
|
|
14
|
+
eventHandlers = [];
|
|
15
|
+
constructor() {
|
|
16
|
+
this.id = global.PROCESSOR_STATE.templates.length;
|
|
17
|
+
global.PROCESSOR_STATE.templates.push(this);
|
|
18
|
+
}
|
|
19
|
+
bind(options) {
|
|
20
|
+
const sig = (0, bind_options_1.getOptionsSignature)(options);
|
|
21
|
+
if (this.binds.has(sig)) {
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
this.binds.add(sig);
|
|
25
|
+
const processor = this.bindInternal(options);
|
|
26
|
+
for (const eh of this.eventHandlers) {
|
|
27
|
+
processor.onEvent(eh.handler, eh.filter);
|
|
28
|
+
}
|
|
29
|
+
for (const bh of this.blockHandlers) {
|
|
30
|
+
processor.onBlock(bh);
|
|
31
|
+
}
|
|
32
|
+
const instance = {
|
|
33
|
+
templateId: this.id,
|
|
34
|
+
contract: {
|
|
35
|
+
address: options.address,
|
|
36
|
+
name: options.name || '',
|
|
37
|
+
chainId: options.network ? (0, providers_1.getNetwork)(options.network).chainId.toString() : '1',
|
|
38
|
+
abi: '',
|
|
39
|
+
},
|
|
40
|
+
startBlock: long_1.default.ZERO,
|
|
41
|
+
endBlock: long_1.default.ZERO,
|
|
42
|
+
};
|
|
43
|
+
if (options.startBlock) {
|
|
44
|
+
if (typeof options.startBlock === 'number') {
|
|
45
|
+
instance.startBlock = long_1.default.fromNumber(options.startBlock);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
instance.startBlock = options.startBlock;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
if (options.endBlock) {
|
|
52
|
+
if (typeof options.endBlock === 'number') {
|
|
53
|
+
instance.endBlock = long_1.default.fromNumber(options.endBlock);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
instance.endBlock = options.endBlock;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
global.PROCESSOR_STATE.templatesInstances.push(instance);
|
|
60
|
+
return processor;
|
|
61
|
+
}
|
|
62
|
+
onEvent(handler, filter) {
|
|
63
|
+
this.eventHandlers.push({
|
|
64
|
+
handler: handler,
|
|
65
|
+
filter: filter,
|
|
66
|
+
});
|
|
67
|
+
return this;
|
|
68
|
+
}
|
|
69
|
+
onBlock(handler) {
|
|
70
|
+
this.blockHandlers.push(handler);
|
|
71
|
+
return this;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
exports.BaseProcessorTemplate = BaseProcessorTemplate;
|
|
75
|
+
//# sourceMappingURL=base-processor-template.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-processor-template.js","sourceRoot":"","sources":["../src/base-processor-template.ts"],"names":[],"mappings":";;;;;;AAKA,iDAAiE;AAEjE,gDAAuB;AACvB,wDAAqD;AAErD,MAAsB,qBAAqB;IAIzC,EAAE,CAAQ;IACV,KAAK,GAAG,IAAI,GAAG,EAAU,CAAA;IACzB,aAAa,GAA6E,EAAE,CAAA;IAC5F,aAAa,GAGP,EAAE,CAAA;IAER;QACE,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,CAAA;QACjD,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC7C,CAAC;IAEM,IAAI,CAAC,OAAoB;QAC9B,MAAM,GAAG,GAAG,IAAA,kCAAmB,EAAC,OAAO,CAAC,CAAA;QACxC,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YACvB,OAAM;SACP;QACD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAEnB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAA;QAE5C,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE;YACnC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,MAAM,CAAC,CAAA;SACzC;QACD,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE;YACnC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;SACtB;QAED,MAAM,QAAQ,GAAqB;YACjC,UAAU,EAAE,IAAI,CAAC,EAAE;YACnB,QAAQ,EAAE;gBACR,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,EAAE;gBACxB,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAA,sBAAU,EAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,GAAG;gBAC/E,GAAG,EAAE,EAAE;aACR;YACD,UAAU,EAAE,cAAI,CAAC,IAAI;YACrB,QAAQ,EAAE,cAAI,CAAC,IAAI;SACpB,CAAA;QACD,IAAI,OAAO,CAAC,UAAU,EAAE;YACtB,IAAI,OAAO,OAAO,CAAC,UAAU,KAAK,QAAQ,EAAE;gBAC1C,QAAQ,CAAC,UAAU,GAAG,cAAI,CAAC,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,CAAA;aAC1D;iBAAM;gBACL,QAAQ,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAA;aACzC;SACF;QACD,IAAI,OAAO,CAAC,QAAQ,EAAE;YACpB,IAAI,OAAO,OAAO,CAAC,QAAQ,KAAK,QAAQ,EAAE;gBACxC,QAAQ,CAAC,QAAQ,GAAG,cAAI,CAAC,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;aACtD;iBAAM;gBACL,QAAQ,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAA;aACrC;SACF;QACD,MAAM,CAAC,eAAe,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAExD,OAAO,SAAS,CAAA;IAClB,CAAC;IAEM,OAAO,CACZ,OAA6E,EAC7E,MAAmC;QAEnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;YACtB,OAAO,EAAE,OAAO;YAChB,MAAM,EAAE,MAAM;SACf,CAAC,CAAA;QACF,OAAO,IAAI,CAAA;IACb,CAAC;IAEM,OAAO,CAAC,OAA6E;QAC1F,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAChC,OAAO,IAAI,CAAA;IACb,CAAC;CAGF;AAhFD,sDAgFC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { BoundContractView, Context, ContractView } from './context';
|
|
2
|
+
import { Block, Log } from '@ethersproject/abstract-provider';
|
|
3
|
+
import { BaseContract, EventFilter } from 'ethers';
|
|
4
|
+
import { Event } from '@ethersproject/contracts';
|
|
5
|
+
import { O11yResult } from './gen/processor/protos/processor';
|
|
6
|
+
import { BindInternalOptions, BindOptions } from './bind-options';
|
|
7
|
+
declare class EventsHandler {
|
|
8
|
+
filters: EventFilter[];
|
|
9
|
+
handler: (event: Log) => Promise<O11yResult>;
|
|
10
|
+
}
|
|
11
|
+
export declare abstract class BaseProcessor<TContract extends BaseContract, TBoundContractView extends BoundContractView<TContract, ContractView<TContract>>> {
|
|
12
|
+
blockHandlers: ((block: Block) => Promise<O11yResult>)[];
|
|
13
|
+
eventHandlers: EventsHandler[];
|
|
14
|
+
name: string;
|
|
15
|
+
config: BindInternalOptions;
|
|
16
|
+
constructor(config: BindOptions);
|
|
17
|
+
protected abstract CreateBoundContractView(): TBoundContractView;
|
|
18
|
+
getChainId(): string;
|
|
19
|
+
onEvent(handler: (event: Event, ctx: Context<TContract, TBoundContractView>) => void, filter: EventFilter | EventFilter[]): this;
|
|
20
|
+
onBlock(handler: (block: Block, ctx: Context<TContract, TBoundContractView>) => void): this;
|
|
21
|
+
}
|
|
22
|
+
export {};
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.BaseProcessor = void 0;
|
|
7
|
+
const context_1 = require("./context");
|
|
8
|
+
const long_1 = __importDefault(require("long"));
|
|
9
|
+
const providers_1 = require("@ethersproject/providers");
|
|
10
|
+
class EventsHandler {
|
|
11
|
+
filters;
|
|
12
|
+
handler;
|
|
13
|
+
}
|
|
14
|
+
class BaseProcessor {
|
|
15
|
+
blockHandlers = [];
|
|
16
|
+
eventHandlers = [];
|
|
17
|
+
name;
|
|
18
|
+
config;
|
|
19
|
+
constructor(config) {
|
|
20
|
+
this.config = {
|
|
21
|
+
address: config.address,
|
|
22
|
+
name: config.name || '',
|
|
23
|
+
network: config.network ? config.network : 1,
|
|
24
|
+
startBlock: new long_1.default(0),
|
|
25
|
+
};
|
|
26
|
+
if (config.startBlock) {
|
|
27
|
+
if (typeof config.startBlock === 'number') {
|
|
28
|
+
this.config.startBlock = long_1.default.fromNumber(config.startBlock);
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
this.config.startBlock = config.startBlock;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
if (config.endBlock) {
|
|
35
|
+
if (typeof config.endBlock === 'number') {
|
|
36
|
+
this.config.endBlock = long_1.default.fromNumber(config.endBlock);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
this.config.endBlock = config.endBlock;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
// public isBind() {
|
|
44
|
+
// return this.contract.rawContract.address !== ''
|
|
45
|
+
// }
|
|
46
|
+
getChainId() {
|
|
47
|
+
return (0, providers_1.getNetwork)(this.config.network).chainId.toString();
|
|
48
|
+
}
|
|
49
|
+
onEvent(handler, filter) {
|
|
50
|
+
const chainId = this.getChainId();
|
|
51
|
+
let _filters = [];
|
|
52
|
+
if (Array.isArray(filter)) {
|
|
53
|
+
_filters = filter;
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
_filters.push(filter);
|
|
57
|
+
}
|
|
58
|
+
const contractView = this.CreateBoundContractView();
|
|
59
|
+
this.eventHandlers.push({
|
|
60
|
+
filters: _filters,
|
|
61
|
+
handler: async function (log) {
|
|
62
|
+
const ctx = new context_1.Context(contractView, chainId, undefined, log);
|
|
63
|
+
// let event: Event = <Event>deepCopy(log);
|
|
64
|
+
const event = log;
|
|
65
|
+
const parsed = contractView.rawContract.interface.parseLog(log);
|
|
66
|
+
if (parsed) {
|
|
67
|
+
event.args = parsed.args;
|
|
68
|
+
event.decode = (data, topics) => {
|
|
69
|
+
return contractView.rawContract.interface.decodeEventLog(parsed.eventFragment, data, topics);
|
|
70
|
+
};
|
|
71
|
+
event.event = parsed.name;
|
|
72
|
+
event.eventSignature = parsed.signature;
|
|
73
|
+
// TODO fix this bug
|
|
74
|
+
await handler(event, ctx);
|
|
75
|
+
return {
|
|
76
|
+
gauges: ctx.gauges,
|
|
77
|
+
counters: ctx.counters,
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
return {
|
|
81
|
+
gauges: [],
|
|
82
|
+
counters: [],
|
|
83
|
+
};
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
return this;
|
|
87
|
+
}
|
|
88
|
+
onBlock(handler) {
|
|
89
|
+
const chainId = this.getChainId();
|
|
90
|
+
const contractView = this.CreateBoundContractView();
|
|
91
|
+
this.blockHandlers.push(async function (block) {
|
|
92
|
+
const ctx = new context_1.Context(contractView, chainId, block, undefined);
|
|
93
|
+
await handler(block, ctx);
|
|
94
|
+
return {
|
|
95
|
+
gauges: ctx.gauges,
|
|
96
|
+
counters: ctx.counters,
|
|
97
|
+
};
|
|
98
|
+
});
|
|
99
|
+
return this;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
exports.BaseProcessor = BaseProcessor;
|
|
103
|
+
//# sourceMappingURL=base-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-processor.js","sourceRoot":"","sources":["../src/base-processor.ts"],"names":[],"mappings":";;;;;;AAAA,uCAAoE;AAMpE,gDAAuB;AAEvB,wDAAqD;AAErD,MAAM,aAAa;IACjB,OAAO,CAAe;IACtB,OAAO,CAAqC;CAC7C;AAED,MAAsB,aAAa;IAIjC,aAAa,GAA8C,EAAE,CAAA;IAC7D,aAAa,GAAoB,EAAE,CAAA;IAEnC,IAAI,CAAQ;IACZ,MAAM,CAAqB;IAE3B,YAAY,MAAmB;QAC7B,IAAI,CAAC,MAAM,GAAG;YACZ,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,EAAE;YACvB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC5C,UAAU,EAAE,IAAI,cAAI,CAAC,CAAC,CAAC;SACxB,CAAA;QACD,IAAI,MAAM,CAAC,UAAU,EAAE;YACrB,IAAI,OAAO,MAAM,CAAC,UAAU,KAAK,QAAQ,EAAE;gBACzC,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,cAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;aAC5D;iBAAM;gBACL,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAA;aAC3C;SACF;QACD,IAAI,MAAM,CAAC,QAAQ,EAAE;YACnB,IAAI,OAAO,MAAM,CAAC,QAAQ,KAAK,QAAQ,EAAE;gBACvC,IAAI,CAAC,MAAM,CAAC,QAAQ,GAAG,cAAI,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;aACxD;iBAAM;gBACL,IAAI,CAAC,MAAM,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAA;aACvC;SACF;IACH,CAAC;IAID,oBAAoB;IACpB,oDAAoD;IACpD,IAAI;IAEG,UAAU;QACf,OAAO,IAAA,sBAAU,EAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAA;IAC3D,CAAC;IAEM,OAAO,CACZ,OAA4E,EAC5E,MAAmC;QAEnC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;QAEjC,IAAI,QAAQ,GAAkB,EAAE,CAAA;QAEhC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACzB,QAAQ,GAAG,MAAM,CAAA;SAClB;aAAM;YACL,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;SACtB;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAA;QACnD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;YACtB,OAAO,EAAE,QAAQ;YACjB,OAAO,EAAE,KAAK,WAAW,GAAG;gBAC1B,MAAM,GAAG,GAAG,IAAI,iBAAO,CAAgC,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,CAAC,CAAA;gBAC7F,2CAA2C;gBAC3C,MAAM,KAAK,GAAiB,GAAG,CAAA;gBAE/B,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;gBAC/D,IAAI,MAAM,EAAE;oBACV,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;oBACxB,KAAK,CAAC,MAAM,GAAG,CAAC,IAAe,EAAE,MAAmB,EAAE,EAAE;wBACtD,OAAO,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,CAAC,aAAa,EAAE,IAAI,EAAE,MAAM,CAAC,CAAA;oBAC9F,CAAC,CAAA;oBACD,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAA;oBACzB,KAAK,CAAC,cAAc,GAAG,MAAM,CAAC,SAAS,CAAA;oBAEvC,oBAAoB;oBACpB,MAAM,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;oBACzB,OAAO;wBACL,MAAM,EAAE,GAAG,CAAC,MAAM;wBAClB,QAAQ,EAAE,GAAG,CAAC,QAAQ;qBACvB,CAAA;iBACF;gBACD,OAAO;oBACL,MAAM,EAAE,EAAE;oBACV,QAAQ,EAAE,EAAE;iBACb,CAAA;YACH,CAAC;SACF,CAAC,CAAA;QACF,OAAO,IAAI,CAAA;IACb,CAAC;IAEM,OAAO,CAAC,OAA4E;QACzF,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;QACjC,MAAM,YAAY,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAA;QAEnD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,WAAW,KAAY;YAClD,MAAM,GAAG,GAAG,IAAI,iBAAO,CAAgC,YAAY,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,CAAC,CAAA;YAC/F,MAAM,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;YACzB,OAAO;gBACL,MAAM,EAAE,GAAG,CAAC,MAAM;gBAClB,QAAQ,EAAE,GAAG,CAAC,QAAQ;aACvB,CAAA;QACH,CAAC,CAAC,CAAA;QACF,OAAO,IAAI,CAAA;IACb,CAAC;CACF;AAxGD,sCAwGC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Networkish } from '@ethersproject/networks';
|
|
2
|
+
import Long from 'long';
|
|
3
|
+
export declare class BindOptions {
|
|
4
|
+
address: string;
|
|
5
|
+
network?: Networkish;
|
|
6
|
+
name?: string;
|
|
7
|
+
startBlock?: Long | number;
|
|
8
|
+
endBlock?: Long | number;
|
|
9
|
+
}
|
|
10
|
+
export declare function getOptionsSignature(opts: BindOptions): string;
|
|
11
|
+
export declare class BindInternalOptions {
|
|
12
|
+
address: string;
|
|
13
|
+
network: Networkish;
|
|
14
|
+
name: string;
|
|
15
|
+
startBlock: Long;
|
|
16
|
+
endBlock?: Long;
|
|
17
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BindInternalOptions = exports.getOptionsSignature = exports.BindOptions = void 0;
|
|
4
|
+
const providers_1 = require("@ethersproject/providers");
|
|
5
|
+
class BindOptions {
|
|
6
|
+
address;
|
|
7
|
+
network = 1;
|
|
8
|
+
name;
|
|
9
|
+
startBlock;
|
|
10
|
+
endBlock;
|
|
11
|
+
}
|
|
12
|
+
exports.BindOptions = BindOptions;
|
|
13
|
+
function getOptionsSignature(opts) {
|
|
14
|
+
const sig = [opts.address];
|
|
15
|
+
if (opts.network) {
|
|
16
|
+
sig.push((0, providers_1.getNetwork)(opts.network).chainId.toString());
|
|
17
|
+
}
|
|
18
|
+
if (opts.name) {
|
|
19
|
+
sig.push(opts.name);
|
|
20
|
+
}
|
|
21
|
+
if (opts.startBlock) {
|
|
22
|
+
sig.push(opts.startBlock.toString());
|
|
23
|
+
}
|
|
24
|
+
if (opts.endBlock) {
|
|
25
|
+
sig.push(opts.endBlock.toString());
|
|
26
|
+
}
|
|
27
|
+
return sig.join('_');
|
|
28
|
+
}
|
|
29
|
+
exports.getOptionsSignature = getOptionsSignature;
|
|
30
|
+
class BindInternalOptions {
|
|
31
|
+
address;
|
|
32
|
+
network;
|
|
33
|
+
name;
|
|
34
|
+
startBlock;
|
|
35
|
+
endBlock;
|
|
36
|
+
}
|
|
37
|
+
exports.BindInternalOptions = BindInternalOptions;
|
|
38
|
+
//# sourceMappingURL=bind-options.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bind-options.js","sourceRoot":"","sources":["../src/bind-options.ts"],"names":[],"mappings":";;;AAEA,wDAAqD;AAErD,MAAa,WAAW;IACtB,OAAO,CAAQ;IACf,OAAO,GAAgB,CAAC,CAAA;IACxB,IAAI,CAAS;IACb,UAAU,CAAgB;IAC1B,QAAQ,CAAgB;CACzB;AAND,kCAMC;AAED,SAAgB,mBAAmB,CAAC,IAAiB;IACnD,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IAC1B,IAAI,IAAI,CAAC,OAAO,EAAE;QAChB,GAAG,CAAC,IAAI,CAAC,IAAA,sBAAU,EAAC,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAA;KACtD;IACD,IAAI,IAAI,CAAC,IAAI,EAAE;QACb,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;KACpB;IACD,IAAI,IAAI,CAAC,UAAU,EAAE;QACnB,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAA;KACrC;IACD,IAAI,IAAI,CAAC,QAAQ,EAAE;QACjB,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAA;KACnC;IACD,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;AACtB,CAAC;AAfD,kDAeC;AAED,MAAa,mBAAmB;IAC9B,OAAO,CAAQ;IACf,OAAO,CAAY;IACnB,IAAI,CAAQ;IACZ,UAAU,CAAM;IAChB,QAAQ,CAAO;CAChB;AAND,kDAMC"}
|
package/dist/binds.d.ts
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { BindOptions } from './bind-options';
|
|
2
|
+
import { BaseProcessor } from './base-processor';
|
|
3
|
+
import { Networkish } from '@ethersproject/networks';
|
|
4
|
+
import { ContractView } from './context';
|
|
5
|
+
import { BaseContract } from 'ethers';
|
|
6
|
+
export declare function getContractName(abiName: string, contractName: string | undefined, address: string, network?: Networkish): string;
|
|
7
|
+
export declare function getProcessor(abiName: string, opts: BindOptions): BaseProcessor<any, any> | undefined;
|
|
8
|
+
export declare function addProcessor(abiName: string, opts: BindOptions, processor: BaseProcessor<any, any>): void;
|
|
9
|
+
export declare function getContractByABI(abiName: string, address: string, network: Networkish): ContractView<BaseContract> | undefined;
|
|
10
|
+
export declare function addContractByABI(abiName: string, address: string, network: Networkish, contract: ContractView<BaseContract>): Map<string, ContractView<BaseContract>>;
|
package/dist/binds.js
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.addContractByABI = exports.getContractByABI = exports.addProcessor = exports.getProcessor = exports.getContractName = void 0;
|
|
4
|
+
const bind_options_1 = require("./bind-options");
|
|
5
|
+
const providers_1 = require("@ethersproject/providers");
|
|
6
|
+
const contract_namer_1 = require("./contract-namer");
|
|
7
|
+
function getKey(abiName, address, network) {
|
|
8
|
+
const chainId = (0, providers_1.getNetwork)(network).chainId.toString();
|
|
9
|
+
return [abiName, address.toLowerCase(), chainId].join('_');
|
|
10
|
+
}
|
|
11
|
+
const addressToName = new Map();
|
|
12
|
+
const namerMap = new Map();
|
|
13
|
+
// Get contract name by ABI, and other options
|
|
14
|
+
// If there is contract using same ABI and different (address, network) pair
|
|
15
|
+
// It will be renamed as ABI, ABI_1, ABI_2
|
|
16
|
+
// Otherwise just use same contract name
|
|
17
|
+
function getContractName(abiName, contractName, address, network = 1) {
|
|
18
|
+
const key = getKey(abiName, address, network);
|
|
19
|
+
let name = addressToName.get(key);
|
|
20
|
+
if (name) {
|
|
21
|
+
return name;
|
|
22
|
+
}
|
|
23
|
+
if (contractName) {
|
|
24
|
+
addressToName.set(key, contractName);
|
|
25
|
+
return contractName;
|
|
26
|
+
}
|
|
27
|
+
let namer = namerMap.get(abiName);
|
|
28
|
+
if (!namer) {
|
|
29
|
+
namer = new contract_namer_1.ContractNamer(abiName);
|
|
30
|
+
namerMap.set(abiName, namer);
|
|
31
|
+
}
|
|
32
|
+
name = namer.nextName();
|
|
33
|
+
addressToName.set(key, name);
|
|
34
|
+
return name;
|
|
35
|
+
}
|
|
36
|
+
exports.getContractName = getContractName;
|
|
37
|
+
function getProcessor(abiName, opts) {
|
|
38
|
+
const sig = abiName + '_' + (0, bind_options_1.getOptionsSignature)(opts);
|
|
39
|
+
return global.PROCESSOR_STATE.processorMap.get(sig);
|
|
40
|
+
}
|
|
41
|
+
exports.getProcessor = getProcessor;
|
|
42
|
+
function addProcessor(abiName, opts, processor) {
|
|
43
|
+
const sig = abiName + '_' + (0, bind_options_1.getOptionsSignature)(opts);
|
|
44
|
+
global.PROCESSOR_STATE.processors.push(processor);
|
|
45
|
+
global.PROCESSOR_STATE.processorMap.set(sig, processor);
|
|
46
|
+
}
|
|
47
|
+
exports.addProcessor = addProcessor;
|
|
48
|
+
function getContractByABI(abiName, address, network) {
|
|
49
|
+
const key = getKey(abiName, address, network);
|
|
50
|
+
return global.PROCESSOR_STATE.contracts.get(key);
|
|
51
|
+
}
|
|
52
|
+
exports.getContractByABI = getContractByABI;
|
|
53
|
+
function addContractByABI(abiName, address, network, contract) {
|
|
54
|
+
const key = getKey(abiName, address, network);
|
|
55
|
+
return global.PROCESSOR_STATE.contracts.set(key, contract);
|
|
56
|
+
}
|
|
57
|
+
exports.addContractByABI = addContractByABI;
|
|
58
|
+
//# sourceMappingURL=binds.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"binds.js","sourceRoot":"","sources":["../src/binds.ts"],"names":[],"mappings":";;;AAAA,iDAAiE;AAGjE,wDAAqD;AAGrD,qDAAgD;AAEhD,SAAS,MAAM,CAAC,OAAe,EAAE,OAAe,EAAE,OAAmB;IACnE,MAAM,OAAO,GAAG,IAAA,sBAAU,EAAC,OAAO,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAA;IACtD,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,WAAW,EAAE,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;AAC5D,CAAC;AAED,MAAM,aAAa,GAAG,IAAI,GAAG,EAAkB,CAAA;AAC/C,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAyB,CAAA;AAEjD,8CAA8C;AAC9C,4EAA4E;AAC5E,0CAA0C;AAC1C,wCAAwC;AACxC,SAAgB,eAAe,CAC7B,OAAe,EACf,YAAgC,EAChC,OAAe,EACf,UAAsB,CAAC;IAEvB,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAA;IAC7C,IAAI,IAAI,GAAG,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;IACjC,IAAI,IAAI,EAAE;QACR,OAAO,IAAI,CAAA;KACZ;IACD,IAAI,YAAY,EAAE;QAChB,aAAa,CAAC,GAAG,CAAC,GAAG,EAAE,YAAY,CAAC,CAAA;QACpC,OAAO,YAAY,CAAA;KACpB;IAED,IAAI,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;IACjC,IAAI,CAAC,KAAK,EAAE;QACV,KAAK,GAAG,IAAI,8BAAa,CAAC,OAAO,CAAC,CAAA;QAClC,QAAQ,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAA;KAC7B;IACD,IAAI,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAA;IACvB,aAAa,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;IAC5B,OAAO,IAAI,CAAA;AACb,CAAC;AAxBD,0CAwBC;AAED,SAAgB,YAAY,CAAC,OAAe,EAAE,IAAiB;IAC7D,MAAM,GAAG,GAAG,OAAO,GAAG,GAAG,GAAG,IAAA,kCAAmB,EAAC,IAAI,CAAC,CAAA;IACrD,OAAO,MAAM,CAAC,eAAe,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;AACrD,CAAC;AAHD,oCAGC;AAED,SAAgB,YAAY,CAAC,OAAe,EAAE,IAAiB,EAAE,SAAkC;IACjG,MAAM,GAAG,GAAG,OAAO,GAAG,GAAG,GAAG,IAAA,kCAAmB,EAAC,IAAI,CAAC,CAAA;IAErD,MAAM,CAAC,eAAe,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IACjD,MAAM,CAAC,eAAe,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,CAAA;AACzD,CAAC;AALD,oCAKC;AAED,SAAgB,gBAAgB,CAAC,OAAe,EAAE,OAAe,EAAE,OAAmB;IACpF,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAA;IAC7C,OAAO,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;AAClD,CAAC;AAHD,4CAGC;AAED,SAAgB,gBAAgB,CAC9B,OAAe,EACf,OAAe,EACf,OAAmB,EACnB,QAAoC;IAEpC,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAA;IAC7C,OAAO,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAA;AAC5D,CAAC;AARD,4CAQC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/* Autogenerated file. Do not edit manually. */
|
|
3
|
+
/* tslint:disable */
|
|
4
|
+
/* eslint-disable */
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
17
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
18
|
+
};
|
|
19
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
+
__exportStar(require("../internal/erc20_processor"), exports);
|
|
21
|
+
__exportStar(require("../internal/Erc20"), exports);
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/builtin/erc20/index.ts"],"names":[],"mappings":";AAAA,+CAA+C;AAC/C,oBAAoB;AACpB,oBAAoB;;;;;;;;;;;;;;;;AAEpB,8DAA4C;AAC5C,oDAAkC"}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import type { BaseContract, BigNumber, BigNumberish, BytesLike, CallOverrides, ContractTransaction, Overrides, PopulatedTransaction, Signer, utils } from "ethers";
|
|
2
|
+
import type { FunctionFragment, Result, EventFragment } from "@ethersproject/abi";
|
|
3
|
+
import type { Listener, Provider } from "@ethersproject/providers";
|
|
4
|
+
import type { TypedEventFilter, TypedEvent, TypedListener, OnEvent, PromiseOrValue } from "./common";
|
|
5
|
+
export interface Erc20Interface extends utils.Interface {
|
|
6
|
+
functions: {
|
|
7
|
+
"allowance(address,address)": FunctionFragment;
|
|
8
|
+
"approve(address,uint256)": FunctionFragment;
|
|
9
|
+
"balanceOf(address)": FunctionFragment;
|
|
10
|
+
"decimals()": FunctionFragment;
|
|
11
|
+
"totalSupply()": FunctionFragment;
|
|
12
|
+
"transfer(address,uint256)": FunctionFragment;
|
|
13
|
+
"transferFrom(address,address,uint256)": FunctionFragment;
|
|
14
|
+
};
|
|
15
|
+
getFunction(nameOrSignatureOrTopic: "allowance" | "approve" | "balanceOf" | "decimals" | "totalSupply" | "transfer" | "transferFrom"): FunctionFragment;
|
|
16
|
+
encodeFunctionData(functionFragment: "allowance", values: [PromiseOrValue<string>, PromiseOrValue<string>]): string;
|
|
17
|
+
encodeFunctionData(functionFragment: "approve", values: [PromiseOrValue<string>, PromiseOrValue<BigNumberish>]): string;
|
|
18
|
+
encodeFunctionData(functionFragment: "balanceOf", values: [PromiseOrValue<string>]): string;
|
|
19
|
+
encodeFunctionData(functionFragment: "decimals", values?: undefined): string;
|
|
20
|
+
encodeFunctionData(functionFragment: "totalSupply", values?: undefined): string;
|
|
21
|
+
encodeFunctionData(functionFragment: "transfer", values: [PromiseOrValue<string>, PromiseOrValue<BigNumberish>]): string;
|
|
22
|
+
encodeFunctionData(functionFragment: "transferFrom", values: [
|
|
23
|
+
PromiseOrValue<string>,
|
|
24
|
+
PromiseOrValue<string>,
|
|
25
|
+
PromiseOrValue<BigNumberish>
|
|
26
|
+
]): string;
|
|
27
|
+
decodeFunctionResult(functionFragment: "allowance", data: BytesLike): Result;
|
|
28
|
+
decodeFunctionResult(functionFragment: "approve", data: BytesLike): Result;
|
|
29
|
+
decodeFunctionResult(functionFragment: "balanceOf", data: BytesLike): Result;
|
|
30
|
+
decodeFunctionResult(functionFragment: "decimals", data: BytesLike): Result;
|
|
31
|
+
decodeFunctionResult(functionFragment: "totalSupply", data: BytesLike): Result;
|
|
32
|
+
decodeFunctionResult(functionFragment: "transfer", data: BytesLike): Result;
|
|
33
|
+
decodeFunctionResult(functionFragment: "transferFrom", data: BytesLike): Result;
|
|
34
|
+
events: {
|
|
35
|
+
"Approval(address,address,uint256)": EventFragment;
|
|
36
|
+
"Transfer(address,address,uint256)": EventFragment;
|
|
37
|
+
};
|
|
38
|
+
getEvent(nameOrSignatureOrTopic: "Approval"): EventFragment;
|
|
39
|
+
getEvent(nameOrSignatureOrTopic: "Transfer"): EventFragment;
|
|
40
|
+
}
|
|
41
|
+
export interface ApprovalEventObject {
|
|
42
|
+
owner: string;
|
|
43
|
+
spender: string;
|
|
44
|
+
value: BigNumber;
|
|
45
|
+
}
|
|
46
|
+
export declare type ApprovalEvent = TypedEvent<[
|
|
47
|
+
string,
|
|
48
|
+
string,
|
|
49
|
+
BigNumber
|
|
50
|
+
], ApprovalEventObject>;
|
|
51
|
+
export declare type ApprovalEventFilter = TypedEventFilter<ApprovalEvent>;
|
|
52
|
+
export interface TransferEventObject {
|
|
53
|
+
from: string;
|
|
54
|
+
to: string;
|
|
55
|
+
value: BigNumber;
|
|
56
|
+
}
|
|
57
|
+
export declare type TransferEvent = TypedEvent<[
|
|
58
|
+
string,
|
|
59
|
+
string,
|
|
60
|
+
BigNumber
|
|
61
|
+
], TransferEventObject>;
|
|
62
|
+
export declare type TransferEventFilter = TypedEventFilter<TransferEvent>;
|
|
63
|
+
export interface Erc20 extends BaseContract {
|
|
64
|
+
connect(signerOrProvider: Signer | Provider | string): this;
|
|
65
|
+
attach(addressOrName: string): this;
|
|
66
|
+
deployed(): Promise<this>;
|
|
67
|
+
interface: Erc20Interface;
|
|
68
|
+
queryFilter<TEvent extends TypedEvent>(event: TypedEventFilter<TEvent>, fromBlockOrBlockhash?: string | number | undefined, toBlock?: string | number | undefined): Promise<Array<TEvent>>;
|
|
69
|
+
listeners<TEvent extends TypedEvent>(eventFilter?: TypedEventFilter<TEvent>): Array<TypedListener<TEvent>>;
|
|
70
|
+
listeners(eventName?: string): Array<Listener>;
|
|
71
|
+
removeAllListeners<TEvent extends TypedEvent>(eventFilter: TypedEventFilter<TEvent>): this;
|
|
72
|
+
removeAllListeners(eventName?: string): this;
|
|
73
|
+
off: OnEvent<this>;
|
|
74
|
+
on: OnEvent<this>;
|
|
75
|
+
once: OnEvent<this>;
|
|
76
|
+
removeListener: OnEvent<this>;
|
|
77
|
+
functions: {
|
|
78
|
+
allowance(owner: PromiseOrValue<string>, spender: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[BigNumber]>;
|
|
79
|
+
approve(spender: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
80
|
+
from?: PromiseOrValue<string>;
|
|
81
|
+
}): Promise<ContractTransaction>;
|
|
82
|
+
balanceOf(account: PromiseOrValue<string>, overrides?: CallOverrides): Promise<[BigNumber]>;
|
|
83
|
+
decimals(overrides?: CallOverrides): Promise<[number]>;
|
|
84
|
+
totalSupply(overrides?: CallOverrides): Promise<[BigNumber]>;
|
|
85
|
+
transfer(to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
86
|
+
from?: PromiseOrValue<string>;
|
|
87
|
+
}): Promise<ContractTransaction>;
|
|
88
|
+
transferFrom(from: PromiseOrValue<string>, to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
89
|
+
from?: PromiseOrValue<string>;
|
|
90
|
+
}): Promise<ContractTransaction>;
|
|
91
|
+
};
|
|
92
|
+
allowance(owner: PromiseOrValue<string>, spender: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
|
|
93
|
+
approve(spender: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
94
|
+
from?: PromiseOrValue<string>;
|
|
95
|
+
}): Promise<ContractTransaction>;
|
|
96
|
+
balanceOf(account: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
|
|
97
|
+
decimals(overrides?: CallOverrides): Promise<number>;
|
|
98
|
+
totalSupply(overrides?: CallOverrides): Promise<BigNumber>;
|
|
99
|
+
transfer(to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
100
|
+
from?: PromiseOrValue<string>;
|
|
101
|
+
}): Promise<ContractTransaction>;
|
|
102
|
+
transferFrom(from: PromiseOrValue<string>, to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
103
|
+
from?: PromiseOrValue<string>;
|
|
104
|
+
}): Promise<ContractTransaction>;
|
|
105
|
+
callStatic: {
|
|
106
|
+
allowance(owner: PromiseOrValue<string>, spender: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
|
|
107
|
+
approve(spender: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<boolean>;
|
|
108
|
+
balanceOf(account: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
|
|
109
|
+
decimals(overrides?: CallOverrides): Promise<number>;
|
|
110
|
+
totalSupply(overrides?: CallOverrides): Promise<BigNumber>;
|
|
111
|
+
transfer(to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<boolean>;
|
|
112
|
+
transferFrom(from: PromiseOrValue<string>, to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: CallOverrides): Promise<boolean>;
|
|
113
|
+
};
|
|
114
|
+
filters: {
|
|
115
|
+
"Approval(address,address,uint256)"(owner?: PromiseOrValue<string> | null, spender?: PromiseOrValue<string> | null, value?: null): ApprovalEventFilter;
|
|
116
|
+
Approval(owner?: PromiseOrValue<string> | null, spender?: PromiseOrValue<string> | null, value?: null): ApprovalEventFilter;
|
|
117
|
+
"Transfer(address,address,uint256)"(from?: PromiseOrValue<string> | null, to?: PromiseOrValue<string> | null, value?: null): TransferEventFilter;
|
|
118
|
+
Transfer(from?: PromiseOrValue<string> | null, to?: PromiseOrValue<string> | null, value?: null): TransferEventFilter;
|
|
119
|
+
};
|
|
120
|
+
estimateGas: {
|
|
121
|
+
allowance(owner: PromiseOrValue<string>, spender: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
|
|
122
|
+
approve(spender: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
123
|
+
from?: PromiseOrValue<string>;
|
|
124
|
+
}): Promise<BigNumber>;
|
|
125
|
+
balanceOf(account: PromiseOrValue<string>, overrides?: CallOverrides): Promise<BigNumber>;
|
|
126
|
+
decimals(overrides?: CallOverrides): Promise<BigNumber>;
|
|
127
|
+
totalSupply(overrides?: CallOverrides): Promise<BigNumber>;
|
|
128
|
+
transfer(to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
129
|
+
from?: PromiseOrValue<string>;
|
|
130
|
+
}): Promise<BigNumber>;
|
|
131
|
+
transferFrom(from: PromiseOrValue<string>, to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
132
|
+
from?: PromiseOrValue<string>;
|
|
133
|
+
}): Promise<BigNumber>;
|
|
134
|
+
};
|
|
135
|
+
populateTransaction: {
|
|
136
|
+
allowance(owner: PromiseOrValue<string>, spender: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
|
|
137
|
+
approve(spender: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
138
|
+
from?: PromiseOrValue<string>;
|
|
139
|
+
}): Promise<PopulatedTransaction>;
|
|
140
|
+
balanceOf(account: PromiseOrValue<string>, overrides?: CallOverrides): Promise<PopulatedTransaction>;
|
|
141
|
+
decimals(overrides?: CallOverrides): Promise<PopulatedTransaction>;
|
|
142
|
+
totalSupply(overrides?: CallOverrides): Promise<PopulatedTransaction>;
|
|
143
|
+
transfer(to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
144
|
+
from?: PromiseOrValue<string>;
|
|
145
|
+
}): Promise<PopulatedTransaction>;
|
|
146
|
+
transferFrom(from: PromiseOrValue<string>, to: PromiseOrValue<string>, amount: PromiseOrValue<BigNumberish>, overrides?: Overrides & {
|
|
147
|
+
from?: PromiseOrValue<string>;
|
|
148
|
+
}): Promise<PopulatedTransaction>;
|
|
149
|
+
};
|
|
150
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Erc20.js","sourceRoot":"","sources":["../../../src/builtin/internal/Erc20.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { Listener } from "@ethersproject/providers";
|
|
2
|
+
import type { Event, EventFilter } from "ethers";
|
|
3
|
+
export interface TypedEvent<TArgsArray extends Array<any> = any, TArgsObject = any> extends Event {
|
|
4
|
+
args: TArgsArray & TArgsObject;
|
|
5
|
+
}
|
|
6
|
+
export interface TypedEventFilter<_TEvent extends TypedEvent> extends EventFilter {
|
|
7
|
+
}
|
|
8
|
+
export interface TypedListener<TEvent extends TypedEvent> {
|
|
9
|
+
(...listenerArg: [...__TypechainArgsArray<TEvent>, TEvent]): void;
|
|
10
|
+
}
|
|
11
|
+
declare type __TypechainArgsArray<T> = T extends TypedEvent<infer U> ? U : never;
|
|
12
|
+
export interface OnEvent<TRes> {
|
|
13
|
+
<TEvent extends TypedEvent>(eventFilter: TypedEventFilter<TEvent>, listener: TypedListener<TEvent>): TRes;
|
|
14
|
+
(eventName: string, listener: Listener): TRes;
|
|
15
|
+
}
|
|
16
|
+
export declare type MinEthersFactory<C, ARGS> = {
|
|
17
|
+
deploy(...a: ARGS[]): Promise<C>;
|
|
18
|
+
};
|
|
19
|
+
export declare type GetContractTypeFromFactory<F> = F extends MinEthersFactory<infer C, any> ? C : never;
|
|
20
|
+
export declare type GetARGsTypeFromFactory<F> = F extends MinEthersFactory<any, any> ? Parameters<F["deploy"]> : never;
|
|
21
|
+
export declare type PromiseOrValue<T> = T | Promise<T>;
|
|
22
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../src/builtin/internal/common.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { CallOverrides } from "ethers";
|
|
2
|
+
import { Networkish } from "@ethersproject/providers";
|
|
3
|
+
import { BindOptions, BaseProcessor, BaseProcessorTemplate, BoundContractView, Context, ContractView } from "@sentio/sdk";
|
|
4
|
+
import { PromiseOrValue } from "./common";
|
|
5
|
+
import { Erc20 } from "./index";
|
|
6
|
+
import { ApprovalEvent, ApprovalEventFilter, TransferEvent, TransferEventFilter } from "./Erc20";
|
|
7
|
+
export declare class Erc20ContractView extends ContractView<Erc20> {
|
|
8
|
+
constructor(contract: Erc20);
|
|
9
|
+
allowance(owner: PromiseOrValue<string>, spender: PromiseOrValue<string>, overrides?: CallOverrides): Promise<import("ethers").BigNumber>;
|
|
10
|
+
balanceOf(account: PromiseOrValue<string>, overrides?: CallOverrides): Promise<import("ethers").BigNumber>;
|
|
11
|
+
decimals(overrides?: CallOverrides): Promise<number>;
|
|
12
|
+
totalSupply(overrides?: CallOverrides): Promise<import("ethers").BigNumber>;
|
|
13
|
+
}
|
|
14
|
+
export declare class Erc20BoundContractView extends BoundContractView<Erc20, Erc20ContractView> {
|
|
15
|
+
allowance(owner: PromiseOrValue<string>, spender: PromiseOrValue<string>, overrides?: CallOverrides): Promise<import("ethers").BigNumber>;
|
|
16
|
+
balanceOf(account: PromiseOrValue<string>, overrides?: CallOverrides): Promise<import("ethers").BigNumber>;
|
|
17
|
+
decimals(overrides?: CallOverrides): Promise<number>;
|
|
18
|
+
totalSupply(overrides?: CallOverrides): Promise<import("ethers").BigNumber>;
|
|
19
|
+
}
|
|
20
|
+
export declare type Erc20Context = Context<Erc20, Erc20BoundContractView>;
|
|
21
|
+
export declare class Erc20ProcessorTemplate extends BaseProcessorTemplate<Erc20, Erc20BoundContractView> {
|
|
22
|
+
bindInternal(options: BindOptions): Erc20Processor;
|
|
23
|
+
onApproval(handler: (event: ApprovalEvent, ctx: Erc20Context) => void, filter?: ApprovalEventFilter | ApprovalEventFilter[]): this;
|
|
24
|
+
onTransfer(handler: (event: TransferEvent, ctx: Erc20Context) => void, filter?: TransferEventFilter | TransferEventFilter[]): this;
|
|
25
|
+
}
|
|
26
|
+
export declare class Erc20Processor extends BaseProcessor<Erc20, Erc20BoundContractView> {
|
|
27
|
+
onApproval(handler: (event: ApprovalEvent, ctx: Erc20Context) => void, filter?: ApprovalEventFilter | ApprovalEventFilter[]): this;
|
|
28
|
+
onTransfer(handler: (event: TransferEvent, ctx: Erc20Context) => void, filter?: TransferEventFilter | TransferEventFilter[]): this;
|
|
29
|
+
static filters: {
|
|
30
|
+
"Approval(address,address,uint256)"(owner?: PromiseOrValue<string> | null | undefined, spender?: PromiseOrValue<string> | null | undefined, value?: null | undefined): ApprovalEventFilter;
|
|
31
|
+
Approval(owner?: PromiseOrValue<string> | null | undefined, spender?: PromiseOrValue<string> | null | undefined, value?: null | undefined): ApprovalEventFilter;
|
|
32
|
+
"Transfer(address,address,uint256)"(from?: PromiseOrValue<string> | null | undefined, to?: PromiseOrValue<string> | null | undefined, value?: null | undefined): TransferEventFilter;
|
|
33
|
+
Transfer(from?: PromiseOrValue<string> | null | undefined, to?: PromiseOrValue<string> | null | undefined, value?: null | undefined): TransferEventFilter;
|
|
34
|
+
};
|
|
35
|
+
protected CreateBoundContractView(): Erc20BoundContractView;
|
|
36
|
+
static bind(options: BindOptions): Erc20Processor;
|
|
37
|
+
}
|
|
38
|
+
export declare function getErc20Contract(address: string, network?: Networkish): Erc20ContractView;
|