@trustvc/trustvc 1.0.5 → 1.1.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 (184) hide show
  1. package/dist/{core → cjs/core}/documentBuilder.js +7 -5
  2. package/dist/cjs/core/endorsement-chain/fetchEscrowTransfer.js +167 -0
  3. package/dist/cjs/core/endorsement-chain/fetchTokenTransfer.js +58 -0
  4. package/dist/cjs/core/endorsement-chain/helpers.js +99 -0
  5. package/dist/cjs/core/endorsement-chain/index.js +47 -0
  6. package/dist/cjs/core/endorsement-chain/retrieveEndorsementChain.js +43 -0
  7. package/dist/cjs/core/endorsement-chain/useEndorsementChain.js +103 -0
  8. package/dist/{core → cjs/core}/index.js +7 -0
  9. package/dist/cjs/token-registry-v5/typedContractMethod.js +2 -0
  10. package/dist/cjs/verify/fragments/document-status/transferableRecords/transferableRecordVerifier.types.js +2 -0
  11. package/dist/cjs/w3c/types.js +2 -0
  12. package/dist/esm/core/documentBuilder.js +7 -5
  13. package/dist/esm/core/endorsement-chain/fetchEscrowTransfer.js +164 -0
  14. package/dist/esm/core/endorsement-chain/fetchTokenTransfer.js +56 -0
  15. package/dist/esm/core/endorsement-chain/helpers.js +94 -0
  16. package/dist/esm/core/endorsement-chain/index.js +6 -0
  17. package/dist/esm/core/endorsement-chain/retrieveEndorsementChain.js +41 -0
  18. package/dist/esm/core/endorsement-chain/types.js +1 -0
  19. package/dist/esm/core/endorsement-chain/useEndorsementChain.js +98 -0
  20. package/dist/esm/core/index.js +1 -0
  21. package/dist/esm/token-registry-v5/index.js +1 -1
  22. package/dist/esm/token-registry-v5/typedContractMethod.js +1 -1
  23. package/dist/esm/w3c/types.js +1 -2
  24. package/dist/types/core/endorsement-chain/fetchEscrowTransfer.d.ts +8 -0
  25. package/dist/types/core/endorsement-chain/fetchTokenTransfer.d.ts +8 -0
  26. package/dist/types/core/endorsement-chain/helpers.d.ts +11 -0
  27. package/dist/types/core/endorsement-chain/index.d.ts +11 -0
  28. package/dist/types/core/endorsement-chain/retrieveEndorsementChain.d.ts +8 -0
  29. package/dist/types/core/endorsement-chain/types.d.ts +50 -0
  30. package/dist/types/core/endorsement-chain/useEndorsementChain.d.ts +14 -0
  31. package/dist/types/core/index.d.ts +16 -0
  32. package/dist/{index-DK8Em_TZ.d.ts → types/index-BVNDN0vp.d.ts} +3 -2
  33. package/dist/{index.d.ts → types/index.d.ts} +13 -3
  34. package/dist/{token-registry-v5 → types/token-registry-v5}/index.d.ts +2 -1
  35. package/dist/{verify → types/verify}/fragments/document-status/transferableRecords/transferableRecordVerifier.types.d.ts +10 -1
  36. package/dist/{verify → types/verify}/fragments/index.d.ts +1 -1
  37. package/dist/{verify → types/verify}/index.d.ts +1 -1
  38. package/package.json +36 -36
  39. package/dist/constants.d.mts +0 -3
  40. package/dist/core/decrypt.d.mts +0 -3
  41. package/dist/core/documentBuilder.d.mts +0 -6
  42. package/dist/core/encrypt.d.mts +0 -3
  43. package/dist/core/index.d.mts +0 -5
  44. package/dist/core/index.d.ts +0 -5
  45. package/dist/core/verify.d.mts +0 -6
  46. package/dist/dnsprove/index.d.mts +0 -1
  47. package/dist/index-1ws_BWZW.d.mts +0 -22
  48. package/dist/index-CUw8WpjA.d.mts +0 -22
  49. package/dist/index-CjwEVGoM.d.mts +0 -22
  50. package/dist/index-ClF4_Nqk.d.mts +0 -22
  51. package/dist/index-DwAYXQn2.d.mts +0 -22
  52. package/dist/index.d.mts +0 -51
  53. package/dist/open-attestation/index.d.mts +0 -13
  54. package/dist/open-attestation/sign.d.mts +0 -9
  55. package/dist/open-attestation/types.d.mts +0 -9
  56. package/dist/open-attestation/utils.d.mts +0 -42
  57. package/dist/open-attestation/verify.d.mts +0 -5
  58. package/dist/open-attestation/wrap.d.mts +0 -9
  59. package/dist/token-registry-v4/contractAddress.d.mts +0 -13
  60. package/dist/token-registry-v4/contracts.d.mts +0 -1
  61. package/dist/token-registry-v4/index.d.mts +0 -3
  62. package/dist/token-registry-v4/roleHash.d.mts +0 -11
  63. package/dist/token-registry-v4/supportInterfaceIds.d.mts +0 -12
  64. package/dist/token-registry-v5/contractAddress.d.mts +0 -13
  65. package/dist/token-registry-v5/contracts.d.mts +0 -1
  66. package/dist/token-registry-v5/index.d.mts +0 -3
  67. package/dist/token-registry-v5/roleHash.d.mts +0 -11
  68. package/dist/token-registry-v5/supportInterfaceIds.d.mts +0 -12
  69. package/dist/token-registry-v5/typedContractMethod.d.mts +0 -9
  70. package/dist/token-registry-v5/typedContractMethod.js +0 -10
  71. package/dist/utils/errorMessages/index.d.mts +0 -1
  72. package/dist/utils/fragment/index.d.mts +0 -1
  73. package/dist/utils/index.d.mts +0 -4
  74. package/dist/utils/network/index.d.mts +0 -1
  75. package/dist/utils/stringUtils/index.d.mts +0 -9
  76. package/dist/utils/supportedChains/index.d.mts +0 -1
  77. package/dist/verify/fragments/document-integrity/w3cSignatureIntegrity.d.mts +0 -5
  78. package/dist/verify/fragments/document-status/transferableRecords/transferableRecordVerifier.d.mts +0 -7
  79. package/dist/verify/fragments/document-status/transferableRecords/transferableRecordVerifier.types.d.mts +0 -22
  80. package/dist/verify/fragments/document-status/transferableRecords/utils.d.mts +0 -18
  81. package/dist/verify/fragments/document-status/w3cCredentialStatus.d.mts +0 -5
  82. package/dist/verify/fragments/index.d.mts +0 -6
  83. package/dist/verify/fragments/issuer-identity/w3cIssuerIdentity.d.mts +0 -5
  84. package/dist/verify/index.d.mts +0 -9
  85. package/dist/verify/verify.d.mts +0 -29
  86. package/dist/w3c/context/index.d.mts +0 -1
  87. package/dist/w3c/credential-status/index.d.mts +0 -1
  88. package/dist/w3c/index.d.mts +0 -10
  89. package/dist/w3c/issuer/index.d.mts +0 -1
  90. package/dist/w3c/sign.d.mts +0 -6
  91. package/dist/w3c/types.d.mts +0 -2
  92. package/dist/w3c/types.js +0 -27
  93. package/dist/w3c/vc/index.d.mts +0 -1
  94. package/dist/w3c/verify.d.mts +0 -5
  95. package/dist/{constants.js → cjs/constants.js} +0 -0
  96. package/dist/{core → cjs/core}/decrypt.js +0 -0
  97. package/dist/{core → cjs/core}/encrypt.js +0 -0
  98. package/dist/{verify/fragments/document-status/transferableRecords/transferableRecordVerifier.types.js → cjs/core/endorsement-chain/types.js} +0 -0
  99. package/dist/{core → cjs/core}/verify.js +0 -0
  100. package/dist/{dnsprove → cjs/dnsprove}/index.js +0 -0
  101. package/dist/{index.js → cjs/index.js} +0 -0
  102. package/dist/{open-attestation → cjs/open-attestation}/index.js +0 -0
  103. package/dist/{open-attestation → cjs/open-attestation}/sign.js +0 -0
  104. package/dist/{open-attestation → cjs/open-attestation}/types.js +0 -0
  105. package/dist/{open-attestation → cjs/open-attestation}/utils.js +0 -0
  106. package/dist/{open-attestation → cjs/open-attestation}/verify.js +0 -0
  107. package/dist/{open-attestation → cjs/open-attestation}/wrap.js +0 -0
  108. package/dist/{token-registry-v4 → cjs/token-registry-v4}/contractAddress.js +0 -0
  109. package/dist/{token-registry-v4 → cjs/token-registry-v4}/contracts.js +0 -0
  110. package/dist/{token-registry-v4 → cjs/token-registry-v4}/index.js +0 -0
  111. package/dist/{token-registry-v4 → cjs/token-registry-v4}/roleHash.js +0 -0
  112. package/dist/{token-registry-v4 → cjs/token-registry-v4}/supportInterfaceIds.js +0 -0
  113. package/dist/{token-registry-v5 → cjs/token-registry-v5}/contractAddress.js +0 -0
  114. package/dist/{token-registry-v5 → cjs/token-registry-v5}/contracts.js +0 -0
  115. package/dist/{token-registry-v5 → cjs/token-registry-v5}/index.js +5 -5
  116. package/dist/{token-registry-v5 → cjs/token-registry-v5}/roleHash.js +0 -0
  117. package/dist/{token-registry-v5 → cjs/token-registry-v5}/supportInterfaceIds.js +0 -0
  118. package/dist/{utils → cjs/utils}/errorMessages/index.js +0 -0
  119. package/dist/{utils → cjs/utils}/fragment/index.js +0 -0
  120. package/dist/{utils → cjs/utils}/index.js +0 -0
  121. package/dist/{utils → cjs/utils}/network/index.js +0 -0
  122. package/dist/{utils → cjs/utils}/stringUtils/index.js +0 -0
  123. package/dist/{utils → cjs/utils}/supportedChains/index.js +0 -0
  124. package/dist/{verify → cjs/verify}/fragments/document-integrity/w3cSignatureIntegrity.js +0 -0
  125. package/dist/{verify → cjs/verify}/fragments/document-status/transferableRecords/transferableRecordVerifier.js +0 -0
  126. package/dist/{verify → cjs/verify}/fragments/document-status/transferableRecords/utils.js +0 -0
  127. package/dist/{verify → cjs/verify}/fragments/document-status/w3cCredentialStatus.js +0 -0
  128. package/dist/{verify → cjs/verify}/fragments/index.js +0 -0
  129. package/dist/{verify → cjs/verify}/fragments/issuer-identity/w3cIssuerIdentity.js +0 -0
  130. package/dist/{verify → cjs/verify}/index.js +0 -0
  131. package/dist/{verify → cjs/verify}/verify.js +0 -0
  132. package/dist/{w3c → cjs/w3c}/context/index.js +0 -0
  133. package/dist/{w3c → cjs/w3c}/credential-status/index.js +0 -0
  134. package/dist/{w3c → cjs/w3c}/index.js +0 -0
  135. package/dist/{w3c → cjs/w3c}/issuer/index.js +0 -0
  136. package/dist/{w3c → cjs/w3c}/sign.js +0 -0
  137. package/dist/{w3c → cjs/w3c}/vc/index.js +0 -0
  138. package/dist/{w3c → cjs/w3c}/verify.js +0 -0
  139. package/dist/{constants.d.ts → types/constants.d.ts} +0 -0
  140. package/dist/{core → types/core}/decrypt.d.ts +0 -0
  141. package/dist/{core → types/core}/documentBuilder.d.ts +0 -0
  142. package/dist/{core → types/core}/encrypt.d.ts +0 -0
  143. package/dist/{core → types/core}/verify.d.ts +0 -0
  144. package/dist/{dnsprove → types/dnsprove}/index.d.ts +0 -0
  145. package/dist/{index-1ws_BWZW.d.ts → types/index-1ws_BWZW.d.ts} +0 -0
  146. package/dist/{index-CjwEVGoM.d.ts → types/index-CjwEVGoM.d.ts} +0 -0
  147. package/dist/{index-ClF4_Nqk.d.ts → types/index-ClF4_Nqk.d.ts} +0 -0
  148. package/dist/{index-DwAYXQn2.d.ts → types/index-DwAYXQn2.d.ts} +0 -0
  149. package/dist/{open-attestation → types/open-attestation}/index.d.ts +0 -0
  150. package/dist/{open-attestation → types/open-attestation}/sign.d.ts +0 -0
  151. package/dist/{open-attestation → types/open-attestation}/types.d.ts +0 -0
  152. package/dist/{open-attestation → types/open-attestation}/utils.d.ts +0 -0
  153. package/dist/{open-attestation → types/open-attestation}/verify.d.ts +0 -0
  154. package/dist/{open-attestation → types/open-attestation}/wrap.d.ts +0 -0
  155. package/dist/{token-registry-v4 → types/token-registry-v4}/contractAddress.d.ts +0 -0
  156. package/dist/{token-registry-v4 → types/token-registry-v4}/contracts.d.ts +0 -0
  157. package/dist/{token-registry-v4 → types/token-registry-v4}/index.d.ts +0 -0
  158. package/dist/{token-registry-v4 → types/token-registry-v4}/roleHash.d.ts +0 -0
  159. package/dist/{token-registry-v4 → types/token-registry-v4}/supportInterfaceIds.d.ts +0 -0
  160. package/dist/{token-registry-v5 → types/token-registry-v5}/contractAddress.d.ts +0 -0
  161. package/dist/{token-registry-v5 → types/token-registry-v5}/contracts.d.ts +0 -0
  162. package/dist/{token-registry-v5 → types/token-registry-v5}/roleHash.d.ts +0 -0
  163. package/dist/{token-registry-v5 → types/token-registry-v5}/supportInterfaceIds.d.ts +0 -0
  164. package/dist/{token-registry-v5 → types/token-registry-v5}/typedContractMethod.d.ts +1 -1
  165. /package/dist/{utils → types/utils}/errorMessages/index.d.ts +0 -0
  166. /package/dist/{utils → types/utils}/fragment/index.d.ts +0 -0
  167. /package/dist/{utils → types/utils}/index.d.ts +0 -0
  168. /package/dist/{utils → types/utils}/network/index.d.ts +0 -0
  169. /package/dist/{utils → types/utils}/stringUtils/index.d.ts +0 -0
  170. /package/dist/{utils → types/utils}/supportedChains/index.d.ts +0 -0
  171. /package/dist/{verify → types/verify}/fragments/document-integrity/w3cSignatureIntegrity.d.ts +0 -0
  172. /package/dist/{verify → types/verify}/fragments/document-status/transferableRecords/transferableRecordVerifier.d.ts +0 -0
  173. /package/dist/{verify → types/verify}/fragments/document-status/transferableRecords/utils.d.ts +0 -0
  174. /package/dist/{verify → types/verify}/fragments/document-status/w3cCredentialStatus.d.ts +0 -0
  175. /package/dist/{verify → types/verify}/fragments/issuer-identity/w3cIssuerIdentity.d.ts +0 -0
  176. /package/dist/{verify → types/verify}/verify.d.ts +0 -0
  177. /package/dist/{w3c → types/w3c}/context/index.d.ts +0 -0
  178. /package/dist/{w3c → types/w3c}/credential-status/index.d.ts +0 -0
  179. /package/dist/{w3c → types/w3c}/index.d.ts +0 -0
  180. /package/dist/{w3c → types/w3c}/issuer/index.d.ts +0 -0
  181. /package/dist/{w3c → types/w3c}/sign.d.ts +0 -0
  182. /package/dist/{w3c → types/w3c}/types.d.ts +0 -0
  183. /package/dist/{w3c → types/w3c}/vc/index.d.ts +0 -0
  184. /package/dist/{w3c → types/w3c}/verify.d.ts +0 -0
@@ -2,12 +2,14 @@
2
2
 
3
3
  var __defProp = Object.defineProperty;
4
4
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
5
- const _DocumentBuilder = class _DocumentBuilder {
5
+ class DocumentBuilder {
6
+ static {
7
+ __name(this, "DocumentBuilder");
8
+ }
9
+ document;
6
10
  constructor() {
7
- this.document = new _DocumentBuilder();
11
+ this.document = new DocumentBuilder();
8
12
  }
9
- };
10
- __name(_DocumentBuilder, "DocumentBuilder");
11
- let DocumentBuilder = _DocumentBuilder;
13
+ }
12
14
 
13
15
  exports.DocumentBuilder = DocumentBuilder;
@@ -0,0 +1,167 @@
1
+ 'use strict';
2
+
3
+ var contracts = require('../../token-registry-v4/contracts');
4
+ var contracts$1 = require('../../token-registry-v5/contracts');
5
+
6
+ var __defProp = Object.defineProperty;
7
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
8
+ const fetchEscrowTransfersV4 = /* @__PURE__ */ __name(async (provider, address) => {
9
+ const titleEscrowContract = contracts.TitleEscrow__factory.connect(address, provider);
10
+ const holderChangeLogsDeferred = await fetchHolderTransfers(titleEscrowContract, provider);
11
+ const ownerChangeLogsDeferred = await fetchOwnerTransfers(titleEscrowContract, provider);
12
+ const [holderChangeLogs, ownerChangeLogs] = await Promise.all([
13
+ holderChangeLogsDeferred,
14
+ ownerChangeLogsDeferred
15
+ ]);
16
+ return [...holderChangeLogs, ...ownerChangeLogs];
17
+ }, "fetchEscrowTransfersV4");
18
+ const fetchEscrowTransfersV5 = /* @__PURE__ */ __name(async (provider, address) => {
19
+ const titleEscrowContract = contracts$1.TitleEscrow__factory.connect(address, provider);
20
+ const holderChangeLogsDeferred = await fetchAllTransfers(titleEscrowContract);
21
+ return holderChangeLogsDeferred;
22
+ }, "fetchEscrowTransfersV5");
23
+ const getParsedLogs = /* @__PURE__ */ __name((logs, titleEscrow) => {
24
+ return logs.map((log) => {
25
+ if (!log.blockNumber) throw new Error("Block number not present");
26
+ return {
27
+ ...log,
28
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
29
+ ...titleEscrow.interface.parseLog(log)
30
+ };
31
+ });
32
+ }, "getParsedLogs");
33
+ const fetchOwnerTransfers = /* @__PURE__ */ __name(async (titleEscrowContract, provider) => {
34
+ const ownerChangeFilter = titleEscrowContract.filters.BeneficiaryTransfer(null, null);
35
+ const ownerChangeLogs = await provider.getLogs({ ...ownerChangeFilter, fromBlock: 0 });
36
+ const ownerChangeLogsParsed = getParsedLogs(ownerChangeLogs, titleEscrowContract);
37
+ return ownerChangeLogsParsed.map((event) => ({
38
+ type: "TRANSFER_BENEFICIARY",
39
+ owner: event.args.toBeneficiary,
40
+ blockNumber: event.blockNumber,
41
+ transactionHash: event.transactionHash,
42
+ transactionIndex: event.transactionIndex
43
+ }));
44
+ }, "fetchOwnerTransfers");
45
+ const fetchHolderTransfers = /* @__PURE__ */ __name(async (titleEscrowContract, provider) => {
46
+ const holderChangeFilter = titleEscrowContract.filters.HolderTransfer(null, null);
47
+ const holderChangeLogs = await provider.getLogs({ ...holderChangeFilter, fromBlock: 0 });
48
+ const holderChangeLogsParsed = getParsedLogs(holderChangeLogs, titleEscrowContract);
49
+ return holderChangeLogsParsed.map((event) => ({
50
+ type: "TRANSFER_HOLDER",
51
+ blockNumber: event.blockNumber,
52
+ holder: event.args.toHolder,
53
+ transactionHash: event.transactionHash,
54
+ transactionIndex: event.transactionIndex
55
+ }));
56
+ }, "fetchHolderTransfers");
57
+ const fetchAllTransfers = /* @__PURE__ */ __name(async (titleEscrowContract) => {
58
+ const allFilters = [
59
+ titleEscrowContract.filters.HolderTransfer,
60
+ titleEscrowContract.filters.BeneficiaryTransfer,
61
+ titleEscrowContract.filters.TokenReceived,
62
+ titleEscrowContract.filters.ReturnToIssuer,
63
+ // titleEscrowContract.filters.Nomination,
64
+ titleEscrowContract.filters.RejectTransferOwners,
65
+ titleEscrowContract.filters.RejectTransferBeneficiary,
66
+ titleEscrowContract.filters.RejectTransferHolder,
67
+ titleEscrowContract.filters.Shred
68
+ ];
69
+ const allLogs = await Promise.all(
70
+ allFilters.map(async (filter) => {
71
+ const logs = await titleEscrowContract.queryFilter(filter, 0, "latest");
72
+ return logs;
73
+ })
74
+ );
75
+ const holderChangeLogsParsed = getParsedLogs(allLogs.flat(), titleEscrowContract);
76
+ const tokenRegistryAddress = await titleEscrowContract.registry();
77
+ return holderChangeLogsParsed.map((event) => {
78
+ if (event?.name === "HolderTransfer") {
79
+ return {
80
+ type: "TRANSFER_HOLDER",
81
+ blockNumber: event.blockNumber,
82
+ holder: event.args.toHolder,
83
+ transactionHash: event.transactionHash,
84
+ transactionIndex: event.transactionIndex,
85
+ remark: event.args?.remark
86
+ };
87
+ } else if (event?.name === "BeneficiaryTransfer") {
88
+ return {
89
+ type: "TRANSFER_BENEFICIARY",
90
+ owner: event.args.toBeneficiary,
91
+ blockNumber: event.blockNumber,
92
+ transactionHash: event.transactionHash,
93
+ transactionIndex: event.transactionIndex,
94
+ remark: event.args?.remark
95
+ };
96
+ } else if (event?.name === "TokenReceived") {
97
+ const type = identifyTokenReceivedType(event);
98
+ return {
99
+ type,
100
+ from: type === "INITIAL" ? "0x0000000000000000000000000000000000000000" : tokenRegistryAddress,
101
+ to: titleEscrowContract.address,
102
+ blockNumber: event.blockNumber,
103
+ transactionHash: event.transactionHash,
104
+ transactionIndex: event.transactionIndex,
105
+ remark: event.args?.remark
106
+ };
107
+ } else if (event?.name === "ReturnToIssuer") {
108
+ return {
109
+ type: "RETURNED_TO_ISSUER",
110
+ blockNumber: event.blockNumber,
111
+ from: titleEscrowContract.address,
112
+ to: tokenRegistryAddress,
113
+ transactionHash: event.transactionHash,
114
+ transactionIndex: event.transactionIndex,
115
+ remark: event.args?.remark
116
+ };
117
+ } else if (event?.name === "Nomination") {
118
+ return void 0;
119
+ } else if (event?.name === "RejectTransferOwners") {
120
+ return {
121
+ type: "REJECT_TRANSFER_OWNERS",
122
+ blockNumber: event.blockNumber,
123
+ transactionHash: event.transactionHash,
124
+ transactionIndex: event.transactionIndex,
125
+ remark: event.args?.remark
126
+ };
127
+ } else if (event?.name === "RejectTransferBeneficiary") {
128
+ return {
129
+ type: "REJECT_TRANSFER_BENEFICIARY",
130
+ blockNumber: event.blockNumber,
131
+ transactionHash: event.transactionHash,
132
+ transactionIndex: event.transactionIndex,
133
+ remark: event.args?.remark
134
+ };
135
+ } else if (event?.name === "RejectTransferHolder") {
136
+ return {
137
+ type: "REJECT_TRANSFER_HOLDER",
138
+ blockNumber: event.blockNumber,
139
+ transactionHash: event.transactionHash,
140
+ transactionIndex: event.transactionIndex,
141
+ remark: event.args?.remark
142
+ };
143
+ } else if (event?.name === "Shred") {
144
+ return {
145
+ type: "RETURN_TO_ISSUER_ACCEPTED",
146
+ blockNumber: event.blockNumber,
147
+ from: tokenRegistryAddress,
148
+ to: "0x00000000000000000000000000000000000dead",
149
+ transactionHash: event.transactionHash,
150
+ transactionIndex: event.transactionIndex,
151
+ remark: event.args?.remark
152
+ };
153
+ }
154
+ return void 0;
155
+ }).filter((event) => event !== void 0);
156
+ }, "fetchAllTransfers");
157
+ function identifyTokenReceivedType(event) {
158
+ if (event.args.isMinting) {
159
+ return "INITIAL";
160
+ } else {
161
+ return "RETURN_TO_ISSUER_REJECTED";
162
+ }
163
+ }
164
+ __name(identifyTokenReceivedType, "identifyTokenReceivedType");
165
+
166
+ exports.fetchEscrowTransfersV4 = fetchEscrowTransfersV4;
167
+ exports.fetchEscrowTransfersV5 = fetchEscrowTransfersV5;
@@ -0,0 +1,58 @@
1
+ 'use strict';
2
+
3
+ var helpers = require('../endorsement-chain/helpers');
4
+
5
+ var __defProp = Object.defineProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
+ const fetchTokenTransfers = /* @__PURE__ */ __name(async (tokenRegistry, tokenId) => {
8
+ const logs = await fetchLogs(tokenRegistry, tokenId);
9
+ const parsedLogs = parseLogs(logs, tokenRegistry);
10
+ const tokenRegistryAddress = tokenRegistry.address;
11
+ const reformattedLogs = parsedLogs.map(
12
+ (event) => formatTokenTransferEvent(event, tokenRegistryAddress)
13
+ );
14
+ helpers.sortLogChain(reformattedLogs);
15
+ return reformattedLogs;
16
+ }, "fetchTokenTransfers");
17
+ const fetchLogs = /* @__PURE__ */ __name(async (tokenRegistry, tokenId) => {
18
+ const transferLogFilter = tokenRegistry.filters.Transfer(null, null, tokenId);
19
+ const logs = await tokenRegistry.queryFilter(transferLogFilter, 0);
20
+ if (logs.length === 0) {
21
+ throw new Error("Unminted Title Escrow");
22
+ }
23
+ return logs;
24
+ }, "fetchLogs");
25
+ const parseLogs = /* @__PURE__ */ __name((logs, tokenRegistry) => {
26
+ return logs.map((log) => {
27
+ if (!log.args) throw new Error(`Transfer log malformed: ${log}`);
28
+ if (!log.blockNumber) throw new Error("Block number not present");
29
+ if (!log.transactionHash) throw new Error("Transaction hash not present");
30
+ return {
31
+ ...log,
32
+ ...tokenRegistry.interface.parseLog(log)
33
+ };
34
+ });
35
+ }, "parseLogs");
36
+ const formatTokenTransferEvent = /* @__PURE__ */ __name((event, tokenRegistryAddress) => {
37
+ const type = identifyTokenTransferEvent(event, tokenRegistryAddress);
38
+ return {
39
+ type,
40
+ from: event.args.from,
41
+ to: event.args.to,
42
+ blockNumber: event.blockNumber,
43
+ transactionHash: event.transactionHash,
44
+ transactionIndex: event.transactionIndex
45
+ };
46
+ }, "formatTokenTransferEvent");
47
+ const identifyTokenTransferEvent = /* @__PURE__ */ __name((log, tokenRegistryAddress) => {
48
+ const InitialAddress = "0x0000000000000000000000000000000000000000";
49
+ const BurnAddress = "0x000000000000000000000000000000000000dEaD";
50
+ const { from, to } = log.args;
51
+ if (to === tokenRegistryAddress) return "SURRENDERED";
52
+ if (to === BurnAddress) return "SURRENDER_ACCEPTED";
53
+ if (from === tokenRegistryAddress) return "SURRENDER_REJECTED";
54
+ if (from === InitialAddress) return "INITIAL";
55
+ throw new Error("Unidentified transfer event");
56
+ }, "identifyTokenTransferEvent");
57
+
58
+ exports.fetchTokenTransfers = fetchTokenTransfers;
@@ -0,0 +1,99 @@
1
+ 'use strict';
2
+
3
+ var lodash = require('lodash');
4
+
5
+ var __defProp = Object.defineProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
+ const fetchEventTime = /* @__PURE__ */ __name(async (blockNumber, provider) => {
8
+ const msecToSec = 1e3;
9
+ const eventTimestamp = (await provider.getBlock(blockNumber)).timestamp * msecToSec;
10
+ return eventTimestamp;
11
+ }, "fetchEventTime");
12
+ const getHolderOwner = /* @__PURE__ */ __name((events) => {
13
+ let owner = "";
14
+ let holder = "";
15
+ for (const event of events) {
16
+ owner = event.owner || owner;
17
+ holder = event.holder || holder;
18
+ }
19
+ return { owner, holder };
20
+ }, "getHolderOwner");
21
+ const mergeTransfersV4 = /* @__PURE__ */ __name((transferEvents) => {
22
+ const groupedEventsDict = lodash.groupBy(
23
+ transferEvents,
24
+ "transactionHash"
25
+ );
26
+ const transactionHashValues = Object.values(groupedEventsDict);
27
+ const mergedTransaction = transactionHashValues.flatMap((groupedEvents) => {
28
+ if (groupedEvents.length === 1) return groupedEvents;
29
+ if (groupedEvents.length === 2) {
30
+ const type = "TRANSFER_OWNERS";
31
+ const base = groupedEvents[0];
32
+ const { owner, holder } = getHolderOwner(groupedEvents);
33
+ return [{ ...base, type, owner, holder }];
34
+ }
35
+ if (groupedEvents.length === 3) {
36
+ const base = groupedEvents[0];
37
+ const type = "INITIAL";
38
+ const { owner, holder } = getHolderOwner(groupedEvents);
39
+ const found = groupedEvents.find((x) => {
40
+ return x.type === "INITIAL" || x.type === "SURRENDER_ACCEPTED";
41
+ });
42
+ return [{ ...base, owner, holder, type: found?.type || type }];
43
+ }
44
+ throw new Error("Invalid hash, update your configuration");
45
+ });
46
+ return mergedTransaction;
47
+ }, "mergeTransfersV4");
48
+ const mergeTransfersV5 = /* @__PURE__ */ __name((transferEvents) => {
49
+ const groupedEventsDict = lodash.groupBy(
50
+ transferEvents,
51
+ "transactionHash"
52
+ );
53
+ const transactionHashValues = Object.values(groupedEventsDict);
54
+ const mergedTransaction = transactionHashValues.flatMap((groupedEvents) => {
55
+ if (groupedEvents.length === 1) return groupedEvents;
56
+ if (groupedEvents.length > 1) {
57
+ const { owner, holder } = getHolderOwner(groupedEvents);
58
+ const base = groupedEvents[0];
59
+ const type = identifyEventTypeFromLogs(groupedEvents);
60
+ return [{ ...base, owner, holder, type }];
61
+ }
62
+ throw new Error("Invalid hash, update your configuration");
63
+ });
64
+ return mergedTransaction;
65
+ }, "mergeTransfersV5");
66
+ const identifyEventTypeFromLogs = /* @__PURE__ */ __name((groupedEvents) => {
67
+ for (const event of groupedEvents) {
68
+ if ([
69
+ "INITIAL",
70
+ "RETURNED_TO_ISSUER",
71
+ "RETURN_TO_ISSUER_ACCEPTED",
72
+ "RETURN_TO_ISSUER_REJECTED"
73
+ ].includes(event.type) || event.type.startsWith("REJECT_")) {
74
+ return event.type;
75
+ }
76
+ }
77
+ const isTransferHolder = groupedEvents.some((event) => event.type === "TRANSFER_HOLDER");
78
+ const isTransferBeneficiary = groupedEvents.some(
79
+ (event) => event.type === "TRANSFER_BENEFICIARY"
80
+ );
81
+ if (isTransferHolder && isTransferBeneficiary) {
82
+ return "TRANSFER_OWNERS";
83
+ } else if (isTransferHolder) {
84
+ return "TRANSFER_HOLDER";
85
+ } else if (isTransferBeneficiary) {
86
+ return "TRANSFER_BENEFICIARY";
87
+ }
88
+ throw new Error("Unable to identify event type");
89
+ }, "identifyEventTypeFromLogs");
90
+ const sortLogChain = /* @__PURE__ */ __name((logChain) => {
91
+ return logChain.sort((a, b) => {
92
+ return a.blockNumber - b.blockNumber;
93
+ });
94
+ }, "sortLogChain");
95
+
96
+ exports.fetchEventTime = fetchEventTime;
97
+ exports.mergeTransfersV4 = mergeTransfersV4;
98
+ exports.mergeTransfersV5 = mergeTransfersV5;
99
+ exports.sortLogChain = sortLogChain;
@@ -0,0 +1,47 @@
1
+ 'use strict';
2
+
3
+ var fetchEscrowTransfer = require('./fetchEscrowTransfer');
4
+ var fetchTokenTransfer = require('./fetchTokenTransfer');
5
+ var helpers = require('./helpers');
6
+ var retrieveEndorsementChain = require('./retrieveEndorsementChain');
7
+ var types = require('./types');
8
+ var useEndorsementChain = require('./useEndorsementChain');
9
+
10
+
11
+
12
+ Object.keys(fetchEscrowTransfer).forEach(function (k) {
13
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
14
+ enumerable: true,
15
+ get: function () { return fetchEscrowTransfer[k]; }
16
+ });
17
+ });
18
+ Object.keys(fetchTokenTransfer).forEach(function (k) {
19
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
20
+ enumerable: true,
21
+ get: function () { return fetchTokenTransfer[k]; }
22
+ });
23
+ });
24
+ Object.keys(helpers).forEach(function (k) {
25
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
26
+ enumerable: true,
27
+ get: function () { return helpers[k]; }
28
+ });
29
+ });
30
+ Object.keys(retrieveEndorsementChain).forEach(function (k) {
31
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
32
+ enumerable: true,
33
+ get: function () { return retrieveEndorsementChain[k]; }
34
+ });
35
+ });
36
+ Object.keys(types).forEach(function (k) {
37
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
38
+ enumerable: true,
39
+ get: function () { return types[k]; }
40
+ });
41
+ });
42
+ Object.keys(useEndorsementChain).forEach(function (k) {
43
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
44
+ enumerable: true,
45
+ get: function () { return useEndorsementChain[k]; }
46
+ });
47
+ });
@@ -0,0 +1,43 @@
1
+ 'use strict';
2
+
3
+ var helpers = require('../endorsement-chain/helpers');
4
+
5
+ var __defProp = Object.defineProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
+ const getEndorsementChain = /* @__PURE__ */ __name(async (provider, logChain) => {
8
+ const historyChain = [];
9
+ helpers.sortLogChain(logChain);
10
+ let previousBeneficiary = "";
11
+ let previousHolder = "";
12
+ const timestampPromises = logChain.map((log) => helpers.fetchEventTime(log.blockNumber, provider));
13
+ const timestamps = await Promise.all(timestampPromises);
14
+ logChain.forEach((log, index) => {
15
+ const timestamp = timestamps[index];
16
+ const transactionDetails = {
17
+ type: log.type,
18
+ transactionHash: log.transactionHash,
19
+ transactionIndex: log.transactionIndex,
20
+ blockNumber: log.blockNumber,
21
+ owner: log.owner || previousBeneficiary,
22
+ holder: log.holder || previousHolder,
23
+ timestamp,
24
+ remark: log?.remark || ""
25
+ };
26
+ if (log.type === "TRANSFER_OWNERS" || log.type === "TRANSFER_BENEFICIARY" || log.type === "TRANSFER_HOLDER" || log.type === "INITIAL") {
27
+ historyChain.push(transactionDetails);
28
+ previousHolder = transactionDetails.holder;
29
+ previousBeneficiary = transactionDetails.owner;
30
+ } else if (log.type === "SURRENDER_ACCEPTED" || log.type === "RETURN_TO_ISSUER_ACCEPTED") {
31
+ previousHolder = "";
32
+ previousBeneficiary = "";
33
+ historyChain.push(transactionDetails);
34
+ } else if (log.type === "SURRENDERED" || log.type === "SURRENDER_REJECTED" || log.type === "RETURNED_TO_ISSUER" || log.type === "RETURN_TO_ISSUER_REJECTED") {
35
+ historyChain.push(transactionDetails);
36
+ } else {
37
+ historyChain.push(transactionDetails);
38
+ }
39
+ });
40
+ return historyChain;
41
+ }, "getEndorsementChain");
42
+
43
+ exports.getEndorsementChain = getEndorsementChain;
@@ -0,0 +1,103 @@
1
+ 'use strict';
2
+
3
+ var ethers = require('ethers');
4
+ var decrypt = require('../decrypt');
5
+ var fetchEscrowTransfer = require('../endorsement-chain/fetchEscrowTransfer');
6
+ var fetchTokenTransfer = require('../endorsement-chain/fetchTokenTransfer');
7
+ var helpers = require('../endorsement-chain/helpers');
8
+ var retrieveEndorsementChain = require('../endorsement-chain/retrieveEndorsementChain');
9
+ var contracts = require('../../token-registry-v4/contracts');
10
+ var supportInterfaceIds = require('../../token-registry-v4/supportInterfaceIds');
11
+ var supportInterfaceIds$1 = require('../../token-registry-v5/supportInterfaceIds');
12
+
13
+ var __defProp = Object.defineProperty;
14
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
15
+ const TitleEscrowInterface = {
16
+ V4: supportInterfaceIds.supportInterfaceIds.TitleEscrow,
17
+ V5: supportInterfaceIds$1.supportInterfaceIds.TitleEscrow
18
+ };
19
+ const fetchTitleEscrowFactoryAddress = /* @__PURE__ */ __name(async (tokenRegistry) => {
20
+ return tokenRegistry.titleEscrowFactory();
21
+ }, "fetchTitleEscrowFactoryAddress");
22
+ const resolveTitleEscrowAddress = /* @__PURE__ */ __name(async (titleEscrowFactoryContract, tokenRegistryAddress, tokenId) => {
23
+ try {
24
+ return await titleEscrowFactoryContract.getEscrowAddress(tokenRegistryAddress, tokenId);
25
+ } catch {
26
+ return titleEscrowFactoryContract.getAddress(tokenRegistryAddress, tokenId);
27
+ }
28
+ }, "resolveTitleEscrowAddress");
29
+ const getTitleEscrowAddress = /* @__PURE__ */ __name(async (tokenRegistryAddress, tokenId, provider) => {
30
+ const tokenRegistryAbi = [
31
+ "function titleEscrowFactory() external view returns (address)",
32
+ "function ownerOf(uint256 tokenId) view returns (address)"
33
+ ];
34
+ const tokenRegistry = new ethers.ethers.Contract(tokenRegistryAddress, tokenRegistryAbi, provider);
35
+ const titleEscrowOwner = await tokenRegistry.ownerOf(tokenId);
36
+ const BURN_ADDRESS = "0x000000000000000000000000000000000000dEaD";
37
+ const isInactiveEscrow = [BURN_ADDRESS, tokenRegistryAddress].map((address) => address.toLowerCase()).includes(titleEscrowOwner.toLowerCase());
38
+ if (!isInactiveEscrow) return titleEscrowOwner;
39
+ const titleEscrowFactoryAddress = await fetchTitleEscrowFactoryAddress(tokenRegistry);
40
+ const titleEscrowFactoryContract = new ethers.ethers.Contract(
41
+ titleEscrowFactoryAddress,
42
+ [
43
+ "function getAddress(address, uint256) view returns (address)",
44
+ "function getEscrowAddress(address, uint256) view returns (address)"
45
+ ],
46
+ provider
47
+ );
48
+ return resolveTitleEscrowAddress(titleEscrowFactoryContract, tokenRegistryAddress, tokenId);
49
+ }, "getTitleEscrowAddress");
50
+ const checkSupportsInterface = /* @__PURE__ */ __name(async (titleEscrowAddress, interfaceId, provider) => {
51
+ try {
52
+ const titleEscrowAbi = [
53
+ "function supportsInterface(bytes4 interfaceId) external view returns (bool)"
54
+ ];
55
+ const titleEscrowContract = new ethers.ethers.Contract(titleEscrowAddress, titleEscrowAbi, provider);
56
+ return await titleEscrowContract.supportsInterface(interfaceId);
57
+ } catch {
58
+ return false;
59
+ }
60
+ }, "checkSupportsInterface");
61
+ const isTitleEscrowVersion = /* @__PURE__ */ __name(async (versionInterface, tokenRegistryAddress, tokenId, provider) => {
62
+ try {
63
+ const titleEscrowAddress = await getTitleEscrowAddress(tokenRegistryAddress, tokenId, provider);
64
+ return await checkSupportsInterface(titleEscrowAddress, versionInterface, provider);
65
+ } catch {
66
+ return false;
67
+ }
68
+ }, "isTitleEscrowVersion");
69
+ const fetchEndorsementChain = /* @__PURE__ */ __name(async (tokenRegistry, tokenId, provider, keyId) => {
70
+ if (!tokenRegistry || !tokenId || !provider) {
71
+ throw new Error("Missing required dependencies");
72
+ }
73
+ const [isV4, isV5] = await Promise.all([
74
+ isTitleEscrowVersion(TitleEscrowInterface.V4, tokenRegistry, tokenId, provider),
75
+ isTitleEscrowVersion(TitleEscrowInterface.V5, tokenRegistry, tokenId, provider)
76
+ ]);
77
+ if (!isV4 && !isV5) {
78
+ throw new Error("Only Token Registry V4/V5 is supported");
79
+ }
80
+ const titleEscrowAddress = await getTitleEscrowAddress(tokenRegistry, tokenId, provider);
81
+ let transferEvents = [];
82
+ if (isV4) {
83
+ const tokenRegistryContract = contracts.TradeTrustToken__factory.connect(tokenRegistry, provider);
84
+ const [tokenLogs, titleEscrowLogs] = await Promise.all([
85
+ fetchTokenTransfer.fetchTokenTransfers(tokenRegistryContract, tokenId),
86
+ fetchEscrowTransfer.fetchEscrowTransfersV4(provider, titleEscrowAddress)
87
+ ]);
88
+ transferEvents = helpers.mergeTransfersV4([...titleEscrowLogs, ...tokenLogs]);
89
+ } else if (isV5) {
90
+ const titleEscrowLogs = await fetchEscrowTransfer.fetchEscrowTransfersV5(provider, titleEscrowAddress);
91
+ transferEvents = helpers.mergeTransfersV5(titleEscrowLogs);
92
+ }
93
+ const endorsementChain = await retrieveEndorsementChain.getEndorsementChain(provider, transferEvents);
94
+ return isV4 ? endorsementChain : endorsementChain.map((event) => ({
95
+ ...event,
96
+ remark: event?.remark?.slice(2) ? decrypt.decrypt(event.remark.slice(2), keyId ?? "") : ""
97
+ }));
98
+ }, "fetchEndorsementChain");
99
+
100
+ exports.TitleEscrowInterface = TitleEscrowInterface;
101
+ exports.fetchEndorsementChain = fetchEndorsementChain;
102
+ exports.getTitleEscrowAddress = getTitleEscrowAddress;
103
+ exports.isTitleEscrowVersion = isTitleEscrowVersion;
@@ -3,6 +3,7 @@
3
3
  var decrypt = require('./decrypt');
4
4
  var encrypt = require('./encrypt');
5
5
  var verify = require('./verify');
6
+ var endorsementChain = require('./endorsement-chain');
6
7
 
7
8
 
8
9
 
@@ -24,3 +25,9 @@ Object.keys(verify).forEach(function (k) {
24
25
  get: function () { return verify[k]; }
25
26
  });
26
27
  });
28
+ Object.keys(endorsementChain).forEach(function (k) {
29
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
30
+ enumerable: true,
31
+ get: function () { return endorsementChain[k]; }
32
+ });
33
+ });
@@ -0,0 +1,2 @@
1
+ 'use strict';
2
+
@@ -0,0 +1,2 @@
1
+ 'use strict';
2
+
@@ -1,11 +1,13 @@
1
1
  var __defProp = Object.defineProperty;
2
2
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
- const _DocumentBuilder = class _DocumentBuilder {
3
+ class DocumentBuilder {
4
+ static {
5
+ __name(this, "DocumentBuilder");
6
+ }
7
+ document;
4
8
  constructor() {
5
- this.document = new _DocumentBuilder();
9
+ this.document = new DocumentBuilder();
6
10
  }
7
- };
8
- __name(_DocumentBuilder, "DocumentBuilder");
9
- let DocumentBuilder = _DocumentBuilder;
11
+ }
10
12
 
11
13
  export { DocumentBuilder };