@hashgraphonline/standards-sdk 0.1.141-canary.4 → 0.1.141-canary.40

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 (272) hide show
  1. package/README.md +13 -1
  2. package/dist/cjs/hcs-11/client.d.ts.map +1 -1
  3. package/dist/cjs/hcs-11/types.d.ts +1 -0
  4. package/dist/cjs/hcs-11/types.d.ts.map +1 -1
  5. package/dist/cjs/hcs-16/base-client.d.ts.map +1 -1
  6. package/dist/cjs/hcs-17/types.d.ts.map +1 -1
  7. package/dist/cjs/hcs-20/sdk.d.ts.map +1 -1
  8. package/dist/cjs/hcs-20/types.d.ts +9 -8
  9. package/dist/cjs/hcs-20/types.d.ts.map +1 -1
  10. package/dist/cjs/hcs-21/base-client.d.ts +5 -3
  11. package/dist/cjs/hcs-21/base-client.d.ts.map +1 -1
  12. package/dist/cjs/hcs-21/browser.d.ts +17 -7
  13. package/dist/cjs/hcs-21/browser.d.ts.map +1 -1
  14. package/dist/cjs/hcs-21/index.d.ts +1 -0
  15. package/dist/cjs/hcs-21/index.d.ts.map +1 -1
  16. package/dist/cjs/hcs-21/sdk.d.ts +62 -0
  17. package/dist/cjs/hcs-21/sdk.d.ts.map +1 -1
  18. package/dist/cjs/hcs-21/tx.d.ts.map +1 -1
  19. package/dist/cjs/hcs-21/types.d.ts +149 -65
  20. package/dist/cjs/hcs-21/types.d.ts.map +1 -1
  21. package/dist/cjs/hcs-21/verify.d.ts +6 -0
  22. package/dist/cjs/hcs-21/verify.d.ts.map +1 -0
  23. package/dist/cjs/inscribe/inscriber.d.ts +3 -1
  24. package/dist/cjs/inscribe/inscriber.d.ts.map +1 -1
  25. package/dist/cjs/inscribe/quote-cache.d.ts.map +1 -1
  26. package/dist/cjs/inscribe/types.d.ts +5 -0
  27. package/dist/cjs/inscribe/types.d.ts.map +1 -1
  28. package/dist/cjs/services/registry-broker/client.d.ts +4 -3
  29. package/dist/cjs/services/registry-broker/client.d.ts.map +1 -1
  30. package/dist/cjs/services/registry-broker/private-key-signer.d.ts.map +1 -1
  31. package/dist/cjs/services/registry-broker/schemas.d.ts +24 -24
  32. package/dist/cjs/services/registry-broker/schemas.d.ts.map +1 -1
  33. package/dist/cjs/services/types.d.ts +1 -0
  34. package/dist/cjs/services/types.d.ts.map +1 -1
  35. package/dist/cjs/standards-sdk.cjs +2 -2
  36. package/dist/cjs/standards-sdk.cjs.map +1 -1
  37. package/dist/cjs/utils/dynamic-import.d.ts +1 -0
  38. package/dist/cjs/utils/dynamic-import.d.ts.map +1 -1
  39. package/dist/es/hcs-11/client.d.ts.map +1 -1
  40. package/dist/es/hcs-11/types.d.ts +1 -0
  41. package/dist/es/hcs-11/types.d.ts.map +1 -1
  42. package/dist/es/hcs-16/base-client.d.ts.map +1 -1
  43. package/dist/es/hcs-17/types.d.ts.map +1 -1
  44. package/dist/es/hcs-20/sdk.d.ts.map +1 -1
  45. package/dist/es/hcs-20/types.d.ts +9 -8
  46. package/dist/es/hcs-20/types.d.ts.map +1 -1
  47. package/dist/es/hcs-21/base-client.d.ts +5 -3
  48. package/dist/es/hcs-21/base-client.d.ts.map +1 -1
  49. package/dist/es/hcs-21/browser.d.ts +17 -7
  50. package/dist/es/hcs-21/browser.d.ts.map +1 -1
  51. package/dist/es/hcs-21/index.d.ts +1 -0
  52. package/dist/es/hcs-21/index.d.ts.map +1 -1
  53. package/dist/es/hcs-21/sdk.d.ts +62 -0
  54. package/dist/es/hcs-21/sdk.d.ts.map +1 -1
  55. package/dist/es/hcs-21/tx.d.ts.map +1 -1
  56. package/dist/es/hcs-21/types.d.ts +149 -65
  57. package/dist/es/hcs-21/types.d.ts.map +1 -1
  58. package/dist/es/hcs-21/verify.d.ts +6 -0
  59. package/dist/es/hcs-21/verify.d.ts.map +1 -0
  60. package/dist/es/inscribe/inscriber.d.ts +3 -1
  61. package/dist/es/inscribe/inscriber.d.ts.map +1 -1
  62. package/dist/es/inscribe/quote-cache.d.ts.map +1 -1
  63. package/dist/es/inscribe/types.d.ts +5 -0
  64. package/dist/es/inscribe/types.d.ts.map +1 -1
  65. package/dist/es/services/registry-broker/client.d.ts +4 -3
  66. package/dist/es/services/registry-broker/client.d.ts.map +1 -1
  67. package/dist/es/services/registry-broker/private-key-signer.d.ts.map +1 -1
  68. package/dist/es/services/registry-broker/schemas.d.ts +24 -24
  69. package/dist/es/services/registry-broker/schemas.d.ts.map +1 -1
  70. package/dist/es/services/types.d.ts +1 -0
  71. package/dist/es/services/types.d.ts.map +1 -1
  72. package/dist/es/standards-sdk.es.js +58 -50
  73. package/dist/es/standards-sdk.es.js.map +1 -1
  74. package/dist/es/standards-sdk.es10.js +2 -2
  75. package/dist/es/standards-sdk.es100.js +26 -229
  76. package/dist/es/standards-sdk.es100.js.map +1 -1
  77. package/dist/es/standards-sdk.es101.js +228 -109
  78. package/dist/es/standards-sdk.es101.js.map +1 -1
  79. package/dist/es/standards-sdk.es102.js +94 -15
  80. package/dist/es/standards-sdk.es102.js.map +1 -1
  81. package/dist/es/standards-sdk.es103.js +30 -80
  82. package/dist/es/standards-sdk.es103.js.map +1 -1
  83. package/dist/es/standards-sdk.es104.js +80 -27
  84. package/dist/es/standards-sdk.es104.js.map +1 -1
  85. package/dist/es/standards-sdk.es105.js +25 -136
  86. package/dist/es/standards-sdk.es105.js.map +1 -1
  87. package/dist/es/standards-sdk.es106.js +140 -27
  88. package/dist/es/standards-sdk.es106.js.map +1 -1
  89. package/dist/es/standards-sdk.es107.js +27 -20
  90. package/dist/es/standards-sdk.es107.js.map +1 -1
  91. package/dist/es/standards-sdk.es108.js +18 -156
  92. package/dist/es/standards-sdk.es108.js.map +1 -1
  93. package/dist/es/standards-sdk.es109.js +148 -196
  94. package/dist/es/standards-sdk.es109.js.map +1 -1
  95. package/dist/es/standards-sdk.es110.js +160 -747
  96. package/dist/es/standards-sdk.es110.js.map +1 -1
  97. package/dist/es/standards-sdk.es111.js +786 -9
  98. package/dist/es/standards-sdk.es111.js.map +1 -1
  99. package/dist/es/standards-sdk.es112.js +13 -567
  100. package/dist/es/standards-sdk.es112.js.map +1 -1
  101. package/dist/es/standards-sdk.es113.js +541 -576
  102. package/dist/es/standards-sdk.es113.js.map +1 -1
  103. package/dist/es/standards-sdk.es114.js +601 -12
  104. package/dist/es/standards-sdk.es114.js.map +1 -1
  105. package/dist/es/standards-sdk.es115.js +13 -2
  106. package/dist/es/standards-sdk.es115.js.map +1 -1
  107. package/dist/es/standards-sdk.es116.js +2 -83
  108. package/dist/es/standards-sdk.es116.js.map +1 -1
  109. package/dist/es/standards-sdk.es117.js +80 -36
  110. package/dist/es/standards-sdk.es117.js.map +1 -1
  111. package/dist/es/standards-sdk.es118.js +39 -2
  112. package/dist/es/standards-sdk.es118.js.map +1 -1
  113. package/dist/es/standards-sdk.es119.js +2 -223
  114. package/dist/es/standards-sdk.es119.js.map +1 -1
  115. package/dist/es/standards-sdk.es12.js +1 -1
  116. package/dist/es/standards-sdk.es120.js +193 -1110
  117. package/dist/es/standards-sdk.es120.js.map +1 -1
  118. package/dist/es/standards-sdk.es121.js +1059 -225
  119. package/dist/es/standards-sdk.es121.js.map +1 -1
  120. package/dist/es/standards-sdk.es122.js +303 -419
  121. package/dist/es/standards-sdk.es122.js.map +1 -1
  122. package/dist/es/standards-sdk.es123.js +418 -351
  123. package/dist/es/standards-sdk.es123.js.map +1 -1
  124. package/dist/es/standards-sdk.es124.js +348 -785
  125. package/dist/es/standards-sdk.es124.js.map +1 -1
  126. package/dist/es/standards-sdk.es125.js +854 -182
  127. package/dist/es/standards-sdk.es125.js.map +1 -1
  128. package/dist/es/standards-sdk.es126.js +153 -1512
  129. package/dist/es/standards-sdk.es126.js.map +1 -1
  130. package/dist/es/standards-sdk.es127.js +1373 -1977
  131. package/dist/es/standards-sdk.es127.js.map +1 -1
  132. package/dist/es/standards-sdk.es128.js +2209 -69
  133. package/dist/es/standards-sdk.es128.js.map +1 -1
  134. package/dist/es/standards-sdk.es129.js +59 -79
  135. package/dist/es/standards-sdk.es129.js.map +1 -1
  136. package/dist/es/standards-sdk.es13.js +1 -1
  137. package/dist/es/standards-sdk.es130.js +80 -152
  138. package/dist/es/standards-sdk.es130.js.map +1 -1
  139. package/dist/es/standards-sdk.es131.js +159 -7
  140. package/dist/es/standards-sdk.es131.js.map +1 -1
  141. package/dist/es/standards-sdk.es132.js +7 -86
  142. package/dist/es/standards-sdk.es132.js.map +1 -1
  143. package/dist/es/standards-sdk.es133.js +65 -44
  144. package/dist/es/standards-sdk.es133.js.map +1 -1
  145. package/dist/es/standards-sdk.es134.js +65 -28
  146. package/dist/es/standards-sdk.es134.js.map +1 -1
  147. package/dist/es/standards-sdk.es135.js +28 -12274
  148. package/dist/es/standards-sdk.es135.js.map +1 -1
  149. package/dist/es/standards-sdk.es136.js +138 -760
  150. package/dist/es/standards-sdk.es136.js.map +1 -1
  151. package/dist/es/standards-sdk.es137.js +37 -133
  152. package/dist/es/standards-sdk.es137.js.map +1 -1
  153. package/dist/es/standards-sdk.es138.js +12265 -33
  154. package/dist/es/standards-sdk.es138.js.map +1 -1
  155. package/dist/es/standards-sdk.es139.js +766 -17
  156. package/dist/es/standards-sdk.es139.js.map +1 -1
  157. package/dist/es/standards-sdk.es14.js +1 -1
  158. package/dist/es/standards-sdk.es140.js +167 -51
  159. package/dist/es/standards-sdk.es140.js.map +1 -1
  160. package/dist/es/standards-sdk.es141.js +311 -53
  161. package/dist/es/standards-sdk.es141.js.map +1 -1
  162. package/dist/es/standards-sdk.es142.js +294 -120
  163. package/dist/es/standards-sdk.es142.js.map +1 -1
  164. package/dist/es/standards-sdk.es143.js +322 -191
  165. package/dist/es/standards-sdk.es143.js.map +1 -1
  166. package/dist/es/standards-sdk.es144.js +279 -294
  167. package/dist/es/standards-sdk.es144.js.map +1 -1
  168. package/dist/es/standards-sdk.es145.js +63 -440
  169. package/dist/es/standards-sdk.es145.js.map +1 -1
  170. package/dist/es/standards-sdk.es146.js +13 -327
  171. package/dist/es/standards-sdk.es146.js.map +1 -1
  172. package/dist/es/standards-sdk.es147.js +49 -69
  173. package/dist/es/standards-sdk.es147.js.map +1 -1
  174. package/dist/es/standards-sdk.es148.js +85 -0
  175. package/dist/es/standards-sdk.es148.js.map +1 -0
  176. package/dist/es/standards-sdk.es15.js +1 -1
  177. package/dist/es/standards-sdk.es16.js +1 -1
  178. package/dist/es/standards-sdk.es17.js +5 -11
  179. package/dist/es/standards-sdk.es17.js.map +1 -1
  180. package/dist/es/standards-sdk.es19.js +12 -17
  181. package/dist/es/standards-sdk.es19.js.map +1 -1
  182. package/dist/es/standards-sdk.es20.js +9 -14
  183. package/dist/es/standards-sdk.es20.js.map +1 -1
  184. package/dist/es/standards-sdk.es21.js +1 -1
  185. package/dist/es/standards-sdk.es22.js +1 -1
  186. package/dist/es/standards-sdk.es23.js +1 -1
  187. package/dist/es/standards-sdk.es24.js +1 -1
  188. package/dist/es/standards-sdk.es25.js +1 -1
  189. package/dist/es/standards-sdk.es26.js +1 -1
  190. package/dist/es/standards-sdk.es27.js +1 -1
  191. package/dist/es/standards-sdk.es28.js +16 -19
  192. package/dist/es/standards-sdk.es28.js.map +1 -1
  193. package/dist/es/standards-sdk.es29.js.map +1 -1
  194. package/dist/es/standards-sdk.es3.js +2 -2
  195. package/dist/es/standards-sdk.es31.js +2 -2
  196. package/dist/es/standards-sdk.es32.js +4 -4
  197. package/dist/es/standards-sdk.es33.js +1 -1
  198. package/dist/es/standards-sdk.es36.js +7 -12
  199. package/dist/es/standards-sdk.es36.js.map +1 -1
  200. package/dist/es/standards-sdk.es37.js +4 -4
  201. package/dist/es/standards-sdk.es38.js +2 -2
  202. package/dist/es/standards-sdk.es39.js +2 -2
  203. package/dist/es/standards-sdk.es40.js +1 -1
  204. package/dist/es/standards-sdk.es41.js +1 -1
  205. package/dist/es/standards-sdk.es42.js +2 -2
  206. package/dist/es/standards-sdk.es47.js +1 -1
  207. package/dist/es/standards-sdk.es5.js +2 -2
  208. package/dist/es/standards-sdk.es52.js +1 -1
  209. package/dist/es/standards-sdk.es54.js +1 -1
  210. package/dist/es/standards-sdk.es57.js +2 -2
  211. package/dist/es/standards-sdk.es59.js +1 -1
  212. package/dist/es/standards-sdk.es6.js +2 -2
  213. package/dist/es/standards-sdk.es60.js +1 -1
  214. package/dist/es/standards-sdk.es61.js +7 -12
  215. package/dist/es/standards-sdk.es61.js.map +1 -1
  216. package/dist/es/standards-sdk.es63.js +1 -1
  217. package/dist/es/standards-sdk.es65.js +2 -2
  218. package/dist/es/standards-sdk.es66.js +3 -3
  219. package/dist/es/standards-sdk.es69.js +2 -2
  220. package/dist/es/standards-sdk.es7.js +2 -2
  221. package/dist/es/standards-sdk.es70.js +3 -3
  222. package/dist/es/standards-sdk.es71.js +2 -2
  223. package/dist/es/standards-sdk.es72.js +1 -1
  224. package/dist/es/standards-sdk.es73.js.map +1 -1
  225. package/dist/es/standards-sdk.es75.js +2 -2
  226. package/dist/es/standards-sdk.es77.js +5 -3
  227. package/dist/es/standards-sdk.es77.js.map +1 -1
  228. package/dist/es/standards-sdk.es78.js +4 -10
  229. package/dist/es/standards-sdk.es78.js.map +1 -1
  230. package/dist/es/standards-sdk.es79.js +1 -1
  231. package/dist/es/standards-sdk.es8.js +1 -1
  232. package/dist/es/standards-sdk.es80.js +27 -15
  233. package/dist/es/standards-sdk.es80.js.map +1 -1
  234. package/dist/es/standards-sdk.es82.js +12 -4
  235. package/dist/es/standards-sdk.es82.js.map +1 -1
  236. package/dist/es/standards-sdk.es83.js +31 -6
  237. package/dist/es/standards-sdk.es83.js.map +1 -1
  238. package/dist/es/standards-sdk.es84.js +182 -7
  239. package/dist/es/standards-sdk.es84.js.map +1 -1
  240. package/dist/es/standards-sdk.es85.js +256 -9
  241. package/dist/es/standards-sdk.es85.js.map +1 -1
  242. package/dist/es/standards-sdk.es86.js +55 -21
  243. package/dist/es/standards-sdk.es86.js.map +1 -1
  244. package/dist/es/standards-sdk.es87.js +22 -75
  245. package/dist/es/standards-sdk.es87.js.map +1 -1
  246. package/dist/es/standards-sdk.es88.js +45 -30
  247. package/dist/es/standards-sdk.es88.js.map +1 -1
  248. package/dist/es/standards-sdk.es89.js +57 -22
  249. package/dist/es/standards-sdk.es89.js.map +1 -1
  250. package/dist/es/standards-sdk.es90.js +28 -23
  251. package/dist/es/standards-sdk.es90.js.map +1 -1
  252. package/dist/es/standards-sdk.es91.js +23 -167
  253. package/dist/es/standards-sdk.es91.js.map +1 -1
  254. package/dist/es/standards-sdk.es92.js +158 -119
  255. package/dist/es/standards-sdk.es92.js.map +1 -1
  256. package/dist/es/standards-sdk.es93.js +68 -95
  257. package/dist/es/standards-sdk.es93.js.map +1 -1
  258. package/dist/es/standards-sdk.es94.js +136 -119
  259. package/dist/es/standards-sdk.es94.js.map +1 -1
  260. package/dist/es/standards-sdk.es95.js +139 -39
  261. package/dist/es/standards-sdk.es95.js.map +1 -1
  262. package/dist/es/standards-sdk.es96.js +42 -257
  263. package/dist/es/standards-sdk.es96.js.map +1 -1
  264. package/dist/es/standards-sdk.es97.js +243 -80
  265. package/dist/es/standards-sdk.es97.js.map +1 -1
  266. package/dist/es/standards-sdk.es98.js +47 -48
  267. package/dist/es/standards-sdk.es98.js.map +1 -1
  268. package/dist/es/standards-sdk.es99.js +100 -28
  269. package/dist/es/standards-sdk.es99.js.map +1 -1
  270. package/dist/es/utils/dynamic-import.d.ts +1 -0
  271. package/dist/es/utils/dynamic-import.d.ts.map +1 -1
  272. package/package.json +65 -63
@@ -1,13 +1,13 @@
1
1
  import { proto } from "@hashgraph/proto";
2
- import { Long } from "@hashgraph/sdk";
3
- import { hasTransactionType, parseKey } from "./standards-sdk.es147.js";
2
+ import { Long, Hbar, HbarUnit, ContractId, AccountId, FileId } from "@hashgraph/sdk";
4
3
  import { Buffer } from "buffer";
5
- class FileParser {
4
+ import { hasTransactionType, parseKey } from "./standards-sdk.es145.js";
5
+ class SCSParser {
6
6
  /**
7
- * Parse File Service transaction using unified dual-branch approach
7
+ * Parse Smart Contract Service transaction using unified dual-branch approach
8
8
  * This handles both regular transactions and signed transaction variants
9
9
  */
10
- static parseFileTransaction(transaction, originalBytes) {
10
+ static parseSCSTransaction(transaction, originalBytes) {
11
11
  try {
12
12
  if (originalBytes || transaction.toBytes) {
13
13
  try {
@@ -38,147 +38,181 @@ class FileParser {
38
38
  }
39
39
  return this.parseFromTransactionInternals(transaction);
40
40
  } catch (error) {
41
- return { type: "UNKNOWN", humanReadableType: "Unknown File Transaction" };
41
+ return {
42
+ type: "UNKNOWN",
43
+ humanReadableType: "Unknown Contract Transaction"
44
+ };
42
45
  }
43
46
  }
44
47
  /**
45
- * Parse file transaction from protobuf TransactionBody
46
- * Handles all file operations from decoded protobuf data
48
+ * Parse contract transaction from protobuf TransactionBody
49
+ * Handles all contract operations from decoded protobuf data
47
50
  */
48
51
  static parseFromProtobufTxBody(txBody) {
49
- if (txBody.fileCreate) {
50
- const fileCreate = this.parseFileCreate(txBody.fileCreate);
51
- if (fileCreate) {
52
+ if (txBody.contractCall) {
53
+ const contractCall = this.parseContractCall(txBody.contractCall);
54
+ if (contractCall) {
55
+ return {
56
+ type: "CONTRACTCALL",
57
+ humanReadableType: "Contract Call",
58
+ contractCall
59
+ };
60
+ }
61
+ }
62
+ if (txBody.contractCreateInstance) {
63
+ const contractCreate = this.parseContractCreate(
64
+ txBody.contractCreateInstance
65
+ );
66
+ if (contractCreate) {
52
67
  return {
53
- type: "FILECREATE",
54
- humanReadableType: "File Create",
55
- fileCreate
68
+ type: "CONTRACTCREATE",
69
+ humanReadableType: "Contract Create",
70
+ contractCreate
56
71
  };
57
72
  }
58
73
  }
59
- if (txBody.fileAppend) {
60
- const fileAppend = this.parseFileAppend(txBody.fileAppend);
61
- if (fileAppend) {
74
+ if (txBody.contractUpdateInstance) {
75
+ const contractUpdate = this.parseContractUpdate(
76
+ txBody.contractUpdateInstance
77
+ );
78
+ if (contractUpdate) {
62
79
  return {
63
- type: "FILEAPPEND",
64
- humanReadableType: "File Append",
65
- fileAppend
80
+ type: "CONTRACTUPDATE",
81
+ humanReadableType: "Contract Update",
82
+ contractUpdate
66
83
  };
67
84
  }
68
85
  }
69
- if (txBody.fileUpdate) {
70
- const fileUpdate = this.parseFileUpdate(txBody.fileUpdate);
71
- if (fileUpdate) {
86
+ if (txBody.contractDeleteInstance) {
87
+ const contractDelete = this.parseContractDelete(
88
+ txBody.contractDeleteInstance
89
+ );
90
+ if (contractDelete) {
72
91
  return {
73
- type: "FILEUPDATE",
74
- humanReadableType: "File Update",
75
- fileUpdate
92
+ type: "CONTRACTDELETE",
93
+ humanReadableType: "Contract Delete",
94
+ contractDelete
76
95
  };
77
96
  }
78
97
  }
79
- if (txBody.fileDelete) {
80
- const fileDelete = this.parseFileDelete(txBody.fileDelete);
81
- if (fileDelete) {
98
+ if (txBody.ethereumTransaction) {
99
+ const ethereumCall = this.parseEthereumTransaction(
100
+ txBody.ethereumTransaction
101
+ );
102
+ if (ethereumCall) {
82
103
  return {
83
- type: "FILEDELETE",
84
- humanReadableType: "File Delete",
85
- fileDelete
104
+ type: "ETHEREUMTRANSACTION",
105
+ humanReadableType: "Ethereum Transaction",
106
+ ethereumTransaction: ethereumCall
86
107
  };
87
108
  }
88
109
  }
89
110
  return {};
90
111
  }
91
112
  /**
92
- * Extract file data from Transaction internal fields
113
+ * Extract contract data from Transaction internal fields
93
114
  * This handles cases where data is stored in Transaction object internals
94
115
  */
95
116
  static parseFromTransactionInternals(transaction) {
96
117
  try {
97
118
  const tx = transaction;
98
- if (hasTransactionType(transaction, "fileCreate")) {
99
- const fileCreate = {};
100
- if (tx._contents) {
101
- const contentInfo = this.analyzeContent(tx._contents);
102
- fileCreate.contents = contentInfo.encoded;
103
- if (contentInfo.contentType) {
104
- fileCreate.contentType = contentInfo.contentType;
105
- }
106
- if (contentInfo.size) {
107
- fileCreate.contentSize = contentInfo.size;
108
- }
109
- }
110
- if (tx._keys && tx._keys.length > 0) {
111
- const keyList = {
112
- keys: tx._keys
113
- };
114
- fileCreate.keys = parseKey({ keyList });
115
- }
116
- if (tx._expirationTime) {
117
- fileCreate.expirationTime = tx._expirationTime.toString();
118
- }
119
- if (tx._memo) {
120
- fileCreate.memo = tx._memo;
119
+ if (tx._contractId && tx._gas) {
120
+ const contractCall = {
121
+ contractId: tx._contractId.toString(),
122
+ gas: typeof tx._gas === "number" ? tx._gas : Long.fromValue(tx._gas).toNumber(),
123
+ amount: tx._amount ? parseFloat(tx._amount.toString()) : 0
124
+ };
125
+ if (tx._functionParameters) {
126
+ const funcParams = Buffer.from(tx._functionParameters).toString(
127
+ "hex"
128
+ );
129
+ contractCall.functionParameters = funcParams;
130
+ contractCall.functionName = this.extractFunctionName(funcParams);
121
131
  }
122
132
  return {
123
- type: "FILECREATE",
124
- humanReadableType: "File Create",
125
- fileCreate
133
+ type: "CONTRACTCALL",
134
+ humanReadableType: "Contract Call",
135
+ contractCall
126
136
  };
127
137
  }
128
- if (hasTransactionType(transaction, "fileAppend")) {
129
- const fileAppend = {
130
- fileId: tx._fileId.toString()
138
+ if (hasTransactionType(transaction, "contractCreateInstance")) {
139
+ const contractCreate = {
140
+ gas: tx._gas.toString(),
141
+ initialBalance: tx._initialBalance?.toString() || "0"
131
142
  };
132
- if (tx._contents) {
133
- const contentInfo = this.analyzeContent(tx._contents);
134
- fileAppend.contents = contentInfo.encoded;
135
- if (contentInfo.size) {
136
- fileAppend.contentSize = contentInfo.size;
137
- }
143
+ if (tx._fileId) {
144
+ contractCreate.initcodeSource = "fileID";
145
+ contractCreate.initcode = tx._fileId.toString();
146
+ } else if (tx._bytecode) {
147
+ contractCreate.initcodeSource = "bytes";
148
+ contractCreate.initcode = Buffer.from(tx._bytecode).toString("hex");
149
+ }
150
+ if (tx._constructorParameters) {
151
+ contractCreate.constructorParameters = Buffer.from(
152
+ tx._constructorParameters
153
+ ).toString("hex");
138
154
  }
155
+ if (tx._memo) contractCreate.memo = tx._memo;
156
+ if (tx._adminKey) contractCreate.adminKey = parseKey(tx._adminKey);
157
+ if (tx._maxAutomaticTokenAssociations !== void 0) {
158
+ contractCreate.maxAutomaticTokenAssociations = tx._maxAutomaticTokenAssociations;
159
+ }
160
+ if (tx._stakedAccountId) {
161
+ contractCreate.stakedAccountId = tx._stakedAccountId.toString();
162
+ } else if (tx._stakedNodeId !== null && tx._stakedNodeId !== void 0) {
163
+ contractCreate.stakedNodeId = Long.fromValue(
164
+ tx._stakedNodeId
165
+ ).toString();
166
+ }
167
+ if (tx._declineReward !== void 0)
168
+ contractCreate.declineReward = tx._declineReward;
169
+ if (tx._autoRenewPeriod)
170
+ contractCreate.autoRenewPeriod = tx._autoRenewPeriod.toString();
139
171
  return {
140
- type: "FILEAPPEND",
141
- humanReadableType: "File Append",
142
- fileAppend
172
+ type: "CONTRACTCREATE",
173
+ humanReadableType: "Contract Create",
174
+ contractCreate
143
175
  };
144
176
  }
145
- if (hasTransactionType(transaction, "fileUpdate")) {
146
- const fileUpdate = {
147
- fileId: tx._fileId.toString()
177
+ if (hasTransactionType(transaction, "contractUpdateInstance")) {
178
+ const contractUpdate = {
179
+ contractIdToUpdate: tx._contractId.toString()
148
180
  };
149
- if (tx._contents) {
150
- const contentInfo = this.analyzeContent(tx._contents);
151
- fileUpdate.contents = contentInfo.encoded;
152
- if (contentInfo.size) {
153
- fileUpdate.contentSize = contentInfo.size;
154
- }
155
- }
156
- if (tx._keys && tx._keys.length > 0) {
157
- const keyList = {
158
- keys: tx._keys
159
- };
160
- fileUpdate.keys = parseKey({ keyList });
181
+ if (tx._memo) contractUpdate.memo = tx._memo;
182
+ if (tx._adminKey) contractUpdate.adminKey = parseKey(tx._adminKey);
183
+ if (tx._maxAutomaticTokenAssociations !== void 0) {
184
+ contractUpdate.maxAutomaticTokenAssociations = tx._maxAutomaticTokenAssociations;
161
185
  }
162
- if (tx._expirationTime) {
163
- fileUpdate.expirationTime = tx._expirationTime.toString();
164
- }
165
- if (tx._memo) {
166
- fileUpdate.memo = tx._memo;
186
+ if (tx._stakedAccountId) {
187
+ contractUpdate.stakedAccountId = tx._stakedAccountId.toString();
188
+ } else if (tx._stakedNodeId !== null && tx._stakedNodeId !== void 0) {
189
+ contractUpdate.stakedNodeId = Long.fromValue(
190
+ tx._stakedNodeId
191
+ ).toString();
167
192
  }
193
+ if (tx._declineReward !== void 0)
194
+ contractUpdate.declineReward = tx._declineReward;
195
+ if (tx._autoRenewPeriod)
196
+ contractUpdate.autoRenewPeriod = tx._autoRenewPeriod.toString();
168
197
  return {
169
- type: "FILEUPDATE",
170
- humanReadableType: "File Update",
171
- fileUpdate
198
+ type: "CONTRACTUPDATE",
199
+ humanReadableType: "Contract Update",
200
+ contractUpdate
172
201
  };
173
202
  }
174
- if (hasTransactionType(transaction, "fileDelete")) {
175
- const fileDelete = {
176
- fileId: tx._fileId.toString()
203
+ if (hasTransactionType(transaction, "contractDeleteInstance")) {
204
+ const contractDelete = {
205
+ contractIdToDelete: tx._contractId.toString()
177
206
  };
207
+ if (tx._transferAccountId) {
208
+ contractDelete.transferAccountId = tx._transferAccountId.toString();
209
+ } else if (tx._transferContractId) {
210
+ contractDelete.transferContractId = tx._transferContractId.toString();
211
+ }
178
212
  return {
179
- type: "FILEDELETE",
180
- humanReadableType: "File Delete",
181
- fileDelete
213
+ type: "CONTRACTDELETE",
214
+ humanReadableType: "Contract Delete",
215
+ contractDelete
182
216
  };
183
217
  }
184
218
  return {};
@@ -187,139 +221,236 @@ class FileParser {
187
221
  }
188
222
  }
189
223
  /**
190
- * Enhanced content analysis with type detection and metadata
224
+ * Enhanced function name extraction from contract call parameters
225
+ * Attempts to decode function selector and map to known function names
191
226
  */
192
- static analyzeContent(contents) {
193
- const size = contents.length;
194
- const contentBuffer = Buffer.from(contents);
195
- let contentType;
196
- if (size >= 4) {
197
- const header = contentBuffer.subarray(0, 4);
198
- const headerHex = header.toString("hex");
199
- const signatures = {
200
- "89504e47": "image/png",
201
- ffd8ffe0: "image/jpeg",
202
- ffd8ffe1: "image/jpeg",
203
- "47494638": "image/gif",
204
- "25504446": "application/pdf",
205
- "504b0304": "application/zip",
206
- "7f454c46": "application/x-executable",
207
- d0cf11e0: "application/msoffice"
208
- };
209
- contentType = signatures[headerHex.toLowerCase()];
210
- }
211
- if (!contentType) {
212
- try {
213
- const textContent = contentBuffer.toString("utf8");
214
- const hasControlChars = /[\x00-\x08\x0B\x0E-\x1F\x7F]/.test(
215
- textContent
216
- );
217
- const hasReplacementChars = textContent.includes("�");
218
- if (!hasControlChars && !hasReplacementChars) {
219
- if (textContent.trim().startsWith("{") && textContent.trim().endsWith("}")) {
220
- contentType = "application/json";
221
- } else if (textContent.includes("<?xml") || textContent.includes("<html")) {
222
- contentType = "text/xml";
223
- } else if (textContent.includes("<!DOCTYPE html")) {
224
- contentType = "text/html";
225
- } else {
226
- contentType = "text/plain";
227
- }
228
- } else {
229
- contentType = "application/octet-stream";
230
- }
231
- } catch {
232
- contentType = "application/octet-stream";
227
+ static extractFunctionName(functionParameters) {
228
+ if (functionParameters.length < 8) return "unknown";
229
+ const selector = functionParameters.substring(0, 8);
230
+ const commonSelectors = {
231
+ a9059cbb: "transfer",
232
+ "095ea7b3": "approve",
233
+ "23b872dd": "transferFrom",
234
+ "70a08231": "balanceOf",
235
+ dd62ed3e: "allowance",
236
+ "18160ddd": "totalSupply",
237
+ "06fdde03": "name",
238
+ "95d89b41": "symbol",
239
+ "313ce567": "decimals",
240
+ "42842e0e": "safeTransferFrom",
241
+ b88d4fde: "safeTransferFrom",
242
+ e985e9c5: "isApprovedForAll",
243
+ a22cb465: "setApprovalForAll",
244
+ "6352211e": "ownerOf",
245
+ c87b56dd: "tokenURI",
246
+ "01ffc9a7": "supportsInterface",
247
+ "40c10f19": "mint",
248
+ "42966c68": "burn",
249
+ f2fde38b: "transferOwnership",
250
+ "715018a6": "renounceOwnership",
251
+ "8da5cb5b": "owner"
252
+ };
253
+ return commonSelectors[selector] || selector;
254
+ }
255
+ /**
256
+ * Parse Ethereum Transaction (was completely missing from original parser)
257
+ */
258
+ static parseEthereumTransaction(body) {
259
+ if (!body) return void 0;
260
+ const data = {
261
+ contractId: "EVM",
262
+ gas: body.maxGasAllowance ? Long.fromValue(body.maxGasAllowance).toNumber() : 0,
263
+ amount: 0
264
+ };
265
+ if (body.ethereumData && body.ethereumData.length > 0) {
266
+ const ethData = Buffer.from(body.ethereumData).toString("hex");
267
+ data.functionParameters = ethData;
268
+ if (ethData.length >= 8) {
269
+ data.functionName = this.extractFunctionName(ethData);
233
270
  }
234
271
  }
235
- let encoded;
236
- if (contentType?.startsWith("text/") || contentType === "application/json") {
237
- try {
238
- encoded = contentBuffer.toString("utf8");
239
- if (encoded.includes("�") || /[\x00-\x08\x0B\x0E-\x1F\x7F]/.test(encoded)) {
240
- encoded = contentBuffer.toString("base64");
241
- }
242
- } catch {
243
- encoded = contentBuffer.toString("base64");
272
+ return data;
273
+ }
274
+ static parseContractCall(body) {
275
+ if (!body) return void 0;
276
+ const hbarAmount = Hbar.fromTinybars(Long.fromValue(body.amount ?? 0));
277
+ const data = {
278
+ contractId: new ContractId(
279
+ body.contractID.shardNum ?? 0,
280
+ body.contractID.realmNum ?? 0,
281
+ body.contractID.contractNum ?? 0
282
+ ).toString(),
283
+ gas: Long.fromValue(body.gas ?? 0).toNumber(),
284
+ amount: parseFloat(hbarAmount.toString(HbarUnit.Hbar))
285
+ };
286
+ if (body.functionParameters) {
287
+ data.functionParameters = Buffer.from(body.functionParameters).toString(
288
+ "hex"
289
+ );
290
+ if (data.functionParameters.length >= 8) {
291
+ data.functionName = this.extractFunctionName(data.functionParameters);
244
292
  }
245
- } else {
246
- encoded = contentBuffer.toString("base64");
247
293
  }
248
- return {
249
- encoded,
250
- contentType,
251
- size
252
- };
294
+ return data;
253
295
  }
254
- static parseFileCreate(body) {
296
+ static parseContractCreate(body) {
255
297
  if (!body) return void 0;
256
298
  const data = {};
257
- if (body.expirationTime?.seconds) {
258
- data.expirationTime = `${Long.fromValue(
259
- body.expirationTime.seconds
260
- ).toString()}.${body.expirationTime.nanos}`;
299
+ if (body.initialBalance) {
300
+ data.initialBalance = Hbar.fromTinybars(
301
+ Long.fromValue(body.initialBalance)
302
+ ).toString(HbarUnit.Hbar);
303
+ }
304
+ if (body.gas) {
305
+ data.gas = Long.fromValue(body.gas).toString();
261
306
  }
262
- if (body.keys) {
263
- data.keys = parseKey({ keyList: body.keys });
307
+ if (body.adminKey) {
308
+ data.adminKey = parseKey(body.adminKey);
264
309
  }
265
- if (body.contents) {
266
- data.contents = Buffer.from(body.contents).toString("base64");
310
+ if (body.constructorParameters) {
311
+ data.constructorParameters = Buffer.from(
312
+ body.constructorParameters
313
+ ).toString("hex");
267
314
  }
268
315
  if (body.memo) {
269
316
  data.memo = body.memo;
270
317
  }
271
- return data;
272
- }
273
- static parseFileAppend(body) {
274
- if (!body) return void 0;
275
- const data = {};
276
- if (body.fileID) {
277
- data.fileId = `${body.fileID.shardNum ?? 0}.${body.fileID.realmNum ?? 0}.${body.fileID.fileNum ?? 0}`;
318
+ if (body.autoRenewPeriod?.seconds) {
319
+ data.autoRenewPeriod = Long.fromValue(
320
+ body.autoRenewPeriod.seconds
321
+ ).toString();
322
+ }
323
+ if (body.stakedAccountId) {
324
+ data.stakedAccountId = new AccountId(
325
+ body.stakedAccountId.shardNum ?? 0,
326
+ body.stakedAccountId.realmNum ?? 0,
327
+ body.stakedAccountId.accountNum ?? 0
328
+ ).toString();
329
+ } else if (body.stakedNodeId !== null && body.stakedNodeId !== void 0) {
330
+ data.stakedNodeId = Long.fromValue(body.stakedNodeId).toString();
278
331
  }
279
- if (body.contents) {
280
- data.contents = Buffer.from(body.contents).toString("base64");
332
+ if (body.declineReward !== void 0) {
333
+ data.declineReward = body.declineReward;
334
+ }
335
+ if (body.maxAutomaticTokenAssociations !== void 0) {
336
+ data.maxAutomaticTokenAssociations = body.maxAutomaticTokenAssociations;
337
+ }
338
+ if (body.fileID) {
339
+ data.initcodeSource = "fileID";
340
+ data.initcode = new FileId(
341
+ body.fileID.shardNum ?? 0,
342
+ body.fileID.realmNum ?? 0,
343
+ body.fileID.fileNum ?? 0
344
+ ).toString();
345
+ } else if (body.initcode && body.initcode.length > 0) {
346
+ data.initcodeSource = "bytes";
347
+ data.initcode = Buffer.from(body.initcode).toString("hex");
281
348
  }
282
349
  return data;
283
350
  }
284
- static parseFileUpdate(body) {
351
+ static parseContractUpdate(body) {
285
352
  if (!body) return void 0;
286
353
  const data = {};
287
- if (body.fileID) {
288
- data.fileId = `${body.fileID.shardNum ?? 0}.${body.fileID.realmNum ?? 0}.${body.fileID.fileNum ?? 0}`;
354
+ if (body.contractID) {
355
+ data.contractIdToUpdate = new ContractId(
356
+ body.contractID.shardNum ?? 0,
357
+ body.contractID.realmNum ?? 0,
358
+ body.contractID.contractNum ?? 0
359
+ ).toString();
360
+ }
361
+ if (body.adminKey) {
362
+ data.adminKey = parseKey(body.adminKey);
289
363
  }
290
364
  if (body.expirationTime?.seconds) {
291
365
  data.expirationTime = `${Long.fromValue(
292
366
  body.expirationTime.seconds
293
367
  ).toString()}.${body.expirationTime.nanos}`;
294
368
  }
295
- if (body.keys) {
296
- data.keys = parseKey({ keyList: body.keys });
369
+ if (body.autoRenewPeriod?.seconds) {
370
+ data.autoRenewPeriod = Long.fromValue(
371
+ body.autoRenewPeriod.seconds
372
+ ).toString();
373
+ }
374
+ if (body.memo) {
375
+ const memoUnion = body.memo;
376
+ if (memoUnion && typeof memoUnion === "object" && Object.prototype.hasOwnProperty.call(memoUnion, "value")) {
377
+ const value = memoUnion.value;
378
+ if (value === null || value === void 0) {
379
+ data.memo = void 0;
380
+ } else {
381
+ data.memo = String(value);
382
+ }
383
+ } else if (typeof memoUnion === "string") {
384
+ data.memo = memoUnion;
385
+ } else {
386
+ data.memo = void 0;
387
+ }
388
+ } else {
389
+ data.memo = void 0;
390
+ }
391
+ if (body.stakedAccountId) {
392
+ data.stakedAccountId = new AccountId(
393
+ body.stakedAccountId.shardNum ?? 0,
394
+ body.stakedAccountId.realmNum ?? 0,
395
+ body.stakedAccountId.accountNum ?? 0
396
+ ).toString();
397
+ data.stakedNodeId = void 0;
398
+ } else if (body.stakedNodeId !== null && body.stakedNodeId !== void 0 && Long.fromValue(body.stakedNodeId).notEquals(-1)) {
399
+ data.stakedNodeId = Long.fromValue(body.stakedNodeId).toString();
400
+ data.stakedAccountId = void 0;
401
+ } else {
402
+ data.stakedNodeId = void 0;
403
+ data.stakedAccountId = void 0;
404
+ }
405
+ if (body.declineReward?.value !== void 0) {
406
+ data.declineReward = body.declineReward.value;
297
407
  }
298
- if (body.contents) {
299
- data.contents = Buffer.from(body.contents).toString("base64");
408
+ if (body.maxAutomaticTokenAssociations?.value !== void 0) {
409
+ data.maxAutomaticTokenAssociations = body.maxAutomaticTokenAssociations.value;
300
410
  }
301
- if (body.memo?.value !== void 0) {
302
- data.memo = body.memo.value;
411
+ if (body.autoRenewAccountId) {
412
+ data.autoRenewAccountId = new AccountId(
413
+ body.autoRenewAccountId.shardNum ?? 0,
414
+ body.autoRenewAccountId.realmNum ?? 0,
415
+ body.autoRenewAccountId.accountNum ?? 0
416
+ ).toString();
303
417
  }
304
418
  return data;
305
419
  }
306
- static parseFileDelete(body) {
420
+ static parseContractDelete(body) {
307
421
  if (!body) return void 0;
308
422
  const data = {};
309
- if (body.fileID) {
310
- data.fileId = `${body.fileID.shardNum ?? 0}.${body.fileID.realmNum ?? 0}.${body.fileID.fileNum ?? 0}`;
423
+ if (body.contractID) {
424
+ data.contractIdToDelete = new ContractId(
425
+ body.contractID.shardNum ?? 0,
426
+ body.contractID.realmNum ?? 0,
427
+ body.contractID.contractNum ?? 0
428
+ ).toString();
429
+ }
430
+ if (body.transferAccountID) {
431
+ data.transferAccountId = new AccountId(
432
+ body.transferAccountID.shardNum ?? 0,
433
+ body.transferAccountID.realmNum ?? 0,
434
+ body.transferAccountID.accountNum ?? 0
435
+ ).toString();
436
+ } else if (body.transferContractID) {
437
+ data.transferContractId = new ContractId(
438
+ body.transferContractID.shardNum ?? 0,
439
+ body.transferContractID.realmNum ?? 0,
440
+ body.transferContractID.contractNum ?? 0
441
+ ).toString();
311
442
  }
312
443
  return data;
313
444
  }
314
445
  /**
315
- * Parse File Service transaction from Transaction object
446
+ * Parse SCS (Smart Contract Service) transaction from Transaction object
316
447
  * This is the unified entry point that delegates to the comprehensive parsing logic
317
448
  */
318
449
  static parseFromTransactionObject(transaction) {
319
- return this.parseFileTransaction(transaction);
450
+ return this.parseSCSTransaction(transaction);
320
451
  }
321
452
  }
322
453
  export {
323
- FileParser
454
+ SCSParser
324
455
  };
325
456
  //# sourceMappingURL=standards-sdk.es143.js.map