@avaprotocol/sdk-js 1.5.0 → 1.6.1

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 (67) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/dist/grpc_codegen/custom_types.d.ts +45 -0
  3. package/dist/grpc_codegen/custom_types.d.ts.map +1 -0
  4. package/dist/grpc_codegen/custom_types.js +179 -0
  5. package/dist/index.d.ts +102 -60
  6. package/dist/index.d.ts.map +1 -1
  7. package/dist/index.js +8043 -5376
  8. package/dist/index.mjs +7808 -5143
  9. package/dist/models/execution.d.ts +9 -2
  10. package/dist/models/execution.d.ts.map +1 -1
  11. package/dist/models/execution.js +25 -8
  12. package/dist/models/node/branch.d.ts +1 -1
  13. package/dist/models/node/branch.d.ts.map +1 -1
  14. package/dist/models/node/branch.js +14 -8
  15. package/dist/models/node/contractRead.d.ts.map +1 -1
  16. package/dist/models/node/contractRead.js +7 -3
  17. package/dist/models/node/contractWrite.d.ts +1 -1
  18. package/dist/models/node/contractWrite.d.ts.map +1 -1
  19. package/dist/models/node/contractWrite.js +6 -4
  20. package/dist/models/node/customCode.d.ts +4 -1
  21. package/dist/models/node/customCode.d.ts.map +1 -1
  22. package/dist/models/node/customCode.js +10 -3
  23. package/dist/models/node/ethTransfer.d.ts +1 -1
  24. package/dist/models/node/ethTransfer.d.ts.map +1 -1
  25. package/dist/models/node/ethTransfer.js +5 -3
  26. package/dist/models/node/factory.d.ts +4 -3
  27. package/dist/models/node/factory.d.ts.map +1 -1
  28. package/dist/models/node/factory.js +5 -2
  29. package/dist/models/node/filter.d.ts.map +1 -1
  30. package/dist/models/node/filter.js +6 -2
  31. package/dist/models/node/graphqlQuery.d.ts.map +1 -1
  32. package/dist/models/node/graphqlQuery.js +13 -7
  33. package/dist/models/node/loop.d.ts +13 -0
  34. package/dist/models/node/loop.d.ts.map +1 -0
  35. package/dist/models/node/loop.js +145 -0
  36. package/dist/models/node/restApi.d.ts.map +1 -1
  37. package/dist/models/node/restApi.js +14 -8
  38. package/dist/models/secret.d.ts +6 -7
  39. package/dist/models/secret.d.ts.map +1 -1
  40. package/dist/models/secret.js +7 -1
  41. package/dist/models/trigger/block.d.ts +8 -1
  42. package/dist/models/trigger/block.d.ts.map +1 -1
  43. package/dist/models/trigger/block.js +23 -4
  44. package/dist/models/trigger/cron.d.ts +8 -1
  45. package/dist/models/trigger/cron.d.ts.map +1 -1
  46. package/dist/models/trigger/cron.js +23 -4
  47. package/dist/models/trigger/event.d.ts +8 -1
  48. package/dist/models/trigger/event.d.ts.map +1 -1
  49. package/dist/models/trigger/event.js +41 -28
  50. package/dist/models/trigger/factory.d.ts +8 -10
  51. package/dist/models/trigger/factory.d.ts.map +1 -1
  52. package/dist/models/trigger/factory.js +6 -1
  53. package/dist/models/trigger/fixedTime.d.ts +8 -1
  54. package/dist/models/trigger/fixedTime.d.ts.map +1 -1
  55. package/dist/models/trigger/fixedTime.js +23 -4
  56. package/dist/models/trigger/interface.d.ts +5 -1
  57. package/dist/models/trigger/interface.d.ts.map +1 -1
  58. package/dist/models/trigger/interface.js +4 -0
  59. package/dist/models/trigger/manual.d.ts +13 -0
  60. package/dist/models/trigger/manual.d.ts.map +1 -0
  61. package/dist/models/trigger/manual.js +27 -0
  62. package/dist/models/trigger/reason.d.ts.map +1 -1
  63. package/dist/models/trigger/reason.js +3 -0
  64. package/dist/models/workflow.d.ts +1 -1
  65. package/dist/models/workflow.d.ts.map +1 -1
  66. package/dist/models/workflow.js +3 -4
  67. package/package.json +2 -2
@@ -2,8 +2,15 @@ import * as avs_pb from "@/grpc_codegen/avs_pb";
2
2
  import TriggerReason from "./trigger/reason";
3
3
  import Step from "./step";
4
4
  export type StepProps = avs_pb.Execution.Step.AsObject;
5
- export type OutputDataProps = avs_pb.Execution.TransferLogOutput.AsObject | avs_pb.Execution.BlockOutput.AsObject | avs_pb.Execution.TimeOutput.AsObject | avs_pb.Evm.Log.AsObject | undefined;
6
- export type ExecutionProps = Omit<avs_pb.Execution.AsObject, "stepsList" | "reason" | "transferLog" | "evmLog" | "block" | "time"> & {
5
+ export type OutputDataProps = avs_pb.BlockTrigger.Output.AsObject | avs_pb.FixedTimeTrigger.Output.AsObject | avs_pb.CronTrigger.Output.AsObject | avs_pb.EventTrigger.Output.AsObject | avs_pb.EventTrigger.TransferLogOutput.AsObject | avs_pb.Evm.Log.AsObject | {
6
+ blockNumber: number;
7
+ } | {
8
+ epoch: number;
9
+ } | {
10
+ epoch: number;
11
+ scheduleMatched: string;
12
+ } | undefined;
13
+ export type ExecutionProps = Omit<avs_pb.Execution.AsObject, "stepsList" | "reason" | "blockTrigger" | "fixedTimeTrigger" | "cronTrigger" | "eventTrigger"> & {
7
14
  stepsList: Step[];
8
15
  triggerReason: TriggerReason | undefined;
9
16
  triggerOutput: OutputDataProps;
@@ -1 +1 @@
1
- {"version":3,"file":"execution.d.ts","sourceRoot":"","sources":["../../src/models/execution.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAChD,OAAO,aAAa,MAAM,kBAAkB,CAAC;AAC7C,OAAO,IAAI,MAAM,QAAQ,CAAC;AAE1B,MAAM,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;AAEvD,MAAM,MAAM,eAAe,GACvB,MAAM,CAAC,SAAS,CAAC,iBAAiB,CAAC,QAAQ,GAC3C,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,QAAQ,GACrC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,QAAQ,GACpC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,GACvB,SAAS,CAAC;AAGd,MAAM,MAAM,cAAc,GAAG,IAAI,CAC/B,MAAM,CAAC,SAAS,CAAC,QAAQ,EACzB,WAAW,GAAG,QAAQ,GAAG,aAAa,GAAG,QAAQ,GAAG,OAAO,GAAG,MAAM,CACrE,GAAG;IACF,SAAS,EAAE,IAAI,EAAE,CAAC;IAClB,aAAa,EAAE,aAAa,GAAG,SAAS,CAAC;IACzC,aAAa,EAAE,eAAe,CAAC;CAChC,CAAC;AAEF,cAAM,SAAU,YAAW,cAAc;IACvC,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,IAAI,EAAE,CAAC;IAClB,aAAa,EAAE,aAAa,GAAG,SAAS,CAAC;IACzC,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,eAAe,CAAC;gBAEnB,KAAK,EAAE,cAAc;IAYjC,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,SAAS,GAAG,SAAS;CAoC5D;AAED,eAAe,SAAS,CAAC"}
1
+ {"version":3,"file":"execution.d.ts","sourceRoot":"","sources":["../../src/models/execution.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAChD,OAAO,aAAa,MAAM,kBAAkB,CAAC;AAC7C,OAAO,IAAI,MAAM,QAAQ,CAAC;AAE1B,MAAM,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;AAEvD,MAAM,MAAM,eAAe,GACvB,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ,GACnC,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC,QAAQ,GACvC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,GAClC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ,GACnC,MAAM,CAAC,YAAY,CAAC,iBAAiB,CAAC,QAAQ,GAC9C,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,GACvB;IAAE,WAAW,EAAE,MAAM,CAAA;CAAE,GACvB;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,GACjB;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,eAAe,EAAE,MAAM,CAAA;CAAE,GAC1C,SAAS,CAAC;AAGd,MAAM,MAAM,cAAc,GAAG,IAAI,CAC/B,MAAM,CAAC,SAAS,CAAC,QAAQ,EACvB,WAAW,GACX,QAAQ,GACR,cAAc,GACd,kBAAkB,GAClB,aAAa,GACb,cAAc,CACjB,GAAG;IACF,SAAS,EAAE,IAAI,EAAE,CAAC;IAClB,aAAa,EAAE,aAAa,GAAG,SAAS,CAAC;IACzC,aAAa,EAAE,eAAe,CAAC;CAChC,CAAC;AAEF,cAAM,SAAU,YAAW,cAAc;IACvC,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,IAAI,EAAE,CAAC;IAClB,aAAa,EAAE,aAAa,GAAG,SAAS,CAAC;IACzC,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,eAAe,CAAC;gBAEnB,KAAK,EAAE,cAAc;IAYjC,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,SAAS,GAAG,SAAS;CAoD5D;AAED,eAAe,SAAS,CAAC"}
@@ -17,17 +17,34 @@ class Execution {
17
17
  const triggerOutputDataType = execution.getOutputDataCase();
18
18
  let triggerOutputData;
19
19
  switch (triggerOutputDataType) {
20
- case avs_pb.Execution.OutputDataCase.EVM_LOG:
21
- triggerOutputData = execution.getEvmLog()?.toObject();
20
+ case avs_pb.Execution.OutputDataCase.BLOCK_TRIGGER:
21
+ const blockOutput = execution.getBlockTrigger()?.toObject();
22
+ // Filter to only return blockNumber for block triggers
23
+ triggerOutputData = blockOutput ? { blockNumber: blockOutput.blockNumber } : undefined;
22
24
  break;
23
- case avs_pb.Execution.OutputDataCase.TRANSFER_LOG:
24
- triggerOutputData = execution.getTransferLog()?.toObject();
25
+ case avs_pb.Execution.OutputDataCase.FIXED_TIME_TRIGGER:
26
+ const fixedTimeOutput = execution.getFixedTimeTrigger()?.toObject();
27
+ // Filter to only return epoch for fixed time triggers
28
+ triggerOutputData = fixedTimeOutput ? { epoch: fixedTimeOutput.epoch } : undefined;
25
29
  break;
26
- case avs_pb.Execution.OutputDataCase.BLOCK:
27
- triggerOutputData = execution.getBlock()?.toObject();
30
+ case avs_pb.Execution.OutputDataCase.CRON_TRIGGER:
31
+ const cronOutput = execution.getCronTrigger()?.toObject();
32
+ // Filter to only return epoch and scheduleMatched for cron triggers
33
+ triggerOutputData = cronOutput ? { epoch: cronOutput.epoch, scheduleMatched: cronOutput.scheduleMatched } : undefined;
28
34
  break;
29
- case avs_pb.Execution.OutputDataCase.TIME:
30
- triggerOutputData = execution.getTime()?.toObject();
35
+ case avs_pb.Execution.OutputDataCase.EVENT_TRIGGER:
36
+ const eventTrigger = execution.getEventTrigger();
37
+ if (eventTrigger) {
38
+ if (eventTrigger.hasEvmLog()) {
39
+ triggerOutputData = eventTrigger.getEvmLog()?.toObject();
40
+ }
41
+ else if (eventTrigger.hasTransferLog()) {
42
+ triggerOutputData = eventTrigger.getTransferLog()?.toObject();
43
+ }
44
+ }
45
+ break;
46
+ case avs_pb.Execution.OutputDataCase.OUTPUT_DATA_NOT_SET:
47
+ triggerOutputData = undefined;
31
48
  break;
32
49
  }
33
50
  return new Execution({
@@ -1,7 +1,7 @@
1
1
  import { NodeProps } from "./interface";
2
2
  import Node from "./interface";
3
3
  import * as avs_pb from "@/grpc_codegen/avs_pb";
4
- export type BranchNodeData = avs_pb.BranchNode.AsObject;
4
+ export type BranchNodeData = avs_pb.BranchNode.Config.AsObject;
5
5
  export type BranchNodeProps = NodeProps & {
6
6
  data: BranchNodeData;
7
7
  };
@@ -1 +1 @@
1
- {"version":3,"file":"branch.d.ts","sourceRoot":"","sources":["../../../src/models/node/branch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAGhD,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;AACxD,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG;IACxC,IAAI,EAAE,cAAc,CAAC;CACtB,CAAC;AAEF,cAAM,UAAW,SAAQ,IAAI;gBACf,KAAK,EAAE,eAAe;IAIlC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,UAAU;IAUrD,SAAS,IAAI,MAAM,CAAC,QAAQ;CAuB7B;AACD,eAAe,UAAU,CAAC"}
1
+ {"version":3,"file":"branch.d.ts","sourceRoot":"","sources":["../../../src/models/node/branch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAGhD,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC;AAC/D,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG;IACxC,IAAI,EAAE,cAAc,CAAC;CACtB,CAAC;AAEF,cAAM,UAAW,SAAQ,IAAI;gBACf,KAAK,EAAE,eAAe;IAIlC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,UAAU;IAUrD,SAAS,IAAI,MAAM,CAAC,QAAQ;CAgC7B;AACD,eAAe,UAAU,CAAC"}
@@ -11,7 +11,7 @@ class BranchNode extends Node {
11
11
  return new BranchNode({
12
12
  ...obj,
13
13
  type: NodeType.Branch,
14
- data: raw.getBranch().toObject(),
14
+ data: raw.getBranch().toObject().config,
15
15
  });
16
16
  }
17
17
  toRequest() {
@@ -19,13 +19,19 @@ class BranchNode extends Node {
19
19
  request.setId(this.id);
20
20
  request.setName(this.name);
21
21
  const nodeData = new avs_pb.BranchNode();
22
- nodeData.setConditionsList(this.data.conditionsList.map((condition) => {
23
- const conditionObj = new avs_pb.Condition();
24
- conditionObj.setId(condition.id);
25
- conditionObj.setType(condition.type);
26
- conditionObj.setExpression(condition.expression);
27
- return conditionObj;
28
- }));
22
+ const config = new avs_pb.BranchNode.Config();
23
+ if (this.data.conditionsList &&
24
+ this.data.conditionsList.length > 0) {
25
+ const conditionsList = this.data.conditionsList.map((condition) => {
26
+ const conditionObj = new avs_pb.BranchNode.Condition();
27
+ conditionObj.setId(condition.id);
28
+ conditionObj.setType(condition.type);
29
+ conditionObj.setExpression(condition.expression);
30
+ return conditionObj;
31
+ });
32
+ config.setConditionsList(conditionsList);
33
+ }
34
+ nodeData.setConfig(config);
29
35
  request.setBranch(nodeData);
30
36
  return request;
31
37
  }
@@ -1 +1 @@
1
- {"version":3,"file":"contractRead.d.ts","sourceRoot":"","sources":["../../../src/models/node/contractRead.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,oBAAoB,GAAG,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC;AACpE,MAAM,MAAM,qBAAqB,GAAG,SAAS,GAAG;IAC9C,IAAI,EAAE,oBAAoB,CAAC;CAC5B,CAAC;AAEF,cAAM,gBAAiB,SAAQ,IAAI;gBACrB,KAAK,EAAE,qBAAqB;IAIxC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,gBAAgB;IAU3D,SAAS,IAAI,MAAM,CAAC,QAAQ;CAiB7B;AAED,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"contractRead.d.ts","sourceRoot":"","sources":["../../../src/models/node/contractRead.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,oBAAoB,GAAG,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC;AACpE,MAAM,MAAM,qBAAqB,GAAG,SAAS,GAAG;IAC9C,IAAI,EAAE,oBAAoB,CAAC;CAC5B,CAAC;AAEF,cAAM,gBAAiB,SAAQ,IAAI;gBACrB,KAAK,EAAE,qBAAqB;IAIxC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,gBAAgB;IAU3D,SAAS,IAAI,MAAM,CAAC,QAAQ;CAoB7B;AAED,eAAe,gBAAgB,CAAC"}
@@ -19,9 +19,13 @@ class ContractReadNode extends Node {
19
19
  request.setId(this.id);
20
20
  request.setName(this.name);
21
21
  const nodeData = new avs_pb.ContractReadNode();
22
- nodeData.setContractAddress(this.data.contractAddress);
23
- nodeData.setCallData(this.data.callData);
24
- nodeData.setContractAbi(this.data.contractAbi);
22
+ if (this.data.config) {
23
+ const config = new avs_pb.ContractReadNode.Config();
24
+ config.setContractAddress(this.data.config.contractAddress);
25
+ config.setCallData(this.data.config.callData);
26
+ config.setContractAbi(this.data.config.contractAbi);
27
+ nodeData.setConfig(config);
28
+ }
25
29
  request.setContractRead(nodeData);
26
30
  return request;
27
31
  }
@@ -1,7 +1,7 @@
1
1
  import { NodeProps } from "./interface";
2
2
  import Node from "./interface";
3
3
  import * as avs_pb from "@/grpc_codegen/avs_pb";
4
- export type ContractWriteNodeData = avs_pb.ContractWriteNode.AsObject;
4
+ export type ContractWriteNodeData = avs_pb.ContractWriteNode.Config.AsObject;
5
5
  export type ContractWriteNodeProps = NodeProps & {
6
6
  data: ContractWriteNodeData;
7
7
  };
@@ -1 +1 @@
1
- {"version":3,"file":"contractWrite.d.ts","sourceRoot":"","sources":["../../../src/models/node/contractWrite.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,qBAAqB,GAAG,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC;AACtE,MAAM,MAAM,sBAAsB,GAAG,SAAS,GAAG;IAC/C,IAAI,EAAE,qBAAqB,CAAC;CAC7B,CAAC;AAEF,cAAM,iBAAkB,SAAQ,IAAI;gBACtB,KAAK,EAAE,sBAAsB;IAIzC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,iBAAiB;IAU5D,SAAS,IAAI,MAAM,CAAC,QAAQ;CAiB7B;AAED,eAAe,iBAAiB,CAAC"}
1
+ {"version":3,"file":"contractWrite.d.ts","sourceRoot":"","sources":["../../../src/models/node/contractWrite.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,qBAAqB,GAAG,MAAM,CAAC,iBAAiB,CAAC,MAAM,CAAC,QAAQ,CAAC;AAC7E,MAAM,MAAM,sBAAsB,GAAG,SAAS,GAAG;IAC/C,IAAI,EAAE,qBAAqB,CAAC;CAC7B,CAAC;AAEF,cAAM,iBAAkB,SAAQ,IAAI;gBACtB,KAAK,EAAE,sBAAsB;IAIzC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,iBAAiB;IAU5D,SAAS,IAAI,MAAM,CAAC,QAAQ;CAkB7B;AAED,eAAe,iBAAiB,CAAC"}
@@ -11,7 +11,7 @@ class ContractWriteNode extends Node {
11
11
  return new ContractWriteNode({
12
12
  ...obj,
13
13
  type: NodeType.ContractWrite,
14
- data: raw.getContractWrite().toObject(),
14
+ data: raw.getContractWrite().getConfig().toObject(),
15
15
  });
16
16
  }
17
17
  toRequest() {
@@ -19,9 +19,11 @@ class ContractWriteNode extends Node {
19
19
  request.setId(this.id);
20
20
  request.setName(this.name);
21
21
  const nodeData = new avs_pb.ContractWriteNode();
22
- nodeData.setContractAddress(this.data.contractAddress);
23
- nodeData.setCallData(this.data.callData);
24
- nodeData.setContractAbi(this.data.contractAbi);
22
+ const config = new avs_pb.ContractWriteNode.Config();
23
+ config.setContractAddress(this.data.contractAddress);
24
+ config.setCallData(this.data.callData);
25
+ config.setContractAbi(this.data.contractAbi);
26
+ nodeData.setConfig(config);
25
27
  request.setContractWrite(nodeData);
26
28
  return request;
27
29
  }
@@ -2,7 +2,10 @@ import { NodeProps } from "./interface";
2
2
  import Node from "./interface";
3
3
  import * as avs_pb from "@/grpc_codegen/avs_pb";
4
4
  export type CustomCodeNodeData = avs_pb.CustomCodeNode.AsObject;
5
- export declare const CustomCodeLangs: typeof avs_pb.CustomCodeLang;
5
+ export declare const CustomCodeLangs: {
6
+ JAVASCRIPT: number;
7
+ PYTHON: number;
8
+ };
6
9
  export type CustomCodeNodeProps = NodeProps & {
7
10
  data: CustomCodeNodeData;
8
11
  };
@@ -1 +1 @@
1
- {"version":3,"file":"customCode.d.ts","sourceRoot":"","sources":["../../../src/models/node/customCode.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,kBAAkB,GAAG,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC;AAChE,eAAO,MAAM,eAAe,8BAAwB,CAAC;AACrD,MAAM,MAAM,mBAAmB,GAAG,SAAS,GAAG;IAC5C,IAAI,EAAE,kBAAkB,CAAC;CAC1B,CAAC;AAEF,cAAM,cAAe,SAAQ,IAAI;gBACnB,KAAK,EAAE,mBAAmB;IAItC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,cAAc;IAUzD,SAAS,IAAI,MAAM,CAAC,QAAQ;CAc7B;AAED,eAAe,cAAc,CAAC"}
1
+ {"version":3,"file":"customCode.d.ts","sourceRoot":"","sources":["../../../src/models/node/customCode.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,kBAAkB,GAAG,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC;AAChE,eAAO,MAAM,eAAe;;;CAG3B,CAAC;AACF,MAAM,MAAM,mBAAmB,GAAG,SAAS,GAAG;IAC5C,IAAI,EAAE,kBAAkB,CAAC;CAC1B,CAAC;AAEF,cAAM,cAAe,SAAQ,IAAI;gBACnB,KAAK,EAAE,mBAAmB;IAItC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,cAAc;IAUzD,SAAS,IAAI,MAAM,CAAC,QAAQ;CAmB7B;AAED,eAAe,cAAc,CAAC"}
@@ -1,7 +1,10 @@
1
1
  import Node from "./interface";
2
2
  import * as avs_pb from "@/grpc_codegen/avs_pb";
3
3
  import { NodeType } from "@avaprotocol/types";
4
- export const CustomCodeLangs = avs_pb.CustomCodeLang;
4
+ export const CustomCodeLangs = {
5
+ JAVASCRIPT: 0,
6
+ PYTHON: 1
7
+ };
5
8
  class CustomCodeNode extends Node {
6
9
  constructor(props) {
7
10
  super({ ...props, type: NodeType.CustomCode, data: props.data });
@@ -20,8 +23,12 @@ class CustomCodeNode extends Node {
20
23
  request.setId(this.id);
21
24
  request.setName(this.name);
22
25
  const nodeData = new avs_pb.CustomCodeNode();
23
- nodeData.setLang(this.data.lang);
24
- nodeData.setSource(this.data.source);
26
+ if (this.data.config) {
27
+ const config = new avs_pb.CustomCodeNode.Config();
28
+ config.setLang(this.data.config.lang);
29
+ config.setSource(this.data.config.source);
30
+ nodeData.setConfig(config);
31
+ }
25
32
  request.setCustomCode(nodeData);
26
33
  return request;
27
34
  }
@@ -1,7 +1,7 @@
1
1
  import { NodeProps } from "./interface";
2
2
  import Node from "./interface";
3
3
  import * as avs_pb from "@/grpc_codegen/avs_pb";
4
- export type ETHTransferNodeData = avs_pb.ETHTransferNode.AsObject;
4
+ export type ETHTransferNodeData = avs_pb.ETHTransferNode.Config.AsObject;
5
5
  export type ETHTransferNodeProps = NodeProps & {
6
6
  data: ETHTransferNodeData;
7
7
  };
@@ -1 +1 @@
1
- {"version":3,"file":"ethTransfer.d.ts","sourceRoot":"","sources":["../../../src/models/node/ethTransfer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,mBAAmB,GAAG,MAAM,CAAC,eAAe,CAAC,QAAQ,CAAC;AAClE,MAAM,MAAM,oBAAoB,GAAG,SAAS,GAAG;IAC7C,IAAI,EAAE,mBAAmB,CAAC;CAC3B,CAAC;AAEF,cAAM,eAAgB,SAAQ,IAAI;gBACpB,KAAK,EAAE,oBAAoB;IAIvC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,eAAe;IAU1D,SAAS,IAAI,MAAM,CAAC,QAAQ;CAc7B;AAED,eAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"ethTransfer.d.ts","sourceRoot":"","sources":["../../../src/models/node/ethTransfer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,mBAAmB,GAAG,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,QAAQ,CAAC;AACzE,MAAM,MAAM,oBAAoB,GAAG,SAAS,GAAG;IAC7C,IAAI,EAAE,mBAAmB,CAAC;CAC3B,CAAC;AAEF,cAAM,eAAgB,SAAQ,IAAI;gBACpB,KAAK,EAAE,oBAAoB;IAIvC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,eAAe;IAU1D,SAAS,IAAI,MAAM,CAAC,QAAQ;CAiB7B;AAED,eAAe,eAAe,CAAC"}
@@ -11,7 +11,7 @@ class ETHTransferNode extends Node {
11
11
  return new ETHTransferNode({
12
12
  ...obj,
13
13
  type: NodeType.ETHTransfer,
14
- data: raw.getEthTransfer().toObject(),
14
+ data: raw.getEthTransfer().getConfig().toObject(),
15
15
  });
16
16
  }
17
17
  toRequest() {
@@ -19,8 +19,10 @@ class ETHTransferNode extends Node {
19
19
  request.setId(this.id);
20
20
  request.setName(this.name);
21
21
  const nodeData = new avs_pb.ETHTransferNode();
22
- nodeData.setDestination(this.data.destination);
23
- nodeData.setAmount(this.data.amount);
22
+ const config = new avs_pb.ETHTransferNode.Config();
23
+ config.setDestination(this.data.destination);
24
+ config.setAmount(this.data.amount);
25
+ nodeData.setConfig(config);
24
26
  request.setEthTransfer(nodeData);
25
27
  return request;
26
28
  }
@@ -8,13 +8,14 @@ import ContractReadNode, { ContractReadNodeData, ContractReadNodeProps } from ".
8
8
  import ETHTransferNode, { ETHTransferNodeData, ETHTransferNodeProps } from "./ethTransfer";
9
9
  import BranchNode, { BranchNodeProps, BranchNodeData } from "./branch";
10
10
  import FilterNode, { FilterNodeData, FilterNodeProps } from "./filter";
11
+ import LoopNode, { LoopNodeData, LoopNodeProps } from "./loop";
11
12
  declare class NodeFactory {
12
13
  static create(props: NodeProps): Node;
13
14
  static createNodes(props: NodeProps[]): Node[];
14
15
  static fromResponse(raw: avs_pb.TaskNode): Node;
15
16
  }
16
17
  export default NodeFactory;
17
- export { Node, ContractWriteNode, ContractReadNode, BranchNode, ETHTransferNode, GraphQLQueryNode, RestAPINode, CustomCodeNode, CustomCodeLangs, FilterNode, };
18
- export type { ContractWriteNodeData, ContractReadNodeData, BranchNodeData, ETHTransferNodeData, GraphQLQueryNodeData, RestAPINodeData, CustomCodeNodeData, FilterNodeData, };
19
- export type { NodeProps, ContractWriteNodeProps, ContractReadNodeProps, BranchNodeProps, ETHTransferNodeProps, GraphQLQueryNodeProps, RestAPINodeProps, CustomCodeNodeProps, FilterNodeProps, };
18
+ export { Node, ContractWriteNode, ContractReadNode, BranchNode, ETHTransferNode, GraphQLQueryNode, RestAPINode, CustomCodeNode, CustomCodeLangs, FilterNode, LoopNode, };
19
+ export type { ContractWriteNodeData, ContractReadNodeData, BranchNodeData, ETHTransferNodeData, GraphQLQueryNodeData, RestAPINodeData, CustomCodeNodeData, FilterNodeData, LoopNodeData, };
20
+ export type { NodeProps, ContractWriteNodeProps, ContractReadNodeProps, BranchNodeProps, ETHTransferNodeProps, GraphQLQueryNodeProps, RestAPINodeProps, CustomCodeNodeProps, FilterNodeProps, LoopNodeProps, };
20
21
  //# sourceMappingURL=factory.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../src/models/node/factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAEhD,OAAO,iBAAiB,EAAE,EACxB,qBAAqB,EACrB,sBAAsB,EACvB,MAAM,iBAAiB,CAAC;AACzB,OAAO,cAAc,EAAE,EACrB,eAAe,EACf,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,cAAc,CAAC;AACtB,OAAO,gBAAgB,EAAE,EACvB,oBAAoB,EACpB,qBAAqB,EACtB,MAAM,gBAAgB,CAAC;AACxB,OAAO,IAAI,EAAE,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,WAAW,EAAE,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC3E,OAAO,gBAAgB,EAAE,EACvB,oBAAoB,EACpB,qBAAqB,EACtB,MAAM,gBAAgB,CAAC;AACxB,OAAO,eAAe,EAAE,EACtB,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,eAAe,CAAC;AACvB,OAAO,UAAU,EAAE,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AACvE,OAAO,UAAU,EAAE,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAGvE,cAAM,WAAW;IACf,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IA2BrC,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,EAAE;IAI9C,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,IAAI;CAsBhD;AAED,eAAe,WAAW,CAAC;AAG3B,OAAO,EACL,IAAI,EACJ,iBAAiB,EACjB,gBAAgB,EAChB,UAAU,EACV,eAAe,EACf,gBAAgB,EAChB,WAAW,EACX,cAAc,EACd,eAAe,EACf,UAAU,GACX,CAAC;AAGF,YAAY,EACV,qBAAqB,EACrB,oBAAoB,EACpB,cAAc,EACd,mBAAmB,EACnB,oBAAoB,EACpB,eAAe,EACf,kBAAkB,EAClB,cAAc,GACf,CAAC;AAGF,YAAY,EACV,SAAS,EACT,sBAAsB,EACtB,qBAAqB,EACrB,eAAe,EACf,oBAAoB,EACpB,qBAAqB,EACrB,gBAAgB,EAChB,mBAAmB,EACnB,eAAe,GAChB,CAAC"}
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../src/models/node/factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAEhD,OAAO,iBAAiB,EAAE,EACxB,qBAAqB,EACrB,sBAAsB,EACvB,MAAM,iBAAiB,CAAC;AACzB,OAAO,cAAc,EAAE,EACrB,eAAe,EACf,kBAAkB,EAClB,mBAAmB,EACpB,MAAM,cAAc,CAAC;AACtB,OAAO,gBAAgB,EAAE,EACvB,oBAAoB,EACpB,qBAAqB,EACtB,MAAM,gBAAgB,CAAC;AACxB,OAAO,IAAI,EAAE,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,WAAW,EAAE,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC3E,OAAO,gBAAgB,EAAE,EACvB,oBAAoB,EACpB,qBAAqB,EACtB,MAAM,gBAAgB,CAAC;AACxB,OAAO,eAAe,EAAE,EACtB,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,eAAe,CAAC;AACvB,OAAO,UAAU,EAAE,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AACvE,OAAO,UAAU,EAAE,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AACvE,OAAO,QAAQ,EAAE,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAG/D,cAAM,WAAW;IACf,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IA2BrC,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,EAAE;IAI9C,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,IAAI;CAwBhD;AAED,eAAe,WAAW,CAAC;AAG3B,OAAO,EACL,IAAI,EACJ,iBAAiB,EACjB,gBAAgB,EAChB,UAAU,EACV,eAAe,EACf,gBAAgB,EAChB,WAAW,EACX,cAAc,EACd,eAAe,EACf,UAAU,EACV,QAAQ,GACT,CAAC;AAGF,YAAY,EACV,qBAAqB,EACrB,oBAAoB,EACpB,cAAc,EACd,mBAAmB,EACnB,oBAAoB,EACpB,eAAe,EACf,kBAAkB,EAClB,cAAc,EACd,YAAY,GACb,CAAC;AAGF,YAAY,EACV,SAAS,EACT,sBAAsB,EACtB,qBAAqB,EACrB,eAAe,EACf,oBAAoB,EACpB,qBAAqB,EACrB,gBAAgB,EAChB,mBAAmB,EACnB,eAAe,EACf,aAAa,GACd,CAAC"}
@@ -8,6 +8,7 @@ import ContractReadNode from "./contractRead";
8
8
  import ETHTransferNode from "./ethTransfer";
9
9
  import BranchNode from "./branch";
10
10
  import FilterNode from "./filter";
11
+ import LoopNode from "./loop";
11
12
  import { NodeType } from "@avaprotocol/types";
12
13
  class NodeFactory {
13
14
  static create(props) {
@@ -29,7 +30,7 @@ class NodeFactory {
29
30
  case NodeType.Filter:
30
31
  return new FilterNode(props);
31
32
  case NodeType.Loop:
32
- throw new Error("Loop node type is not yet implemented");
33
+ return new LoopNode(props);
33
34
  case NodeType.Unset:
34
35
  throw new Error("Cannot create node with unset type");
35
36
  default:
@@ -57,6 +58,8 @@ class NodeFactory {
57
58
  return BranchNode.fromResponse(raw);
58
59
  case !!raw.getFilter():
59
60
  return FilterNode.fromResponse(raw);
61
+ case !!raw.getLoop():
62
+ return LoopNode.fromResponse(raw);
60
63
  default:
61
64
  throw new Error(`Unsupported node type: ${raw.getName()}`);
62
65
  }
@@ -64,4 +67,4 @@ class NodeFactory {
64
67
  }
65
68
  export default NodeFactory;
66
69
  // Node object definitions
67
- export { Node, ContractWriteNode, ContractReadNode, BranchNode, ETHTransferNode, GraphQLQueryNode, RestAPINode, CustomCodeNode, CustomCodeLangs, FilterNode, };
70
+ export { Node, ContractWriteNode, ContractReadNode, BranchNode, ETHTransferNode, GraphQLQueryNode, RestAPINode, CustomCodeNode, CustomCodeLangs, FilterNode, LoopNode, };
@@ -1 +1 @@
1
- {"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../../src/models/node/filter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;AACxD,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG;IACxC,IAAI,EAAE,cAAc,CAAC;CACtB,CAAC;AAEF,cAAM,UAAW,SAAQ,IAAI;gBACf,KAAK,EAAE,eAAe;IAIlC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,UAAU;IAUrD,SAAS,IAAI,MAAM,CAAC,QAAQ;CAa7B;AAED,eAAe,UAAU,CAAC"}
1
+ {"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../../src/models/node/filter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;AACxD,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG;IACxC,IAAI,EAAE,cAAc,CAAC;CACtB,CAAC;AAEF,cAAM,UAAW,SAAQ,IAAI;gBACf,KAAK,EAAE,eAAe;IAIlC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,UAAU;IAUrD,SAAS,IAAI,MAAM,CAAC,QAAQ;CAkB7B;AAED,eAAe,UAAU,CAAC"}
@@ -19,8 +19,12 @@ class FilterNode extends Node {
19
19
  request.setId(this.id);
20
20
  request.setName(this.name);
21
21
  const nodeData = new avs_pb.FilterNode();
22
- nodeData.setExpression(this.data.expression);
23
- nodeData.setInput(this.data.input);
22
+ if (this.data.config) {
23
+ const config = new avs_pb.FilterNode.Config();
24
+ config.setExpression(this.data.config.expression);
25
+ config.setSourceId(this.data.config.sourceId || '');
26
+ nodeData.setConfig(config);
27
+ }
24
28
  request.setFilter(nodeData);
25
29
  return request;
26
30
  }
@@ -1 +1 @@
1
- {"version":3,"file":"graphqlQuery.d.ts","sourceRoot":"","sources":["../../../src/models/node/graphqlQuery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,oBAAoB,GAAG,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC;AACpE,MAAM,MAAM,qBAAqB,GAAG,SAAS,GAAG;IAC9C,IAAI,EAAE,oBAAoB,CAAC;CAC5B,CAAC;AAEF,cAAM,gBAAiB,SAAQ,IAAI;gBACrB,KAAK,EAAE,qBAAqB;IAQxC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,gBAAgB;IAU3D,SAAS,IAAI,MAAM,CAAC,QAAQ;CAmB7B;AAED,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"graphqlQuery.d.ts","sourceRoot":"","sources":["../../../src/models/node/graphqlQuery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,oBAAoB,GAAG,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC;AACpE,MAAM,MAAM,qBAAqB,GAAG,SAAS,GAAG;IAC9C,IAAI,EAAE,oBAAoB,CAAC;CAC5B,CAAC;AAEF,cAAM,gBAAiB,SAAQ,IAAI;gBACrB,KAAK,EAAE,qBAAqB;IAQxC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,gBAAgB;IAU3D,SAAS,IAAI,MAAM,CAAC,QAAQ;CA4B7B;AAED,eAAe,gBAAgB,CAAC"}
@@ -23,13 +23,19 @@ class GraphQLQueryNode extends Node {
23
23
  request.setId(this.id);
24
24
  request.setName(this.name);
25
25
  const nodeData = new avs_pb.GraphQLQueryNode();
26
- nodeData.setUrl(this.data.url);
27
- nodeData.setQuery(this.data.query);
28
- const variables = this.data.variablesMap;
29
- const variablesMap = nodeData.getVariablesMap();
30
- variables.forEach(([key, value]) => {
31
- variablesMap.set(key, value);
32
- });
26
+ if (this.data.config) {
27
+ const config = new avs_pb.GraphQLQueryNode.Config();
28
+ config.setUrl(this.data.config.url);
29
+ config.setQuery(this.data.config.query);
30
+ if (this.data.config.variablesMap &&
31
+ this.data.config.variablesMap.length > 0) {
32
+ const variablesMap = config.getVariablesMap();
33
+ this.data.config.variablesMap.forEach(([key, value]) => {
34
+ variablesMap.set(key, value);
35
+ });
36
+ }
37
+ nodeData.setConfig(config);
38
+ }
33
39
  request.setGraphqlQuery(nodeData);
34
40
  return request;
35
41
  }
@@ -0,0 +1,13 @@
1
+ import * as avs_pb from "@/grpc_codegen/avs_pb";
2
+ import Node, { NodeProps } from "./interface";
3
+ export type LoopNodeData = avs_pb.LoopNode.AsObject;
4
+ export type LoopNodeProps = NodeProps & {
5
+ data: LoopNodeData;
6
+ };
7
+ declare class LoopNode extends Node {
8
+ constructor(props: LoopNodeProps);
9
+ static fromResponse(raw: avs_pb.TaskNode): LoopNode;
10
+ toRequest(): avs_pb.TaskNode;
11
+ }
12
+ export default LoopNode;
13
+ //# sourceMappingURL=loop.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loop.d.ts","sourceRoot":"","sources":["../../../src/models/node/loop.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAChD,OAAO,IAAI,EAAE,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAI9C,MAAM,MAAM,YAAY,GAAG,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC;AACpD,MAAM,MAAM,aAAa,GAAG,SAAS,GAAG;IACtC,IAAI,EAAE,YAAY,CAAC;CACpB,CAAC;AAEF,cAAM,QAAS,SAAQ,IAAI;gBACb,KAAK,EAAE,aAAa;IAIhC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,QAAQ;IAsCnD,SAAS,IAAI,MAAM,CAAC,QAAQ;CAuG7B;AAED,eAAe,QAAQ,CAAC"}
@@ -0,0 +1,145 @@
1
+ import * as avs_pb from "@/grpc_codegen/avs_pb";
2
+ import Node from "./interface";
3
+ import { NodeType } from "@avaprotocol/types";
4
+ class LoopNode extends Node {
5
+ constructor(props) {
6
+ super({ ...props, type: NodeType.Loop, data: props.data });
7
+ }
8
+ static fromResponse(raw) {
9
+ const loopNode = raw.getLoop();
10
+ if (!loopNode) {
11
+ throw new Error("Response does not contain a Loop node");
12
+ }
13
+ const loopNodeData = loopNode.toObject();
14
+ // Extract config properties to data level for easier access
15
+ if (loopNodeData.config) {
16
+ loopNodeData.input = loopNodeData.config.sourceId;
17
+ loopNodeData.iterVal = loopNodeData.config.iterVal;
18
+ loopNodeData.iterKey = loopNodeData.config.iterKey;
19
+ // Also determine runnerType based on which runner is present
20
+ if (loopNodeData.restApi) {
21
+ loopNodeData.runnerType = NodeType.RestAPI;
22
+ }
23
+ else if (loopNodeData.customCode) {
24
+ loopNodeData.runnerType = NodeType.CustomCode;
25
+ }
26
+ else if (loopNodeData.ethTransfer) {
27
+ loopNodeData.runnerType = NodeType.ETHTransfer;
28
+ }
29
+ else if (loopNodeData.contractRead) {
30
+ loopNodeData.runnerType = NodeType.ContractRead;
31
+ }
32
+ else if (loopNodeData.contractWrite) {
33
+ loopNodeData.runnerType = NodeType.ContractWrite;
34
+ }
35
+ else if (loopNodeData.graphqlDataQuery) {
36
+ loopNodeData.runnerType = NodeType.GraphQLQuery;
37
+ }
38
+ }
39
+ return new LoopNode({
40
+ id: raw.getId(),
41
+ name: raw.getName(),
42
+ type: NodeType.Loop,
43
+ data: loopNodeData,
44
+ });
45
+ }
46
+ toRequest() {
47
+ const node = new avs_pb.TaskNode();
48
+ const loopNode = new avs_pb.LoopNode();
49
+ node.setId(this.id);
50
+ node.setName(this.name);
51
+ const data = this.data;
52
+ // Set the loop config from data.config or direct properties
53
+ const config = new avs_pb.LoopNode.Config();
54
+ if (data.config) {
55
+ config.setSourceId(data.config.sourceId || "");
56
+ config.setIterVal(data.config.iterVal || "");
57
+ config.setIterKey(data.config.iterKey || "");
58
+ }
59
+ else {
60
+ // Handle direct properties for backward compatibility
61
+ config.setSourceId(data.input || data.sourceId || "");
62
+ config.setIterVal(data.iterVal || "");
63
+ config.setIterKey(data.iterKey || "");
64
+ }
65
+ loopNode.setConfig(config);
66
+ if (data.ethTransfer) {
67
+ const ethTransfer = new avs_pb.ETHTransferNode();
68
+ if (data.ethTransfer.config) {
69
+ const config = new avs_pb.ETHTransferNode.Config();
70
+ config.setDestination(data.ethTransfer.config.destination);
71
+ config.setAmount(data.ethTransfer.config.amount);
72
+ ethTransfer.setConfig(config);
73
+ }
74
+ loopNode.setEthTransfer(ethTransfer);
75
+ }
76
+ else if (data.contractWrite) {
77
+ const contractWrite = new avs_pb.ContractWriteNode();
78
+ if (data.contractWrite.config) {
79
+ const config = new avs_pb.ContractWriteNode.Config();
80
+ config.setContractAddress(data.contractWrite.config.contractAddress);
81
+ config.setCallData(data.contractWrite.config.callData);
82
+ config.setContractAbi(data.contractWrite.config.contractAbi);
83
+ contractWrite.setConfig(config);
84
+ }
85
+ loopNode.setContractWrite(contractWrite);
86
+ }
87
+ else if (data.contractRead) {
88
+ const contractRead = new avs_pb.ContractReadNode();
89
+ if (data.contractRead.config) {
90
+ const config = new avs_pb.ContractReadNode.Config();
91
+ config.setContractAddress(data.contractRead.config.contractAddress);
92
+ config.setCallData(data.contractRead.config.callData);
93
+ config.setContractAbi(data.contractRead.config.contractAbi);
94
+ contractRead.setConfig(config);
95
+ }
96
+ loopNode.setContractRead(contractRead);
97
+ }
98
+ else if (data.graphqlDataQuery) {
99
+ const graphqlQuery = new avs_pb.GraphQLQueryNode();
100
+ if (data.graphqlDataQuery.config) {
101
+ const config = new avs_pb.GraphQLQueryNode.Config();
102
+ config.setUrl(data.graphqlDataQuery.config.url);
103
+ config.setQuery(data.graphqlDataQuery.config.query);
104
+ if (data.graphqlDataQuery.config.variablesMap &&
105
+ data.graphqlDataQuery.config.variablesMap.length > 0) {
106
+ data.graphqlDataQuery.config.variablesMap.forEach(([key, value]) => {
107
+ config.getVariablesMap().set(key, value);
108
+ });
109
+ }
110
+ graphqlQuery.setConfig(config);
111
+ }
112
+ loopNode.setGraphqlDataQuery(graphqlQuery);
113
+ }
114
+ else if (data.restApi) {
115
+ const restApi = new avs_pb.RestAPINode();
116
+ if (data.restApi.config) {
117
+ const config = new avs_pb.RestAPINode.Config();
118
+ config.setUrl(data.restApi.config.url);
119
+ config.setMethod(data.restApi.config.method);
120
+ config.setBody(data.restApi.config.body || "");
121
+ if (data.restApi.config.headersMap &&
122
+ data.restApi.config.headersMap.length > 0) {
123
+ data.restApi.config.headersMap.forEach(([key, value]) => {
124
+ config.getHeadersMap().set(key, value);
125
+ });
126
+ }
127
+ restApi.setConfig(config);
128
+ }
129
+ loopNode.setRestApi(restApi);
130
+ }
131
+ else if (data.customCode) {
132
+ const customCode = new avs_pb.CustomCodeNode();
133
+ if (data.customCode.config) {
134
+ const config = new avs_pb.CustomCodeNode.Config();
135
+ config.setLang(data.customCode.config.lang);
136
+ config.setSource(data.customCode.config.source);
137
+ customCode.setConfig(config);
138
+ }
139
+ loopNode.setCustomCode(customCode);
140
+ }
141
+ node.setLoop(loopNode);
142
+ return node;
143
+ }
144
+ }
145
+ export default LoopNode;
@@ -1 +1 @@
1
- {"version":3,"file":"restApi.d.ts","sourceRoot":"","sources":["../../../src/models/node/restApi.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,eAAe,GAAG,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC;AAC1D,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC;AAEnE,MAAM,MAAM,gBAAgB,GAAG,SAAS,GAAG;IACzC,IAAI,EAAE,eAAe,CAAC;CACvB,CAAC;AAEF,cAAM,WAAY,SAAQ,IAAI;gBAChB,KAAK,EAAE,gBAAgB;IAInC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,WAAW;IAUtD,SAAS,IAAI,MAAM,CAAC,QAAQ;CAqB7B;AAED,eAAe,WAAW,CAAC"}
1
+ {"version":3,"file":"restApi.d.ts","sourceRoot":"","sources":["../../../src/models/node/restApi.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAIhD,MAAM,MAAM,eAAe,GAAG,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC;AAC1D,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC;AAEnE,MAAM,MAAM,gBAAgB,GAAG,SAAS,GAAG;IACzC,IAAI,EAAE,eAAe,CAAC;CACvB,CAAC;AAEF,cAAM,WAAY,SAAQ,IAAI;gBAChB,KAAK,EAAE,gBAAgB;IAInC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,GAAG,WAAW;IAUtD,SAAS,IAAI,MAAM,CAAC,QAAQ;CA6B7B;AAED,eAAe,WAAW,CAAC"}
@@ -19,14 +19,20 @@ class RestAPINode extends Node {
19
19
  request.setId(this.id);
20
20
  request.setName(this.name);
21
21
  const nodeData = new avs_pb.RestAPINode();
22
- nodeData.setUrl(this.data.url);
23
- nodeData.setMethod(this.data.method);
24
- nodeData.setBody(this.data.body);
25
- const headers = this.data.headersMap;
26
- const headersMap = nodeData.getHeadersMap();
27
- headers.forEach(([key, value]) => {
28
- headersMap.set(key, value);
29
- });
22
+ if (this.data.config) {
23
+ const config = new avs_pb.RestAPINode.Config();
24
+ config.setUrl(this.data.config.url);
25
+ config.setMethod(this.data.config.method);
26
+ config.setBody(this.data.config.body || "");
27
+ if (this.data.config.headersMap &&
28
+ this.data.config.headersMap.length > 0) {
29
+ const headersMap = config.getHeadersMap();
30
+ this.data.config.headersMap.forEach(([key, value]) => {
31
+ headersMap.set(key, value);
32
+ });
33
+ }
34
+ nodeData.setConfig(config);
35
+ }
30
36
  request.setRestApi(nodeData);
31
37
  return request;
32
38
  }
@@ -1,15 +1,14 @@
1
1
  import * as avs_pb from "@/grpc_codegen/avs_pb";
2
- export type SecretProps = {
3
- name: string;
4
- secret: string;
5
- workflowId?: string;
6
- orgId?: string;
7
- };
2
+ import { SecretProps } from "@avaprotocol/types";
8
3
  declare class Secret implements SecretProps {
9
4
  name: string;
10
- secret: string;
5
+ secret?: string;
11
6
  workflowId?: string;
12
7
  orgId?: string;
8
+ createdAt?: number;
9
+ updatedAt?: number;
10
+ createdBy?: string;
11
+ description?: string;
13
12
  constructor(props: SecretProps);
14
13
  toRequest(): avs_pb.CreateOrUpdateSecretReq;
15
14
  }
@@ -1 +1 @@
1
- {"version":3,"file":"secret.d.ts","sourceRoot":"","sources":["../../src/models/secret.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAEhD,MAAM,MAAM,WAAW,GAAG;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,cAAM,MAAO,YAAW,WAAW;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;gBAEH,KAAK,EAAE,WAAW;IAO9B,SAAS,IAAI,MAAM,CAAC,uBAAuB;CAc5C;AAED,eAAe,MAAM,CAAC"}
1
+ {"version":3,"file":"secret.d.ts","sourceRoot":"","sources":["../../src/models/secret.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,uBAAuB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,cAAM,MAAO,YAAW,WAAW;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;gBAET,KAAK,EAAE,WAAW;IAW9B,SAAS,IAAI,MAAM,CAAC,uBAAuB;CAgB5C;AAED,eAAe,MAAM,CAAC"}