@sentio/sdk 2.41.4-rc.1 → 2.41.4-rc.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/lib/btc/btc-plugin.d.ts.map +1 -1
  2. package/lib/btc/btc-plugin.js +42 -8
  3. package/lib/btc/btc-plugin.js.map +1 -1
  4. package/lib/btc/btc-processor.d.ts +4 -3
  5. package/lib/btc/btc-processor.d.ts.map +1 -1
  6. package/lib/btc/btc-processor.js +4 -3
  7. package/lib/btc/btc-processor.js.map +1 -1
  8. package/lib/btc/types.d.ts +15 -0
  9. package/lib/btc/types.d.ts.map +1 -1
  10. package/lib/btc/types.js.map +1 -1
  11. package/lib/eth/builtin/internal/eacaggregatorproxy-processor.d.ts.map +1 -1
  12. package/lib/eth/builtin/internal/eacaggregatorproxy-processor.js +131 -145
  13. package/lib/eth/builtin/internal/eacaggregatorproxy-processor.js.map +1 -1
  14. package/lib/eth/builtin/internal/erc1155-processor.d.ts.map +1 -1
  15. package/lib/eth/builtin/internal/erc1155-processor.js +44 -52
  16. package/lib/eth/builtin/internal/erc1155-processor.js.map +1 -1
  17. package/lib/eth/builtin/internal/erc20-processor.d.ts.map +1 -1
  18. package/lib/eth/builtin/internal/erc20-processor.js +104 -112
  19. package/lib/eth/builtin/internal/erc20-processor.js.map +1 -1
  20. package/lib/eth/builtin/internal/erc20bytes-processor.d.ts.map +1 -1
  21. package/lib/eth/builtin/internal/erc20bytes-processor.js +53 -55
  22. package/lib/eth/builtin/internal/erc20bytes-processor.js.map +1 -1
  23. package/lib/eth/builtin/internal/erc721-processor.d.ts.map +1 -1
  24. package/lib/eth/builtin/internal/erc721-processor.js +80 -88
  25. package/lib/eth/builtin/internal/erc721-processor.js.map +1 -1
  26. package/lib/eth/builtin/internal/weth9-processor.d.ts.map +1 -1
  27. package/lib/eth/builtin/internal/weth9-processor.js +67 -65
  28. package/lib/eth/builtin/internal/weth9-processor.js.map +1 -1
  29. package/lib/eth/codegen/function-calls.d.ts.map +1 -1
  30. package/lib/eth/codegen/function-calls.js +3 -5
  31. package/lib/eth/codegen/function-calls.js.map +1 -1
  32. package/lib/store/store.d.ts.map +1 -1
  33. package/lib/store/store.js +6 -46
  34. package/lib/store/store.js.map +1 -1
  35. package/lib/store/util.d.ts +3 -0
  36. package/lib/store/util.d.ts.map +1 -0
  37. package/lib/store/util.js +46 -0
  38. package/lib/store/util.js.map +1 -0
  39. package/package.json +4 -3
  40. package/src/btc/btc-plugin.ts +49 -8
  41. package/src/btc/btc-processor.ts +10 -5
  42. package/src/btc/types.ts +31 -0
  43. package/src/eth/builtin/internal/eacaggregatorproxy-processor.ts +131 -168
  44. package/src/eth/builtin/internal/erc1155-processor.ts +44 -60
  45. package/src/eth/builtin/internal/erc20-processor.ts +104 -130
  46. package/src/eth/builtin/internal/erc20bytes-processor.ts +53 -64
  47. package/src/eth/builtin/internal/erc721-processor.ts +80 -102
  48. package/src/eth/builtin/internal/weth9-processor.ts +67 -76
  49. package/src/eth/codegen/function-calls.ts +3 -5
  50. package/src/store/store.ts +7 -53
  51. package/src/store/util.ts +53 -0
@@ -827,54 +827,53 @@ export class WETH9BoundContractView extends BoundContractView<
827
827
  context: this.context,
828
828
 
829
829
  name(overrides?: Overrides): EthCallParam {
830
- const chainId =
831
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
832
- const address = this.context.address;
833
- let blockTag = "0x" + this.context.blockNumber.toString(16);
830
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
834
831
  if (overrides?.blockTag) {
835
- blockTag =
832
+ blockTagWithOverride =
836
833
  typeof overrides.blockTag == "string"
837
834
  ? overrides.blockTag
838
835
  : "0x" + overrides.blockTag.toString(16);
839
836
  }
840
837
 
841
- return this.view.encodeCall.name({ chainId, address, blockTag });
838
+ return this.view.encodeCall.name({
839
+ chainId: this.context.chainId.toString(),
840
+ address: this.context.address,
841
+ blockTag: blockTagWithOverride,
842
+ });
842
843
  },
843
844
  approve(
844
845
  guy: string,
845
846
  wad: BigNumberish,
846
847
  overrides?: Overrides
847
848
  ): EthCallParam {
848
- const chainId =
849
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
850
- const address = this.context.address;
851
- let blockTag = "0x" + this.context.blockNumber.toString(16);
849
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
852
850
  if (overrides?.blockTag) {
853
- blockTag =
851
+ blockTagWithOverride =
854
852
  typeof overrides.blockTag == "string"
855
853
  ? overrides.blockTag
856
854
  : "0x" + overrides.blockTag.toString(16);
857
855
  }
858
856
 
859
857
  return this.view.encodeCall.approve(guy, wad, {
860
- chainId,
861
- address,
862
- blockTag,
858
+ chainId: this.context.chainId.toString(),
859
+ address: this.context.address,
860
+ blockTag: blockTagWithOverride,
863
861
  });
864
862
  },
865
863
  totalSupply(overrides?: Overrides): EthCallParam {
866
- const chainId =
867
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
868
- const address = this.context.address;
869
- let blockTag = "0x" + this.context.blockNumber.toString(16);
864
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
870
865
  if (overrides?.blockTag) {
871
- blockTag =
866
+ blockTagWithOverride =
872
867
  typeof overrides.blockTag == "string"
873
868
  ? overrides.blockTag
874
869
  : "0x" + overrides.blockTag.toString(16);
875
870
  }
876
871
 
877
- return this.view.encodeCall.totalSupply({ chainId, address, blockTag });
872
+ return this.view.encodeCall.totalSupply({
873
+ chainId: this.context.chainId.toString(),
874
+ address: this.context.address,
875
+ blockTag: blockTagWithOverride,
876
+ });
878
877
  },
879
878
  transferFrom(
880
879
  src: string,
@@ -882,135 +881,127 @@ export class WETH9BoundContractView extends BoundContractView<
882
881
  wad: BigNumberish,
883
882
  overrides?: Overrides
884
883
  ): EthCallParam {
885
- const chainId =
886
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
887
- const address = this.context.address;
888
- let blockTag = "0x" + this.context.blockNumber.toString(16);
884
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
889
885
  if (overrides?.blockTag) {
890
- blockTag =
886
+ blockTagWithOverride =
891
887
  typeof overrides.blockTag == "string"
892
888
  ? overrides.blockTag
893
889
  : "0x" + overrides.blockTag.toString(16);
894
890
  }
895
891
 
896
892
  return this.view.encodeCall.transferFrom(src, dst, wad, {
897
- chainId,
898
- address,
899
- blockTag,
893
+ chainId: this.context.chainId.toString(),
894
+ address: this.context.address,
895
+ blockTag: blockTagWithOverride,
900
896
  });
901
897
  },
902
898
  withdraw(wad: BigNumberish, overrides?: Overrides): EthCallParam {
903
- const chainId =
904
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
905
- const address = this.context.address;
906
- let blockTag = "0x" + this.context.blockNumber.toString(16);
899
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
907
900
  if (overrides?.blockTag) {
908
- blockTag =
901
+ blockTagWithOverride =
909
902
  typeof overrides.blockTag == "string"
910
903
  ? overrides.blockTag
911
904
  : "0x" + overrides.blockTag.toString(16);
912
905
  }
913
906
 
914
- return this.view.encodeCall.withdraw(wad, { chainId, address, blockTag });
907
+ return this.view.encodeCall.withdraw(wad, {
908
+ chainId: this.context.chainId.toString(),
909
+ address: this.context.address,
910
+ blockTag: blockTagWithOverride,
911
+ });
915
912
  },
916
913
  decimals(overrides?: Overrides): EthCallParam {
917
- const chainId =
918
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
919
- const address = this.context.address;
920
- let blockTag = "0x" + this.context.blockNumber.toString(16);
914
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
921
915
  if (overrides?.blockTag) {
922
- blockTag =
916
+ blockTagWithOverride =
923
917
  typeof overrides.blockTag == "string"
924
918
  ? overrides.blockTag
925
919
  : "0x" + overrides.blockTag.toString(16);
926
920
  }
927
921
 
928
- return this.view.encodeCall.decimals({ chainId, address, blockTag });
922
+ return this.view.encodeCall.decimals({
923
+ chainId: this.context.chainId.toString(),
924
+ address: this.context.address,
925
+ blockTag: blockTagWithOverride,
926
+ });
929
927
  },
930
928
  balanceOf(arg0: string, overrides?: Overrides): EthCallParam {
931
- const chainId =
932
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
933
- const address = this.context.address;
934
- let blockTag = "0x" + this.context.blockNumber.toString(16);
929
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
935
930
  if (overrides?.blockTag) {
936
- blockTag =
931
+ blockTagWithOverride =
937
932
  typeof overrides.blockTag == "string"
938
933
  ? overrides.blockTag
939
934
  : "0x" + overrides.blockTag.toString(16);
940
935
  }
941
936
 
942
937
  return this.view.encodeCall.balanceOf(arg0, {
943
- chainId,
944
- address,
945
- blockTag,
938
+ chainId: this.context.chainId.toString(),
939
+ address: this.context.address,
940
+ blockTag: blockTagWithOverride,
946
941
  });
947
942
  },
948
943
  symbol(overrides?: Overrides): EthCallParam {
949
- const chainId =
950
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
951
- const address = this.context.address;
952
- let blockTag = "0x" + this.context.blockNumber.toString(16);
944
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
953
945
  if (overrides?.blockTag) {
954
- blockTag =
946
+ blockTagWithOverride =
955
947
  typeof overrides.blockTag == "string"
956
948
  ? overrides.blockTag
957
949
  : "0x" + overrides.blockTag.toString(16);
958
950
  }
959
951
 
960
- return this.view.encodeCall.symbol({ chainId, address, blockTag });
952
+ return this.view.encodeCall.symbol({
953
+ chainId: this.context.chainId.toString(),
954
+ address: this.context.address,
955
+ blockTag: blockTagWithOverride,
956
+ });
961
957
  },
962
958
  transfer(
963
959
  dst: string,
964
960
  wad: BigNumberish,
965
961
  overrides?: Overrides
966
962
  ): EthCallParam {
967
- const chainId =
968
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
969
- const address = this.context.address;
970
- let blockTag = "0x" + this.context.blockNumber.toString(16);
963
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
971
964
  if (overrides?.blockTag) {
972
- blockTag =
965
+ blockTagWithOverride =
973
966
  typeof overrides.blockTag == "string"
974
967
  ? overrides.blockTag
975
968
  : "0x" + overrides.blockTag.toString(16);
976
969
  }
977
970
 
978
971
  return this.view.encodeCall.transfer(dst, wad, {
979
- chainId,
980
- address,
981
- blockTag,
972
+ chainId: this.context.chainId.toString(),
973
+ address: this.context.address,
974
+ blockTag: blockTagWithOverride,
982
975
  });
983
976
  },
984
977
  deposit(overrides?: Overrides): EthCallParam {
985
- const chainId =
986
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
987
- const address = this.context.address;
988
- let blockTag = "0x" + this.context.blockNumber.toString(16);
978
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
989
979
  if (overrides?.blockTag) {
990
- blockTag =
980
+ blockTagWithOverride =
991
981
  typeof overrides.blockTag == "string"
992
982
  ? overrides.blockTag
993
983
  : "0x" + overrides.blockTag.toString(16);
994
984
  }
995
985
 
996
- return this.view.encodeCall.deposit({ chainId, address, blockTag });
986
+ return this.view.encodeCall.deposit({
987
+ chainId: this.context.chainId.toString(),
988
+ address: this.context.address,
989
+ blockTag: blockTagWithOverride,
990
+ });
997
991
  },
998
992
  allowance(arg0: string, arg1: string, overrides?: Overrides): EthCallParam {
999
- const chainId =
1000
- overrides?.chainId?.toString() ?? this.context.chainId.toString();
1001
- const address = this.context.address;
1002
- let blockTag = "0x" + this.context.blockNumber.toString(16);
993
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16);
1003
994
  if (overrides?.blockTag) {
1004
- blockTag =
995
+ blockTagWithOverride =
1005
996
  typeof overrides.blockTag == "string"
1006
997
  ? overrides.blockTag
1007
998
  : "0x" + overrides.blockTag.toString(16);
1008
999
  }
1009
1000
 
1010
1001
  return this.view.encodeCall.allowance(arg0, arg1, {
1011
- chainId,
1012
- address,
1013
- blockTag,
1002
+ chainId: this.context.chainId.toString(),
1003
+ address: this.context.address,
1004
+ blockTag: blockTagWithOverride,
1014
1005
  });
1015
1006
  },
1016
1007
  };
@@ -154,16 +154,14 @@ export function generateBoundFunctionCallEncoder(fn: FunctionDeclaration, includ
154
154
  ${declName ?? fn.name}(${generateInputTypes(fn.inputs, {
155
155
  useStructs: true
156
156
  })}overrides?: Overrides): EthCallParam {
157
- const chainId = overrides?.chainId?.toString() ?? this.context.chainId.toString()
158
- const address = this.context.address
159
- let blockTag = "0x" + this.context.blockNumber.toString(16)
157
+ let blockTagWithOverride = "0x" + this.context.blockNumber.toString(16)
160
158
  if (overrides?.blockTag) {
161
- blockTag = typeof(overrides.blockTag) == 'string'? overrides.blockTag: "0x" + overrides.blockTag.toString(16)
159
+ blockTagWithOverride = typeof(overrides.blockTag) == 'string'? overrides.blockTag: "0x" + overrides.blockTag.toString(16)
162
160
  }
163
161
 
164
162
  return this.view.encodeCall.${declName}(${
165
163
  fn.inputs.length > 0 ? fn.inputs.map((input, index) => input.name || `arg${index}`).join(',') + ',' : ''
166
- }{chainId, address, blockTag})
164
+ }{chainId: this.context.chainId.toString(), address: this.context.address, blockTag: blockTagWithOverride})
167
165
  }
168
166
  `
169
167
  ]
@@ -2,12 +2,12 @@ import { StoreContext } from './context.js'
2
2
  import { DatabaseSchema } from '../core/index.js'
3
3
  import { BigDecimal } from '@sentio/bigdecimal'
4
4
  import { AbstractEntity as Entity, Bytes, Float, ID, Int, Timestamp } from './types.js'
5
- import type { DBRequest, Entity as EntityStruct, RichValue } from '@sentio/protos'
5
+ import type { DBRequest, Entity as EntityStruct } from '@sentio/protos'
6
6
  import { DBRequest_DBOperator, DBResponse } from '@sentio/protos'
7
- import { toBigInteger } from './convert.js'
8
7
  import { PluginManager } from '@sentio/runtime'
9
8
  import { Cursor } from './cursor.js'
10
9
  import { LocalCache } from './cache.js'
10
+ import { serializeRichValue } from './util.js'
11
11
 
12
12
  export interface EntityClass<T> {
13
13
  new (data: Partial<T>): T
@@ -166,7 +166,11 @@ export class Store {
166
166
  filters?.map((f) => ({
167
167
  field: f.field as string,
168
168
  op: ops[f.op],
169
- value: { values: Array.isArray(f.value) ? f.value.map((v) => serialize(v)) : [serialize(f.value)] }
169
+ value: {
170
+ values: Array.isArray(f.value)
171
+ ? f.value.map((v) => serializeRichValue(v))
172
+ : [serializeRichValue(f.value)]
173
+ }
170
174
  })) || []
171
175
  }
172
176
  },
@@ -297,56 +301,6 @@ const ops: Record<Operators<any>, DBRequest_DBOperator> = {
297
301
  'has any': DBRequest_DBOperator.HAS_ANY
298
302
  }
299
303
 
300
- function serialize(v: any): RichValue {
301
- if (v == null) {
302
- return { nullValue: 0 }
303
- }
304
- if (typeof v == 'boolean') {
305
- return { boolValue: v }
306
- }
307
- if (typeof v == 'string') {
308
- return { stringValue: v }
309
- }
310
-
311
- if (typeof v == 'number') {
312
- return { floatValue: v }
313
- }
314
- if (typeof v == 'bigint') {
315
- return {
316
- bigintValue: toBigInteger(v)
317
- }
318
- }
319
-
320
- if (v instanceof BigDecimal) {
321
- return serializeBigDecimal(v)
322
- }
323
-
324
- if (v instanceof Date) {
325
- return {
326
- timestampValue: v
327
- }
328
- }
329
-
330
- if (v instanceof Uint8Array) {
331
- return { bytesValue: v }
332
- }
333
-
334
- if (Array.isArray(v)) {
335
- return {
336
- listValue: { values: v.map((v) => serialize(v)) }
337
- }
338
- }
339
- return {
340
- nullValue: 0
341
- }
342
- }
343
-
344
- function serializeBigDecimal(v: BigDecimal): RichValue {
345
- return {
346
- bigdecimalValue: undefined
347
- }
348
- }
349
-
350
304
  export function getStore() {
351
305
  const dbContext = PluginManager.INSTANCE.dbContextLocalStorage.getStore()
352
306
  if (dbContext) {
@@ -0,0 +1,53 @@
1
+ import type { RichValue } from '@sentio/protos'
2
+ import { toBigInteger } from './convert.js'
3
+ import { BigDecimal } from '@sentio/bigdecimal'
4
+
5
+ export function serializeRichValue(v: any): RichValue {
6
+ if (v == null) {
7
+ return { nullValue: 0 }
8
+ }
9
+ if (typeof v == 'boolean') {
10
+ return { boolValue: v }
11
+ }
12
+ if (typeof v == 'string') {
13
+ return { stringValue: v }
14
+ }
15
+
16
+ if (typeof v == 'number') {
17
+ return { floatValue: v }
18
+ }
19
+ if (typeof v == 'bigint') {
20
+ return {
21
+ bigintValue: toBigInteger(v)
22
+ }
23
+ }
24
+
25
+ if (v instanceof BigDecimal) {
26
+ return serializeBigDecimal(v)
27
+ }
28
+
29
+ if (v instanceof Date) {
30
+ return {
31
+ timestampValue: v
32
+ }
33
+ }
34
+
35
+ if (v instanceof Uint8Array) {
36
+ return { bytesValue: v }
37
+ }
38
+
39
+ if (Array.isArray(v)) {
40
+ return {
41
+ listValue: { values: v.map((v) => serializeRichValue(v)) }
42
+ }
43
+ }
44
+ return {
45
+ nullValue: 0
46
+ }
47
+ }
48
+
49
+ function serializeBigDecimal(v: BigDecimal): RichValue {
50
+ return {
51
+ bigdecimalValue: undefined
52
+ }
53
+ }