@hashgraphonline/standards-sdk 0.1.158 → 0.1.160
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/hcs-12/validation/schemas.d.ts +4 -4
- package/dist/cjs/hcs-14/index.d.ts +5 -0
- package/dist/cjs/hcs-14/index.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/aid-dns-web-profile.d.ts +37 -0
- package/dist/cjs/hcs-14/resolvers/aid-dns-web-profile.d.ts.map +1 -0
- package/dist/cjs/hcs-14/resolvers/dns.d.ts +3 -0
- package/dist/cjs/hcs-14/resolvers/dns.d.ts.map +1 -0
- package/dist/cjs/hcs-14/resolvers/hcs-11-profile.d.ts +8 -0
- package/dist/cjs/hcs-14/resolvers/hcs-11-profile.d.ts.map +1 -0
- package/dist/cjs/hcs-14/resolvers/profile-utils.d.ts +9 -0
- package/dist/cjs/hcs-14/resolvers/profile-utils.d.ts.map +1 -0
- package/dist/cjs/hcs-14/resolvers/registry.d.ts +21 -1
- package/dist/cjs/hcs-14/resolvers/registry.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/types.d.ts +106 -5
- package/dist/cjs/hcs-14/resolvers/types.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/uaid-did-resolution-profile.d.ts +10 -0
- package/dist/cjs/hcs-14/resolvers/uaid-did-resolution-profile.d.ts.map +1 -0
- package/dist/cjs/hcs-14/resolvers/uaid-dns-web-profile.d.ts +22 -0
- package/dist/cjs/hcs-14/resolvers/uaid-dns-web-profile.d.ts.map +1 -0
- package/dist/cjs/hcs-14/sdk.d.ts +16 -1
- package/dist/cjs/hcs-14/sdk.d.ts.map +1 -1
- package/dist/cjs/inscribe/inscriber.d.ts +1 -1
- package/dist/cjs/inscribe/inscriber.d.ts.map +1 -1
- package/dist/cjs/inscribe/inscription-cost.d.ts +12 -0
- package/dist/cjs/inscribe/inscription-cost.d.ts.map +1 -0
- package/dist/cjs/inscribe/types.d.ts +5 -1
- package/dist/cjs/inscribe/types.d.ts.map +1 -1
- package/dist/cjs/services/registry-broker/schemas.d.ts +1548 -0
- package/dist/cjs/services/registry-broker/schemas.d.ts.map +1 -1
- package/dist/cjs/standards-sdk.cjs +2 -2
- package/dist/cjs/standards-sdk.cjs.map +1 -1
- package/dist/es/hcs-12/validation/schemas.d.ts +4 -4
- package/dist/es/hcs-14/index.d.ts +5 -0
- package/dist/es/hcs-14/index.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/aid-dns-web-profile.d.ts +37 -0
- package/dist/es/hcs-14/resolvers/aid-dns-web-profile.d.ts.map +1 -0
- package/dist/es/hcs-14/resolvers/dns.d.ts +3 -0
- package/dist/es/hcs-14/resolvers/dns.d.ts.map +1 -0
- package/dist/es/hcs-14/resolvers/hcs-11-profile.d.ts +8 -0
- package/dist/es/hcs-14/resolvers/hcs-11-profile.d.ts.map +1 -0
- package/dist/es/hcs-14/resolvers/profile-utils.d.ts +9 -0
- package/dist/es/hcs-14/resolvers/profile-utils.d.ts.map +1 -0
- package/dist/es/hcs-14/resolvers/registry.d.ts +21 -1
- package/dist/es/hcs-14/resolvers/registry.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/types.d.ts +106 -5
- package/dist/es/hcs-14/resolvers/types.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/uaid-did-resolution-profile.d.ts +10 -0
- package/dist/es/hcs-14/resolvers/uaid-did-resolution-profile.d.ts.map +1 -0
- package/dist/es/hcs-14/resolvers/uaid-dns-web-profile.d.ts +22 -0
- package/dist/es/hcs-14/resolvers/uaid-dns-web-profile.d.ts.map +1 -0
- package/dist/es/hcs-14/sdk.d.ts +16 -1
- package/dist/es/hcs-14/sdk.d.ts.map +1 -1
- package/dist/es/inscribe/inscriber.d.ts +1 -1
- package/dist/es/inscribe/inscriber.d.ts.map +1 -1
- package/dist/es/inscribe/inscription-cost.d.ts +12 -0
- package/dist/es/inscribe/inscription-cost.d.ts.map +1 -0
- package/dist/es/inscribe/types.d.ts +5 -1
- package/dist/es/inscribe/types.d.ts.map +1 -1
- package/dist/es/services/registry-broker/schemas.d.ts +1548 -0
- package/dist/es/services/registry-broker/schemas.d.ts.map +1 -1
- package/dist/es/standards-sdk.es.js +96 -83
- package/dist/es/standards-sdk.es.js.map +1 -1
- package/dist/es/standards-sdk.es100.js +41 -224
- package/dist/es/standards-sdk.es100.js.map +1 -1
- package/dist/es/standards-sdk.es101.js +249 -97
- package/dist/es/standards-sdk.es101.js.map +1 -1
- package/dist/es/standards-sdk.es102.js +95 -27
- package/dist/es/standards-sdk.es102.js.map +1 -1
- package/dist/es/standards-sdk.es103.js +97 -80
- package/dist/es/standards-sdk.es103.js.map +1 -1
- package/dist/es/standards-sdk.es104.js +29 -30
- package/dist/es/standards-sdk.es104.js.map +1 -1
- package/dist/es/standards-sdk.es105.js +229 -249
- package/dist/es/standards-sdk.es105.js.map +1 -1
- package/dist/es/standards-sdk.es106.js +103 -468
- package/dist/es/standards-sdk.es106.js.map +1 -1
- package/dist/es/standards-sdk.es107.js +32 -103
- package/dist/es/standards-sdk.es107.js.map +1 -1
- package/dist/es/standards-sdk.es108.js +79 -155
- package/dist/es/standards-sdk.es108.js.map +1 -1
- package/dist/es/standards-sdk.es109.js +28 -31
- package/dist/es/standards-sdk.es109.js.map +1 -1
- package/dist/es/standards-sdk.es11.js +1 -1
- package/dist/es/standards-sdk.es110.js +250 -10
- package/dist/es/standards-sdk.es110.js.map +1 -1
- package/dist/es/standards-sdk.es111.js +451 -115
- package/dist/es/standards-sdk.es111.js.map +1 -1
- package/dist/es/standards-sdk.es112.js +101 -25
- package/dist/es/standards-sdk.es112.js.map +1 -1
- package/dist/es/standards-sdk.es113.js +155 -17
- package/dist/es/standards-sdk.es113.js.map +1 -1
- package/dist/es/standards-sdk.es114.js +29 -155
- package/dist/es/standards-sdk.es114.js.map +1 -1
- package/dist/es/standards-sdk.es115.js +9 -200
- package/dist/es/standards-sdk.es115.js.map +1 -1
- package/dist/es/standards-sdk.es116.js +109 -757
- package/dist/es/standards-sdk.es116.js.map +1 -1
- package/dist/es/standards-sdk.es117.js +27 -11
- package/dist/es/standards-sdk.es117.js.map +1 -1
- package/dist/es/standards-sdk.es118.js +19 -564
- package/dist/es/standards-sdk.es118.js.map +1 -1
- package/dist/es/standards-sdk.es119.js +140 -582
- package/dist/es/standards-sdk.es119.js.map +1 -1
- package/dist/es/standards-sdk.es12.js +1 -1
- package/dist/es/standards-sdk.es120.js +202 -12
- package/dist/es/standards-sdk.es120.js.map +1 -1
- package/dist/es/standards-sdk.es121.js +790 -2
- package/dist/es/standards-sdk.es121.js.map +1 -1
- package/dist/es/standards-sdk.es122.js +10 -84
- package/dist/es/standards-sdk.es122.js.map +1 -1
- package/dist/es/standards-sdk.es123.js +567 -40
- package/dist/es/standards-sdk.es123.js.map +1 -1
- package/dist/es/standards-sdk.es124.js +602 -2
- package/dist/es/standards-sdk.es124.js.map +1 -1
- package/dist/es/standards-sdk.es125.js +12 -234
- package/dist/es/standards-sdk.es125.js.map +1 -1
- package/dist/es/standards-sdk.es126.js +2 -1140
- package/dist/es/standards-sdk.es126.js.map +1 -1
- package/dist/es/standards-sdk.es127.js +73 -292
- package/dist/es/standards-sdk.es127.js.map +1 -1
- package/dist/es/standards-sdk.es128.js +36 -418
- package/dist/es/standards-sdk.es128.js.map +1 -1
- package/dist/es/standards-sdk.es129.js +2 -355
- package/dist/es/standards-sdk.es129.js.map +1 -1
- package/dist/es/standards-sdk.es13.js +1 -1
- package/dist/es/standards-sdk.es130.js +197 -1090
- package/dist/es/standards-sdk.es130.js.map +1 -1
- package/dist/es/standards-sdk.es131.js +1107 -175
- package/dist/es/standards-sdk.es131.js.map +1 -1
- package/dist/es/standards-sdk.es132.js +218 -1479
- package/dist/es/standards-sdk.es132.js.map +1 -1
- package/dist/es/standards-sdk.es133.js +422 -1236
- package/dist/es/standards-sdk.es133.js.map +1 -1
- package/dist/es/standards-sdk.es134.js +351 -13
- package/dist/es/standards-sdk.es134.js.map +1 -1
- package/dist/es/standards-sdk.es135.js +1102 -73
- package/dist/es/standards-sdk.es135.js.map +1 -1
- package/dist/es/standards-sdk.es136.js +203 -76
- package/dist/es/standards-sdk.es136.js.map +1 -1
- package/dist/es/standards-sdk.es137.js +1459 -785
- package/dist/es/standards-sdk.es137.js.map +1 -1
- package/dist/es/standards-sdk.es138.js +1254 -59
- package/dist/es/standards-sdk.es138.js.map +1 -1
- package/dist/es/standards-sdk.es139.js +14 -156
- package/dist/es/standards-sdk.es139.js.map +1 -1
- package/dist/es/standards-sdk.es14.js +1 -1
- package/dist/es/standards-sdk.es140.js +87 -7
- package/dist/es/standards-sdk.es140.js.map +1 -1
- package/dist/es/standards-sdk.es141.js +74 -79
- package/dist/es/standards-sdk.es141.js.map +1 -1
- package/dist/es/standards-sdk.es142.js +889 -61
- package/dist/es/standards-sdk.es142.js.map +1 -1
- package/dist/es/standards-sdk.es143.js +60 -30
- package/dist/es/standards-sdk.es143.js.map +1 -1
- package/dist/es/standards-sdk.es144.js +159 -34
- package/dist/es/standards-sdk.es144.js.map +1 -1
- package/dist/es/standards-sdk.es145.js +7 -28
- package/dist/es/standards-sdk.es145.js.map +1 -1
- package/dist/es/standards-sdk.es146.js +70 -122
- package/dist/es/standards-sdk.es146.js.map +1 -1
- package/dist/es/standards-sdk.es147.js +58 -35
- package/dist/es/standards-sdk.es147.js.map +1 -1
- package/dist/es/standards-sdk.es148.js +30 -12320
- package/dist/es/standards-sdk.es148.js.map +1 -1
- package/dist/es/standards-sdk.es149.js +34 -56
- package/dist/es/standards-sdk.es149.js.map +1 -1
- package/dist/es/standards-sdk.es15.js +1 -1
- package/dist/es/standards-sdk.es150.js +41 -84
- package/dist/es/standards-sdk.es150.js.map +1 -1
- package/dist/es/standards-sdk.es151.js +134 -13
- package/dist/es/standards-sdk.es151.js.map +1 -1
- package/dist/es/standards-sdk.es152.js +36 -236
- package/dist/es/standards-sdk.es152.js.map +1 -1
- package/dist/es/standards-sdk.es153.js +12444 -134
- package/dist/es/standards-sdk.es153.js.map +1 -1
- package/dist/es/standards-sdk.es154.js +139 -289
- package/dist/es/standards-sdk.es154.js.map +1 -1
- package/dist/es/standards-sdk.es155.js +274 -298
- package/dist/es/standards-sdk.es155.js.map +1 -1
- package/dist/es/standards-sdk.es156.js +262 -369
- package/dist/es/standards-sdk.es156.js.map +1 -1
- package/dist/es/standards-sdk.es157.js +316 -194
- package/dist/es/standards-sdk.es157.js.map +1 -1
- package/dist/es/standards-sdk.es158.js +319 -64
- package/dist/es/standards-sdk.es158.js.map +1 -1
- package/dist/es/standards-sdk.es159.js +61 -157
- package/dist/es/standards-sdk.es159.js.map +1 -1
- package/dist/es/standards-sdk.es16.js +5 -5
- package/dist/es/standards-sdk.es160.js +14 -219
- package/dist/es/standards-sdk.es160.js.map +1 -1
- package/dist/es/standards-sdk.es161.js +226 -223
- package/dist/es/standards-sdk.es161.js.map +1 -1
- package/dist/es/standards-sdk.es162.js +49 -112
- package/dist/es/standards-sdk.es162.js.map +1 -1
- package/dist/es/standards-sdk.es163.js +72 -114
- package/dist/es/standards-sdk.es163.js.map +1 -1
- package/dist/es/standards-sdk.es164.js +67 -147
- package/dist/es/standards-sdk.es164.js.map +1 -1
- package/dist/es/standards-sdk.es165.js +61 -173
- package/dist/es/standards-sdk.es165.js.map +1 -1
- package/dist/es/standards-sdk.es166.js +153 -120
- package/dist/es/standards-sdk.es166.js.map +1 -1
- package/dist/es/standards-sdk.es167.js +178 -287
- package/dist/es/standards-sdk.es167.js.map +1 -1
- package/dist/es/standards-sdk.es168.js +218 -238
- package/dist/es/standards-sdk.es168.js.map +1 -1
- package/dist/es/standards-sdk.es169.js +75 -72
- package/dist/es/standards-sdk.es169.js.map +1 -1
- package/dist/es/standards-sdk.es170.js +129 -0
- package/dist/es/standards-sdk.es170.js.map +1 -0
- package/dist/es/standards-sdk.es171.js +164 -0
- package/dist/es/standards-sdk.es171.js.map +1 -0
- package/dist/es/standards-sdk.es172.js +188 -0
- package/dist/es/standards-sdk.es172.js.map +1 -0
- package/dist/es/standards-sdk.es173.js +142 -0
- package/dist/es/standards-sdk.es173.js.map +1 -0
- package/dist/es/standards-sdk.es174.js +334 -0
- package/dist/es/standards-sdk.es174.js.map +1 -0
- package/dist/es/standards-sdk.es175.js +262 -0
- package/dist/es/standards-sdk.es175.js.map +1 -0
- package/dist/es/standards-sdk.es176.js +119 -0
- package/dist/es/standards-sdk.es176.js.map +1 -0
- package/dist/es/standards-sdk.es18.js +12 -12
- package/dist/es/standards-sdk.es19.js +9 -9
- package/dist/es/standards-sdk.es2.js +2 -2
- package/dist/es/standards-sdk.es20.js +1 -1
- package/dist/es/standards-sdk.es21.js +1 -1
- package/dist/es/standards-sdk.es22.js +1 -1
- package/dist/es/standards-sdk.es23.js +1 -1
- package/dist/es/standards-sdk.es24.js +1 -1
- package/dist/es/standards-sdk.es25.js +1 -1
- package/dist/es/standards-sdk.es26.js +1 -1
- package/dist/es/standards-sdk.es27.js +12 -12
- package/dist/es/standards-sdk.es30.js +2 -2
- package/dist/es/standards-sdk.es31.js +4 -4
- package/dist/es/standards-sdk.es32.js +1 -1
- package/dist/es/standards-sdk.es35.js +6 -6
- package/dist/es/standards-sdk.es36.js +4 -4
- package/dist/es/standards-sdk.es37.js +2 -2
- package/dist/es/standards-sdk.es38.js +2 -2
- package/dist/es/standards-sdk.es39.js +1 -1
- package/dist/es/standards-sdk.es4.js +2 -2
- package/dist/es/standards-sdk.es40.js +1 -1
- package/dist/es/standards-sdk.es41.js +2 -2
- package/dist/es/standards-sdk.es46.js +1 -1
- package/dist/es/standards-sdk.es5.js +2 -2
- package/dist/es/standards-sdk.es51.js +1 -1
- package/dist/es/standards-sdk.es53.js +1 -1
- package/dist/es/standards-sdk.es56.js +2 -2
- package/dist/es/standards-sdk.es58.js +194 -13
- package/dist/es/standards-sdk.es58.js.map +1 -1
- package/dist/es/standards-sdk.es59.js +1 -1
- package/dist/es/standards-sdk.es6.js +2 -2
- package/dist/es/standards-sdk.es60.js +100 -192
- package/dist/es/standards-sdk.es60.js.map +1 -1
- package/dist/es/standards-sdk.es61.js +172 -24
- package/dist/es/standards-sdk.es61.js.map +1 -1
- package/dist/es/standards-sdk.es62.js +204 -77
- package/dist/es/standards-sdk.es62.js.map +1 -1
- package/dist/es/standards-sdk.es63.js +130 -3
- package/dist/es/standards-sdk.es63.js.map +1 -1
- package/dist/es/standards-sdk.es64.js +41 -95
- package/dist/es/standards-sdk.es64.js.map +1 -1
- package/dist/es/standards-sdk.es65.js +245 -88
- package/dist/es/standards-sdk.es65.js.map +1 -1
- package/dist/es/standards-sdk.es66.js +32 -17
- package/dist/es/standards-sdk.es66.js.map +1 -1
- package/dist/es/standards-sdk.es67.js +96 -77
- package/dist/es/standards-sdk.es67.js.map +1 -1
- package/dist/es/standards-sdk.es68.js +4 -458
- package/dist/es/standards-sdk.es68.js.map +1 -1
- package/dist/es/standards-sdk.es69.js +72 -295
- package/dist/es/standards-sdk.es69.js.map +1 -1
- package/dist/es/standards-sdk.es7.js +1 -1
- package/dist/es/standards-sdk.es70.js +86 -194
- package/dist/es/standards-sdk.es70.js.map +1 -1
- package/dist/es/standards-sdk.es71.js +16 -69
- package/dist/es/standards-sdk.es71.js.map +1 -1
- package/dist/es/standards-sdk.es72.js +69 -63
- package/dist/es/standards-sdk.es72.js.map +1 -1
- package/dist/es/standards-sdk.es73.js +458 -143
- package/dist/es/standards-sdk.es73.js.map +1 -1
- package/dist/es/standards-sdk.es74.js +298 -43
- package/dist/es/standards-sdk.es74.js.map +1 -1
- package/dist/es/standards-sdk.es75.js +174 -370
- package/dist/es/standards-sdk.es75.js.map +1 -1
- package/dist/es/standards-sdk.es76.js +71 -495
- package/dist/es/standards-sdk.es76.js.map +1 -1
- package/dist/es/standards-sdk.es77.js +71 -365
- package/dist/es/standards-sdk.es77.js.map +1 -1
- package/dist/es/standards-sdk.es78.js +137 -83
- package/dist/es/standards-sdk.es78.js.map +1 -1
- package/dist/es/standards-sdk.es79.js +69 -125
- package/dist/es/standards-sdk.es79.js.map +1 -1
- package/dist/es/standards-sdk.es80.js +402 -6
- package/dist/es/standards-sdk.es80.js.map +1 -1
- package/dist/es/standards-sdk.es81.js +492 -43
- package/dist/es/standards-sdk.es81.js.map +1 -1
- package/dist/es/standards-sdk.es82.js +350 -86
- package/dist/es/standards-sdk.es82.js.map +1 -1
- package/dist/es/standards-sdk.es83.js +88 -347
- package/dist/es/standards-sdk.es83.js.map +1 -1
- package/dist/es/standards-sdk.es84.js +125 -281
- package/dist/es/standards-sdk.es84.js.map +1 -1
- package/dist/es/standards-sdk.es85.js +6 -59
- package/dist/es/standards-sdk.es85.js.map +1 -1
- package/dist/es/standards-sdk.es86.js +43 -45
- package/dist/es/standards-sdk.es86.js.map +1 -1
- package/dist/es/standards-sdk.es87.js +86 -135
- package/dist/es/standards-sdk.es87.js.map +1 -1
- package/dist/es/standards-sdk.es88.js +333 -52
- package/dist/es/standards-sdk.es88.js.map +1 -1
- package/dist/es/standards-sdk.es89.js +277 -26
- package/dist/es/standards-sdk.es89.js.map +1 -1
- package/dist/es/standards-sdk.es9.js +2 -2
- package/dist/es/standards-sdk.es90.js +59 -23
- package/dist/es/standards-sdk.es90.js.map +1 -1
- package/dist/es/standards-sdk.es91.js +26 -217
- package/dist/es/standards-sdk.es91.js.map +1 -1
- package/dist/es/standards-sdk.es92.js +104 -236
- package/dist/es/standards-sdk.es92.js.map +1 -1
- package/dist/es/standards-sdk.es93.js +51 -141
- package/dist/es/standards-sdk.es93.js.map +1 -1
- package/dist/es/standards-sdk.es94.js +22 -137
- package/dist/es/standards-sdk.es94.js.map +1 -1
- package/dist/es/standards-sdk.es95.js +20 -44
- package/dist/es/standards-sdk.es95.js.map +1 -1
- package/dist/es/standards-sdk.es96.js +227 -252
- package/dist/es/standards-sdk.es96.js.map +1 -1
- package/dist/es/standards-sdk.es97.js +248 -68
- package/dist/es/standards-sdk.es97.js.map +1 -1
- package/dist/es/standards-sdk.es98.js +108 -52
- package/dist/es/standards-sdk.es98.js.map +1 -1
- package/dist/es/standards-sdk.es99.js +144 -29
- package/dist/es/standards-sdk.es99.js.map +1 -1
- package/package.json +14 -4
|
@@ -1,793 +1,145 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
import { SCSParser } from "./standards-sdk.es156.js";
|
|
12
|
-
import { UtilParser } from "./standards-sdk.es157.js";
|
|
13
|
-
import { ScheduleParser } from "./standards-sdk.es127.js";
|
|
14
|
-
import { transactionParserRegistry } from "./standards-sdk.es128.js";
|
|
15
|
-
import { getTransactionTypeFromBody, getHumanReadableTransactionType } from "./standards-sdk.es129.js";
|
|
16
|
-
class TransactionParser {
|
|
17
|
-
/**
|
|
18
|
-
* Parse transaction bytes in any supported format (base64 or hex, regular or scheduled)
|
|
19
|
-
* This is the main entry point for transaction parsing with enhanced retry logic
|
|
20
|
-
*
|
|
21
|
-
* @param transactionBytes - Transaction bytes in base64 or hex format
|
|
22
|
-
* @param options - Parsing options and configuration
|
|
23
|
-
* @returns Promise resolving to ParsedTransaction
|
|
24
|
-
*/
|
|
25
|
-
static async parseTransactionBytes(transactionBytes, options = {}) {
|
|
26
|
-
const {
|
|
27
|
-
enableFallback = true,
|
|
28
|
-
strictMode = false,
|
|
29
|
-
includeRaw = true,
|
|
30
|
-
maxRetries = 2
|
|
31
|
-
} = options;
|
|
32
|
-
const validation = this.validateTransactionBytes(transactionBytes);
|
|
33
|
-
if (!validation.isValid && strictMode) {
|
|
34
|
-
throw new TransactionParsingError(
|
|
35
|
-
`Invalid transaction bytes format: ${validation.error}`,
|
|
36
|
-
"INVALID_FORMAT",
|
|
37
|
-
void 0,
|
|
38
|
-
transactionBytes
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
let lastError;
|
|
42
|
-
let retryCount = 0;
|
|
43
|
-
while (retryCount <= maxRetries) {
|
|
44
|
-
try {
|
|
45
|
-
const result = await this.parseTransaction(transactionBytes, options);
|
|
46
|
-
result.formatDetection = {
|
|
47
|
-
originalFormat: validation.format || "base64",
|
|
48
|
-
wasConverted: validation.format === "hex",
|
|
49
|
-
length: transactionBytes.length
|
|
50
|
-
};
|
|
51
|
-
return result;
|
|
52
|
-
} catch (error) {
|
|
53
|
-
lastError = error instanceof Error ? error : new Error(String(error));
|
|
54
|
-
retryCount++;
|
|
55
|
-
if (!enableFallback || retryCount > maxRetries) {
|
|
56
|
-
if (strictMode) {
|
|
57
|
-
throw new TransactionParsingError(
|
|
58
|
-
"Failed to parse transaction after all attempts",
|
|
59
|
-
"PARSING_FAILED",
|
|
60
|
-
lastError,
|
|
61
|
-
transactionBytes
|
|
62
|
-
);
|
|
63
|
-
}
|
|
64
|
-
break;
|
|
65
|
-
}
|
|
66
|
-
try {
|
|
67
|
-
const result = this.parseScheduledTransaction(
|
|
68
|
-
transactionBytes,
|
|
69
|
-
options
|
|
70
|
-
);
|
|
71
|
-
result.formatDetection = {
|
|
72
|
-
originalFormat: validation.format || "base64",
|
|
73
|
-
wasConverted: false,
|
|
74
|
-
length: transactionBytes.length
|
|
75
|
-
};
|
|
76
|
-
return result;
|
|
77
|
-
} catch (scheduledError) {
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
const fallbackResult = this.createFallbackResult(
|
|
82
|
-
transactionBytes,
|
|
83
|
-
lastError,
|
|
84
|
-
void 0
|
|
85
|
-
);
|
|
86
|
-
if (fallbackResult.details) {
|
|
87
|
-
fallbackResult.details.parseAttempts = Math.max(retryCount, 1);
|
|
1
|
+
import { inspect } from "util";
|
|
2
|
+
let loggerFactory = null;
|
|
3
|
+
function setLoggerFactory(factory) {
|
|
4
|
+
loggerFactory = factory;
|
|
5
|
+
Logger.clearInstances();
|
|
6
|
+
}
|
|
7
|
+
const _Logger = class _Logger {
|
|
8
|
+
constructor(options = {}) {
|
|
9
|
+
if (loggerFactory) {
|
|
10
|
+
return loggerFactory(options);
|
|
88
11
|
}
|
|
89
|
-
|
|
12
|
+
const globalDisable = typeof process !== "undefined" && process.env?.DISABLE_LOGS === "true";
|
|
13
|
+
this.silent = options.silent || globalDisable;
|
|
14
|
+
this.level = this.silent ? "silent" : options.level || "info";
|
|
15
|
+
this.moduleContext = options.module || "app";
|
|
16
|
+
this.prettyPrint = !this.silent && options.prettyPrint !== false;
|
|
90
17
|
}
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
* @returns Parsed transaction data
|
|
99
|
-
*/
|
|
100
|
-
static parseTransactionObject(transaction, originalBytesOrOptions, options = {}) {
|
|
101
|
-
let originalBytes;
|
|
102
|
-
let actualOptions;
|
|
103
|
-
if (originalBytesOrOptions && !Buffer.isBuffer(originalBytesOrOptions) && !(originalBytesOrOptions instanceof Uint8Array)) {
|
|
104
|
-
actualOptions = originalBytesOrOptions;
|
|
105
|
-
originalBytes = void 0;
|
|
106
|
-
} else {
|
|
107
|
-
originalBytes = originalBytesOrOptions;
|
|
108
|
-
actualOptions = options;
|
|
109
|
-
}
|
|
110
|
-
try {
|
|
111
|
-
const metadata = this.extractTransactionMetadata(transaction);
|
|
112
|
-
const htsResult = HTSParser.parseFromTransactionObject(transaction);
|
|
113
|
-
const cryptoResult = CryptoParser.parseFromTransactionObject(transaction);
|
|
114
|
-
const hcsResult = HCSParser.parseFromTransactionObject(transaction);
|
|
115
|
-
const fileResult = FileParser.parseFromTransactionObject(transaction);
|
|
116
|
-
const scsResult = SCSParser.parseFromTransactionObject(transaction);
|
|
117
|
-
const scheduleResult = ScheduleParser.parseFromTransactionObject(transaction);
|
|
118
|
-
const utilResult = UtilParser.parseFromTransactionObject(transaction);
|
|
119
|
-
const results = [
|
|
120
|
-
htsResult,
|
|
121
|
-
cryptoResult,
|
|
122
|
-
hcsResult,
|
|
123
|
-
fileResult,
|
|
124
|
-
scsResult,
|
|
125
|
-
scheduleResult,
|
|
126
|
-
utilResult
|
|
127
|
-
];
|
|
128
|
-
const primaryResult = results.find((result2) => result2.type && result2.type !== "UNKNOWN") || {};
|
|
129
|
-
let finalType = "UNKNOWN";
|
|
130
|
-
let finalHumanReadableType = "Unknown Transaction";
|
|
131
|
-
let parsedTokenCreation;
|
|
132
|
-
let protoParsingResult = {};
|
|
133
|
-
if (originalBytes || transaction.toBytes) {
|
|
134
|
-
try {
|
|
135
|
-
const bytesToParse = originalBytes || transaction.toBytes();
|
|
136
|
-
const decoded = proto.TransactionList.decode(bytesToParse);
|
|
137
|
-
if (decoded.transactionList && decoded.transactionList.length > 0) {
|
|
138
|
-
const tx = decoded.transactionList[0];
|
|
139
|
-
if (tx.bodyBytes && tx.bodyBytes.length > 0) {
|
|
140
|
-
const txBody = proto.TransactionBody.decode(tx.bodyBytes);
|
|
141
|
-
const typeResult = this.detectTransactionTypeFromBody(txBody);
|
|
142
|
-
finalType = typeResult.type;
|
|
143
|
-
finalHumanReadableType = typeResult.humanReadableType;
|
|
144
|
-
protoParsingResult = this.parseTransactionBodyDetails(
|
|
145
|
-
txBody,
|
|
146
|
-
finalType
|
|
147
|
-
);
|
|
148
|
-
if (protoParsingResult.tokenCreation) {
|
|
149
|
-
parsedTokenCreation = protoParsingResult.tokenCreation;
|
|
150
|
-
}
|
|
151
|
-
} else if (tx.signedTransactionBytes && tx.signedTransactionBytes.length > 0) {
|
|
152
|
-
const signedTx = proto.SignedTransaction.decode(
|
|
153
|
-
tx.signedTransactionBytes
|
|
154
|
-
);
|
|
155
|
-
if (signedTx.bodyBytes) {
|
|
156
|
-
const txBody = proto.TransactionBody.decode(signedTx.bodyBytes);
|
|
157
|
-
const typeResult = this.detectTransactionTypeFromBody(txBody);
|
|
158
|
-
finalType = typeResult.type;
|
|
159
|
-
finalHumanReadableType = typeResult.humanReadableType;
|
|
160
|
-
protoParsingResult = this.parseTransactionBodyDetails(
|
|
161
|
-
txBody,
|
|
162
|
-
finalType
|
|
163
|
-
);
|
|
164
|
-
if (protoParsingResult.tokenCreation) {
|
|
165
|
-
parsedTokenCreation = protoParsingResult.tokenCreation;
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
} catch (protoError) {
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
if (finalType === "UNKNOWN" && primaryResult.type) {
|
|
174
|
-
finalType = primaryResult.type;
|
|
175
|
-
finalHumanReadableType = primaryResult.humanReadableType || finalHumanReadableType;
|
|
18
|
+
static getInstance(options = {}) {
|
|
19
|
+
const moduleKey = options.module || "default";
|
|
20
|
+
const globalDisable = typeof process !== "undefined" && process.env?.DISABLE_LOGS === "true";
|
|
21
|
+
if (globalDisable && _Logger.instances.has(moduleKey)) {
|
|
22
|
+
const existingLogger = _Logger.instances.get(moduleKey);
|
|
23
|
+
if (existingLogger.getLevel() !== "silent") {
|
|
24
|
+
_Logger.instances.delete(moduleKey);
|
|
176
25
|
}
|
|
177
|
-
const result = {
|
|
178
|
-
type: finalType,
|
|
179
|
-
humanReadableType: finalHumanReadableType,
|
|
180
|
-
transfers: [],
|
|
181
|
-
tokenTransfers: [],
|
|
182
|
-
...metadata,
|
|
183
|
-
...primaryResult,
|
|
184
|
-
raw: actualOptions.includeRaw ? transaction._transactionBody || {} : void 0
|
|
185
|
-
};
|
|
186
|
-
this.mergeProtoParsingResults(
|
|
187
|
-
result,
|
|
188
|
-
protoParsingResult,
|
|
189
|
-
htsResult,
|
|
190
|
-
transaction,
|
|
191
|
-
originalBytes
|
|
192
|
-
);
|
|
193
|
-
result.transfers = cryptoResult.transfers || result.transfers || [];
|
|
194
|
-
result.tokenTransfers = cryptoResult.tokenTransfers || result.tokenTransfers || [];
|
|
195
|
-
return result;
|
|
196
|
-
} catch (error) {
|
|
197
|
-
return {
|
|
198
|
-
type: "UNKNOWN",
|
|
199
|
-
humanReadableType: "Unknown Transaction",
|
|
200
|
-
transfers: [],
|
|
201
|
-
tokenTransfers: [],
|
|
202
|
-
raw: actualOptions.includeRaw ? {} : void 0,
|
|
203
|
-
details: {
|
|
204
|
-
error: `Failed to parse Transaction object: ${error instanceof Error ? error.message : String(error)}`
|
|
205
|
-
}
|
|
206
|
-
};
|
|
207
26
|
}
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
* @param transactionBodyBase64 - The base64 encoded transaction body
|
|
212
|
-
* @returns The parsed transaction
|
|
213
|
-
*/
|
|
214
|
-
static parseTransactionBody(transactionBodyBase64) {
|
|
215
|
-
try {
|
|
216
|
-
const buffer = ethers.decodeBase64(transactionBodyBase64);
|
|
217
|
-
const txBody = proto.SchedulableTransactionBody.decode(buffer);
|
|
218
|
-
const transactionType = this.getTransactionType(txBody);
|
|
219
|
-
const result = {
|
|
220
|
-
type: transactionType,
|
|
221
|
-
humanReadableType: this.getHumanReadableType(transactionType),
|
|
222
|
-
transfers: [],
|
|
223
|
-
tokenTransfers: [],
|
|
224
|
-
raw: txBody
|
|
225
|
-
};
|
|
226
|
-
if (txBody.memo) {
|
|
227
|
-
result.memo = txBody.memo;
|
|
228
|
-
}
|
|
229
|
-
if (txBody.transactionFee) {
|
|
230
|
-
const hbarAmount = Hbar.fromTinybars(
|
|
231
|
-
Long.fromValue(txBody.transactionFee)
|
|
232
|
-
);
|
|
233
|
-
result.transactionFee = hbarAmount.toString(HbarUnit.Hbar);
|
|
234
|
-
}
|
|
235
|
-
this.applySchedulableTransactionParsing(txBody, result);
|
|
236
|
-
return result;
|
|
237
|
-
} catch (error) {
|
|
238
|
-
return {
|
|
239
|
-
type: "UNKNOWN",
|
|
240
|
-
humanReadableType: "Unknown Transaction",
|
|
241
|
-
transfers: [],
|
|
242
|
-
tokenTransfers: [],
|
|
243
|
-
raw: void 0,
|
|
244
|
-
details: {
|
|
245
|
-
error: `Failed to parse transaction body: ${error instanceof Error ? error.message : String(error)}`
|
|
246
|
-
}
|
|
247
|
-
};
|
|
27
|
+
if (!_Logger.instances.has(moduleKey)) {
|
|
28
|
+
const logger = loggerFactory ? loggerFactory(options) : new _Logger(options);
|
|
29
|
+
_Logger.instances.set(moduleKey, logger);
|
|
248
30
|
}
|
|
31
|
+
return _Logger.instances.get(moduleKey);
|
|
249
32
|
}
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
* Uses registry pattern to eliminate massive if-else chain
|
|
253
|
-
*/
|
|
254
|
-
static detectTransactionTypeFromBody(txBody) {
|
|
255
|
-
return getTransactionTypeFromBody(txBody);
|
|
33
|
+
setLogLevel(level) {
|
|
34
|
+
this.level = level;
|
|
256
35
|
}
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
* @param scheduleResponse - The schedule response to parse
|
|
260
|
-
* @returns The parsed transaction
|
|
261
|
-
*/
|
|
262
|
-
static parseScheduleResponse(scheduleResponse) {
|
|
263
|
-
if (!scheduleResponse.transaction_body) {
|
|
264
|
-
return {
|
|
265
|
-
type: "UNKNOWN",
|
|
266
|
-
humanReadableType: "Unknown Transaction",
|
|
267
|
-
transfers: [],
|
|
268
|
-
tokenTransfers: [],
|
|
269
|
-
raw: void 0,
|
|
270
|
-
details: {
|
|
271
|
-
error: "Schedule response missing transaction_body"
|
|
272
|
-
}
|
|
273
|
-
};
|
|
274
|
-
}
|
|
275
|
-
const parsed = this.parseTransactionBody(scheduleResponse.transaction_body);
|
|
276
|
-
if (scheduleResponse.memo) {
|
|
277
|
-
parsed.memo = scheduleResponse.memo;
|
|
278
|
-
}
|
|
279
|
-
return parsed;
|
|
280
|
-
}
|
|
281
|
-
/**
|
|
282
|
-
* Determine the transaction type using registry pattern
|
|
283
|
-
* @param txBody - The transaction body to determine the type of
|
|
284
|
-
* @returns The type of the transaction
|
|
285
|
-
*/
|
|
286
|
-
static getTransactionType(txBody) {
|
|
287
|
-
return getTransactionTypeFromBody(txBody).type;
|
|
36
|
+
getLevel() {
|
|
37
|
+
return this.level;
|
|
288
38
|
}
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
static getHumanReadableType(type) {
|
|
295
|
-
return getHumanReadableTransactionType(type);
|
|
39
|
+
setSilent(silent) {
|
|
40
|
+
this.silent = silent;
|
|
41
|
+
if (silent) {
|
|
42
|
+
this.level = "silent";
|
|
43
|
+
}
|
|
296
44
|
}
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
* @param parsedTx - The parsed transaction
|
|
300
|
-
* @returns The human-readable summary of the transaction
|
|
301
|
-
*/
|
|
302
|
-
static getTransactionSummary(parsedTx) {
|
|
303
|
-
return resolveTransactionSummary(parsedTx);
|
|
45
|
+
setModule(module) {
|
|
46
|
+
this.moduleContext = module;
|
|
304
47
|
}
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
*/
|
|
309
|
-
static validateTransactionBytes(transactionBytes) {
|
|
310
|
-
if (!transactionBytes || typeof transactionBytes !== "string") {
|
|
311
|
-
return {
|
|
312
|
-
isValid: false,
|
|
313
|
-
error: "Transaction bytes must be a non-empty string"
|
|
314
|
-
};
|
|
48
|
+
formatArgs(args) {
|
|
49
|
+
if (args.length === 0) {
|
|
50
|
+
return { msg: "" };
|
|
315
51
|
}
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
let isValid = false;
|
|
320
|
-
let error;
|
|
321
|
-
if (format === "hex") {
|
|
322
|
-
isValid = hexRegex.test(transactionBytes) && transactionBytes.length > 2;
|
|
323
|
-
if (!isValid) {
|
|
324
|
-
error = "Invalid hex format";
|
|
325
|
-
}
|
|
326
|
-
} else {
|
|
327
|
-
isValid = base64Regex.test(transactionBytes) && transactionBytes.length > 0;
|
|
328
|
-
if (!isValid) {
|
|
329
|
-
error = "Invalid base64 format";
|
|
52
|
+
if (args.length === 1) {
|
|
53
|
+
if (typeof args[0] === "string") {
|
|
54
|
+
return { msg: args[0] };
|
|
330
55
|
}
|
|
56
|
+
return { msg: "", data: args[0] };
|
|
331
57
|
}
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
};
|
|
338
|
-
}
|
|
339
|
-
/**
|
|
340
|
-
* Detects the format of transaction bytes
|
|
341
|
-
* @param transactionBytes - The transaction bytes to analyze
|
|
342
|
-
* @returns The detected format ('base64' or 'hex')
|
|
343
|
-
*/
|
|
344
|
-
static detectTransactionFormat(transactionBytes) {
|
|
345
|
-
return transactionBytes.startsWith("0x") ? "hex" : "base64";
|
|
346
|
-
}
|
|
347
|
-
/**
|
|
348
|
-
* Decodes transaction bytes from string to Uint8Array
|
|
349
|
-
* @param transactionBytes - The transaction bytes string (base64 or hex)
|
|
350
|
-
* @returns Decoded Uint8Array
|
|
351
|
-
* @throws TransactionParsingError if decoding fails
|
|
352
|
-
*/
|
|
353
|
-
static decodeTransactionBytes(transactionBytes) {
|
|
354
|
-
try {
|
|
355
|
-
const format = this.detectTransactionFormat(transactionBytes);
|
|
356
|
-
if (format === "hex") {
|
|
357
|
-
const hexString = transactionBytes.slice(2);
|
|
358
|
-
return new Uint8Array(Buffer.from(hexString, "hex"));
|
|
58
|
+
const stringArgs = [];
|
|
59
|
+
const objectArgs = [];
|
|
60
|
+
args.forEach((arg) => {
|
|
61
|
+
if (typeof arg === "string" || typeof arg === "number" || typeof arg === "boolean") {
|
|
62
|
+
stringArgs.push(String(arg));
|
|
359
63
|
} else {
|
|
360
|
-
|
|
64
|
+
objectArgs.push(arg);
|
|
361
65
|
}
|
|
362
|
-
}
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
"DECODE_ERROR",
|
|
366
|
-
error instanceof Error ? error : void 0,
|
|
367
|
-
transactionBytes
|
|
368
|
-
);
|
|
369
|
-
}
|
|
66
|
+
});
|
|
67
|
+
const msg = stringArgs.join(" ");
|
|
68
|
+
return objectArgs.length > 0 ? { msg, data: objectArgs } : { msg };
|
|
370
69
|
}
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
*/
|
|
374
|
-
static async isValidHederaTransaction(transactionBytes) {
|
|
375
|
-
try {
|
|
376
|
-
if (!this.validateTransactionBytes(transactionBytes).isValid) {
|
|
377
|
-
return false;
|
|
378
|
-
}
|
|
379
|
-
const bytes = this.decodeTransactionBytes(transactionBytes);
|
|
380
|
-
Transaction.fromBytes(bytes);
|
|
381
|
-
return true;
|
|
382
|
-
} catch {
|
|
70
|
+
shouldLog(level) {
|
|
71
|
+
if (this.silent || this.level === "silent") {
|
|
383
72
|
return false;
|
|
384
73
|
}
|
|
74
|
+
const levels = ["trace", "debug", "info", "warn", "error", "silent"];
|
|
75
|
+
const currentLevelIndex = levels.indexOf(this.level);
|
|
76
|
+
const targetLevelIndex = levels.indexOf(level);
|
|
77
|
+
return targetLevelIndex >= currentLevelIndex;
|
|
385
78
|
}
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
static decodeBytesLegacy(transactionBytes) {
|
|
390
|
-
return this.decodeTransactionBytes(transactionBytes);
|
|
391
|
-
}
|
|
392
|
-
/**
|
|
393
|
-
* Parse transaction bytes into structured data using thin orchestration
|
|
394
|
-
* Delegates to specialized parsers for clean separation of concerns
|
|
395
|
-
*/
|
|
396
|
-
static async parseTransaction(transactionBytes, options = {}) {
|
|
397
|
-
try {
|
|
398
|
-
const bytes = this.decodeTransactionBytes(transactionBytes);
|
|
399
|
-
const transaction = Transaction.fromBytes(bytes);
|
|
400
|
-
const metadata = this.extractTransactionMetadataEnhanced(transaction);
|
|
401
|
-
const parserResults = this.runAllParsers(transaction);
|
|
402
|
-
const primaryResult = parserResults.find(
|
|
403
|
-
(result2) => result2.type && result2.type !== "UNKNOWN"
|
|
404
|
-
) || {};
|
|
405
|
-
const protoParsingResult = this.parseFromProtobuf(bytes);
|
|
406
|
-
const finalType = protoParsingResult.type || primaryResult.type || "UNKNOWN";
|
|
407
|
-
const finalHumanReadableType = protoParsingResult.humanReadableType || primaryResult.humanReadableType || "Unknown Transaction";
|
|
408
|
-
const result = {
|
|
409
|
-
type: finalType,
|
|
410
|
-
humanReadableType: finalHumanReadableType,
|
|
411
|
-
transfers: [],
|
|
412
|
-
tokenTransfers: [],
|
|
413
|
-
details: { ...metadata },
|
|
414
|
-
memo: typeof metadata.memo === "string" ? metadata.memo : void 0,
|
|
415
|
-
transactionId: typeof metadata.transactionId === "string" ? metadata.transactionId : void 0,
|
|
416
|
-
nodeAccountIds: Array.isArray(metadata.nodeAccountIds) ? metadata.nodeAccountIds : [],
|
|
417
|
-
maxTransactionFee: typeof metadata.maxTransactionFee === "string" ? metadata.maxTransactionFee : void 0,
|
|
418
|
-
validStart: typeof metadata.validStart === "string" ? metadata.validStart : void 0,
|
|
419
|
-
validDuration: typeof metadata.validDuration === "string" ? metadata.validDuration : void 0,
|
|
420
|
-
raw: options.includeRaw ? {} : void 0
|
|
421
|
-
};
|
|
422
|
-
this.mergeAllResults(
|
|
423
|
-
result,
|
|
424
|
-
protoParsingResult,
|
|
425
|
-
primaryResult,
|
|
426
|
-
parserResults
|
|
427
|
-
);
|
|
428
|
-
return result;
|
|
429
|
-
} catch (error) {
|
|
430
|
-
throw new TransactionParsingError(
|
|
431
|
-
"Failed to parse as regular transaction",
|
|
432
|
-
"REGULAR_PARSING_FAILED",
|
|
433
|
-
error instanceof Error ? error : void 0,
|
|
434
|
-
transactionBytes
|
|
435
|
-
);
|
|
79
|
+
getConsoleMethod(level) {
|
|
80
|
+
if (level === "error") {
|
|
81
|
+
return console.error;
|
|
436
82
|
}
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
* Parse scheduled transaction body
|
|
440
|
-
*/
|
|
441
|
-
static parseScheduledTransaction(transactionBytes, options = {}) {
|
|
442
|
-
try {
|
|
443
|
-
const parsedTx = this.parseTransactionBody(transactionBytes);
|
|
444
|
-
const validation = this.validateTransactionBytes(transactionBytes);
|
|
445
|
-
const enhancedResult = {
|
|
446
|
-
...parsedTx,
|
|
447
|
-
details: {
|
|
448
|
-
...parsedTx.details || {},
|
|
449
|
-
parseMethod: "scheduled",
|
|
450
|
-
validation,
|
|
451
|
-
parseAttempts: parsedTx.details?.parseAttempts || 1
|
|
452
|
-
},
|
|
453
|
-
formatDetection: {
|
|
454
|
-
originalFormat: validation.format || "base64",
|
|
455
|
-
wasConverted: false,
|
|
456
|
-
length: transactionBytes.length
|
|
457
|
-
}
|
|
458
|
-
};
|
|
459
|
-
return enhancedResult;
|
|
460
|
-
} catch (error) {
|
|
461
|
-
throw new TransactionParsingError(
|
|
462
|
-
"Failed to parse as scheduled transaction",
|
|
463
|
-
"SCHEDULED_PARSING_FAILED",
|
|
464
|
-
error instanceof Error ? error : void 0,
|
|
465
|
-
transactionBytes
|
|
466
|
-
);
|
|
83
|
+
if (level === "warn") {
|
|
84
|
+
return console.warn;
|
|
467
85
|
}
|
|
86
|
+
if (level === "debug") {
|
|
87
|
+
return console.debug;
|
|
88
|
+
}
|
|
89
|
+
return console.log;
|
|
468
90
|
}
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
}
|
|
482
|
-
/**
|
|
483
|
-
* Extract enhanced metadata from Transaction object
|
|
484
|
-
*/
|
|
485
|
-
static extractTransactionMetadataEnhanced(transaction) {
|
|
486
|
-
return {
|
|
487
|
-
transactionId: transaction.transactionId?.toString(),
|
|
488
|
-
nodeAccountIds: transaction.nodeAccountIds?.map((id) => id.toString()) || [],
|
|
489
|
-
maxTransactionFee: transaction.maxTransactionFee?.toTinybars().toString() || "0",
|
|
490
|
-
memo: transaction._transactionMemo || void 0,
|
|
491
|
-
validStart: transaction._transactionValidStart?.toString(),
|
|
492
|
-
validDuration: transaction._transactionValidDuration?.toString()
|
|
493
|
-
};
|
|
494
|
-
}
|
|
495
|
-
/**
|
|
496
|
-
* Run all available parsers on a transaction
|
|
497
|
-
*/
|
|
498
|
-
static runAllParsers(transaction) {
|
|
499
|
-
return [
|
|
500
|
-
HTSParser.parseFromTransactionObject(transaction),
|
|
501
|
-
CryptoParser.parseFromTransactionObject(transaction),
|
|
502
|
-
HCSParser.parseFromTransactionObject(transaction),
|
|
503
|
-
FileParser.parseFromTransactionObject(transaction),
|
|
504
|
-
SCSParser.parseFromTransactionObject(transaction),
|
|
505
|
-
ScheduleParser.parseFromTransactionObject(transaction),
|
|
506
|
-
UtilParser.parseFromTransactionObject(transaction)
|
|
507
|
-
];
|
|
508
|
-
}
|
|
509
|
-
/**
|
|
510
|
-
* Parse transaction from protobuf bytes
|
|
511
|
-
*/
|
|
512
|
-
static parseFromProtobuf(bytes) {
|
|
513
|
-
const result = {};
|
|
514
|
-
try {
|
|
515
|
-
const decoded = proto.TransactionList.decode(bytes);
|
|
516
|
-
if (decoded.transactionList && decoded.transactionList.length > 0) {
|
|
517
|
-
const tx = decoded.transactionList[0];
|
|
518
|
-
let txBody = null;
|
|
519
|
-
if (tx.bodyBytes && tx.bodyBytes.length > 0) {
|
|
520
|
-
txBody = proto.TransactionBody.decode(tx.bodyBytes);
|
|
521
|
-
} else if (tx.signedTransactionBytes && tx.signedTransactionBytes.length > 0) {
|
|
522
|
-
const signedTx = proto.SignedTransaction.decode(
|
|
523
|
-
tx.signedTransactionBytes
|
|
524
|
-
);
|
|
525
|
-
if (signedTx.bodyBytes) {
|
|
526
|
-
txBody = proto.TransactionBody.decode(signedTx.bodyBytes);
|
|
527
|
-
}
|
|
528
|
-
}
|
|
529
|
-
if (txBody) {
|
|
530
|
-
const typeResult = this.detectTransactionTypeFromBody(txBody);
|
|
531
|
-
result.type = typeResult.type;
|
|
532
|
-
result.humanReadableType = typeResult.humanReadableType;
|
|
533
|
-
const details = this.parseTransactionBodyDetails(
|
|
534
|
-
txBody,
|
|
535
|
-
typeResult.type
|
|
536
|
-
);
|
|
537
|
-
Object.assign(result, details);
|
|
538
|
-
}
|
|
91
|
+
writeLog(level, ...args) {
|
|
92
|
+
if (!this.shouldLog(level)) {
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
const { msg, data } = this.formatArgs(args);
|
|
96
|
+
const timestamp = (/* @__PURE__ */ new Date()).toISOString();
|
|
97
|
+
const consoleMethod = this.getConsoleMethod(level);
|
|
98
|
+
if (this.prettyPrint) {
|
|
99
|
+
const levelFormatted = level.toUpperCase().padEnd(5);
|
|
100
|
+
let output = `${timestamp} ${levelFormatted} [${this.moduleContext}] ${msg}`;
|
|
101
|
+
if (data) {
|
|
102
|
+
output += "\n" + inspect(data, { colors: true, depth: 3 });
|
|
539
103
|
}
|
|
540
|
-
|
|
104
|
+
consoleMethod(output);
|
|
105
|
+
} else {
|
|
106
|
+
const logObj = {
|
|
107
|
+
timestamp,
|
|
108
|
+
level,
|
|
109
|
+
module: this.moduleContext,
|
|
110
|
+
message: msg,
|
|
111
|
+
...data && { data }
|
|
112
|
+
};
|
|
113
|
+
consoleMethod(JSON.stringify(logObj));
|
|
541
114
|
}
|
|
542
|
-
return result;
|
|
543
115
|
}
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
*/
|
|
547
|
-
static mergeAllResults(result, protoResult, primaryResult, parserResults) {
|
|
548
|
-
const cryptoResult = parserResults.find((r) => r.transfers || r.tokenTransfers) || {};
|
|
549
|
-
result.transfers = cryptoResult.transfers || result.transfers || [];
|
|
550
|
-
result.tokenTransfers = cryptoResult.tokenTransfers || result.tokenTransfers || [];
|
|
551
|
-
Object.keys(protoResult).forEach((key) => {
|
|
552
|
-
if (protoResult[key] !== void 0 && key !== "type" && key !== "humanReadableType") {
|
|
553
|
-
result[key] = protoResult[key];
|
|
554
|
-
}
|
|
555
|
-
});
|
|
556
|
-
Object.keys(primaryResult).forEach((key) => {
|
|
557
|
-
if (primaryResult[key] !== void 0 && !(key in result) && key !== "type" && key !== "humanReadableType") {
|
|
558
|
-
result[key] = primaryResult[key];
|
|
559
|
-
}
|
|
560
|
-
});
|
|
116
|
+
debug(...args) {
|
|
117
|
+
this.writeLog("debug", ...args);
|
|
561
118
|
}
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
* Eliminates conditional logic in parseTransactionBody
|
|
565
|
-
*/
|
|
566
|
-
static applySchedulableTransactionParsing(txBody, result) {
|
|
567
|
-
if (txBody.cryptoTransfer) {
|
|
568
|
-
CryptoParser.parseCryptoTransfers(txBody.cryptoTransfer, result);
|
|
569
|
-
}
|
|
570
|
-
if (txBody.cryptoDelete) {
|
|
571
|
-
result.cryptoDelete = CryptoParser.parseCryptoDelete(txBody.cryptoDelete);
|
|
572
|
-
}
|
|
573
|
-
if (txBody.cryptoCreateAccount) {
|
|
574
|
-
result.cryptoCreateAccount = CryptoParser.parseCryptoCreateAccount(
|
|
575
|
-
txBody.cryptoCreateAccount
|
|
576
|
-
);
|
|
577
|
-
}
|
|
578
|
-
if (txBody.cryptoUpdateAccount) {
|
|
579
|
-
result.cryptoUpdateAccount = CryptoParser.parseCryptoUpdateAccount(
|
|
580
|
-
txBody.cryptoUpdateAccount
|
|
581
|
-
);
|
|
582
|
-
}
|
|
583
|
-
if (txBody.cryptoApproveAllowance) {
|
|
584
|
-
result.cryptoApproveAllowance = CryptoParser.parseCryptoApproveAllowance(
|
|
585
|
-
txBody.cryptoApproveAllowance
|
|
586
|
-
);
|
|
587
|
-
}
|
|
588
|
-
if (txBody.cryptoDeleteAllowance) {
|
|
589
|
-
result.cryptoDeleteAllowance = CryptoParser.parseCryptoDeleteAllowance(
|
|
590
|
-
txBody.cryptoDeleteAllowance
|
|
591
|
-
);
|
|
592
|
-
}
|
|
593
|
-
if (txBody.contractCall) {
|
|
594
|
-
result.contractCall = SCSParser.parseContractCall(txBody.contractCall);
|
|
595
|
-
}
|
|
596
|
-
if (txBody.contractCreateInstance) {
|
|
597
|
-
result.contractCreate = SCSParser.parseContractCreate(
|
|
598
|
-
txBody.contractCreateInstance
|
|
599
|
-
);
|
|
600
|
-
}
|
|
601
|
-
if (txBody.contractUpdateInstance) {
|
|
602
|
-
result.contractUpdate = SCSParser.parseContractUpdate(
|
|
603
|
-
txBody.contractUpdateInstance
|
|
604
|
-
);
|
|
605
|
-
}
|
|
606
|
-
if (txBody.contractDeleteInstance) {
|
|
607
|
-
result.contractDelete = SCSParser.parseContractDelete(
|
|
608
|
-
txBody.contractDeleteInstance
|
|
609
|
-
);
|
|
610
|
-
}
|
|
611
|
-
if (txBody.tokenCreation) {
|
|
612
|
-
result.tokenCreation = HTSParser.parseTokenCreate(txBody.tokenCreation);
|
|
613
|
-
}
|
|
614
|
-
if (txBody.tokenMint) {
|
|
615
|
-
result.tokenMint = HTSParser.parseTokenMint(txBody.tokenMint);
|
|
616
|
-
}
|
|
617
|
-
if (txBody.tokenBurn) {
|
|
618
|
-
result.tokenBurn = HTSParser.parseTokenBurn(txBody.tokenBurn);
|
|
619
|
-
}
|
|
620
|
-
if (txBody.tokenUpdate) {
|
|
621
|
-
result.tokenUpdate = HTSParser.parseTokenUpdate(txBody.tokenUpdate);
|
|
622
|
-
}
|
|
623
|
-
if (txBody.tokenFeeScheduleUpdate) {
|
|
624
|
-
result.tokenFeeScheduleUpdate = HTSParser.parseTokenFeeScheduleUpdate(
|
|
625
|
-
txBody.tokenFeeScheduleUpdate
|
|
626
|
-
);
|
|
627
|
-
}
|
|
628
|
-
if (txBody.tokenFreeze) {
|
|
629
|
-
result.tokenFreeze = HTSParser.parseTokenFreeze(txBody.tokenFreeze);
|
|
630
|
-
}
|
|
631
|
-
if (txBody.tokenUnfreeze) {
|
|
632
|
-
result.tokenUnfreeze = HTSParser.parseTokenUnfreeze(txBody.tokenUnfreeze);
|
|
633
|
-
}
|
|
634
|
-
if (txBody.tokenGrantKyc) {
|
|
635
|
-
result.tokenGrantKyc = HTSParser.parseTokenGrantKyc(txBody.tokenGrantKyc);
|
|
636
|
-
}
|
|
637
|
-
if (txBody.tokenRevokeKyc) {
|
|
638
|
-
result.tokenRevokeKyc = HTSParser.parseTokenRevokeKyc(
|
|
639
|
-
txBody.tokenRevokeKyc
|
|
640
|
-
);
|
|
641
|
-
}
|
|
642
|
-
if (txBody.tokenPause) {
|
|
643
|
-
result.tokenPause = HTSParser.parseTokenPause(txBody.tokenPause);
|
|
644
|
-
}
|
|
645
|
-
if (txBody.tokenUnpause) {
|
|
646
|
-
result.tokenUnpause = HTSParser.parseTokenUnpause(txBody.tokenUnpause);
|
|
647
|
-
}
|
|
648
|
-
if (txBody.tokenWipe) {
|
|
649
|
-
result.tokenWipeAccount = HTSParser.parseTokenWipeAccount(
|
|
650
|
-
txBody.tokenWipe
|
|
651
|
-
);
|
|
652
|
-
}
|
|
653
|
-
if (txBody.tokenDeletion) {
|
|
654
|
-
result.tokenDelete = HTSParser.parseTokenDelete(txBody.tokenDeletion);
|
|
655
|
-
}
|
|
656
|
-
if (txBody.tokenAssociate) {
|
|
657
|
-
result.tokenAssociate = HTSParser.parseTokenAssociate(
|
|
658
|
-
txBody.tokenAssociate
|
|
659
|
-
);
|
|
660
|
-
}
|
|
661
|
-
if (txBody.tokenDissociate) {
|
|
662
|
-
result.tokenDissociate = HTSParser.parseTokenDissociate(
|
|
663
|
-
txBody.tokenDissociate
|
|
664
|
-
);
|
|
665
|
-
}
|
|
666
|
-
if (txBody.tokenAirdrop) {
|
|
667
|
-
result.tokenAirdrop = HTSParser.parseTokenAirdropFromProto(
|
|
668
|
-
txBody.tokenAirdrop
|
|
669
|
-
);
|
|
670
|
-
}
|
|
671
|
-
if (txBody.consensusCreateTopic) {
|
|
672
|
-
result.consensusCreateTopic = HCSParser.parseConsensusCreateTopic(
|
|
673
|
-
txBody.consensusCreateTopic
|
|
674
|
-
);
|
|
675
|
-
}
|
|
676
|
-
if (txBody.consensusSubmitMessage) {
|
|
677
|
-
result.consensusSubmitMessage = HCSParser.parseConsensusSubmitMessage(
|
|
678
|
-
txBody.consensusSubmitMessage
|
|
679
|
-
);
|
|
680
|
-
}
|
|
681
|
-
if (txBody.consensusUpdateTopic) {
|
|
682
|
-
result.consensusUpdateTopic = HCSParser.parseConsensusUpdateTopic(
|
|
683
|
-
txBody.consensusUpdateTopic
|
|
684
|
-
);
|
|
685
|
-
}
|
|
686
|
-
if (txBody.consensusDeleteTopic) {
|
|
687
|
-
result.consensusDeleteTopic = HCSParser.parseConsensusDeleteTopic(
|
|
688
|
-
txBody.consensusDeleteTopic
|
|
689
|
-
);
|
|
690
|
-
}
|
|
691
|
-
if (txBody.fileCreate) {
|
|
692
|
-
result.fileCreate = FileParser.parseFileCreate(txBody.fileCreate);
|
|
693
|
-
}
|
|
694
|
-
if (txBody.fileAppend) {
|
|
695
|
-
result.fileAppend = FileParser.parseFileAppend(txBody.fileAppend);
|
|
696
|
-
}
|
|
697
|
-
if (txBody.fileUpdate) {
|
|
698
|
-
result.fileUpdate = FileParser.parseFileUpdate(txBody.fileUpdate);
|
|
699
|
-
}
|
|
700
|
-
if (txBody.fileDelete) {
|
|
701
|
-
result.fileDelete = FileParser.parseFileDelete(txBody.fileDelete);
|
|
702
|
-
}
|
|
703
|
-
if (txBody.utilPrng) {
|
|
704
|
-
result.utilPrng = UtilParser.parseUtilPrng(txBody.utilPrng);
|
|
705
|
-
}
|
|
119
|
+
info(...args) {
|
|
120
|
+
this.writeLog("info", ...args);
|
|
706
121
|
}
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
* Uses a scalable registry pattern instead of if-else chains
|
|
710
|
-
*/
|
|
711
|
-
static parseTransactionBodyDetails(txBody, transactionType) {
|
|
712
|
-
const result = {};
|
|
713
|
-
const parserConfig = transactionParserRegistry[transactionType];
|
|
714
|
-
if (parserConfig) {
|
|
715
|
-
const bodyData = txBody[parserConfig.bodyField];
|
|
716
|
-
if (bodyData) {
|
|
717
|
-
const parserResult = parserConfig.parser(bodyData);
|
|
718
|
-
if (parserConfig.spreadResult) {
|
|
719
|
-
Object.assign(result, parserResult);
|
|
720
|
-
} else {
|
|
721
|
-
result[parserConfig.resultField] = parserResult;
|
|
722
|
-
}
|
|
723
|
-
}
|
|
724
|
-
}
|
|
725
|
-
return result;
|
|
122
|
+
warn(...args) {
|
|
123
|
+
this.writeLog("warn", ...args);
|
|
726
124
|
}
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
* Eliminates transactionFields array and forEach logic
|
|
730
|
-
*/
|
|
731
|
-
static mergeProtoParsingResults(result, protoResult, htsResult, transaction, originalBytes) {
|
|
732
|
-
const fieldsToMerge = Object.values(transactionParserRegistry).map(
|
|
733
|
-
(config) => config.resultField
|
|
734
|
-
);
|
|
735
|
-
for (const field of fieldsToMerge) {
|
|
736
|
-
const protoValue = protoResult[field];
|
|
737
|
-
const htsValue = htsResult[field];
|
|
738
|
-
if (protoValue !== void 0) {
|
|
739
|
-
result[field] = protoValue;
|
|
740
|
-
} else if (htsValue !== void 0) {
|
|
741
|
-
result[field] = htsValue;
|
|
742
|
-
} else {
|
|
743
|
-
this.handleSpecialFieldExtraction(result, field, transaction);
|
|
744
|
-
}
|
|
745
|
-
}
|
|
125
|
+
error(...args) {
|
|
126
|
+
this.writeLog("error", ...args);
|
|
746
127
|
}
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
*/
|
|
750
|
-
static handleSpecialFieldExtraction(result, field, transaction) {
|
|
751
|
-
if (field === "tokenCreation" && result.type === "TOKENCREATE") {
|
|
752
|
-
const extracted = HTSParser.extractTokenCreationFromTransaction(transaction);
|
|
753
|
-
if (extracted) {
|
|
754
|
-
result[field] = extracted;
|
|
755
|
-
}
|
|
756
|
-
} else if (field === "tokenAirdrop" && result.type === "TOKENAIRDROP") {
|
|
757
|
-
const extracted = HTSParser.extractTokenAirdropFromTransaction(transaction);
|
|
758
|
-
if (extracted) {
|
|
759
|
-
result[field] = extracted;
|
|
760
|
-
}
|
|
761
|
-
}
|
|
128
|
+
trace(...args) {
|
|
129
|
+
this.writeLog("trace", ...args);
|
|
762
130
|
}
|
|
763
131
|
/**
|
|
764
|
-
*
|
|
132
|
+
* Clear all logger instances
|
|
133
|
+
* Used when switching logger implementations
|
|
765
134
|
*/
|
|
766
|
-
static
|
|
767
|
-
|
|
768
|
-
return {
|
|
769
|
-
type: "UNKNOWN",
|
|
770
|
-
humanReadableType: "Unknown Transaction",
|
|
771
|
-
transfers: [],
|
|
772
|
-
tokenTransfers: [],
|
|
773
|
-
details: {
|
|
774
|
-
rawBytes: transactionBytes.length > 100 ? transactionBytes.substring(0, 100) + "..." : transactionBytes,
|
|
775
|
-
primaryError: primaryError?.message,
|
|
776
|
-
secondaryError: secondaryError?.message,
|
|
777
|
-
parseAttempts: secondaryError ? 2 : 1,
|
|
778
|
-
validation
|
|
779
|
-
},
|
|
780
|
-
formatDetection: {
|
|
781
|
-
originalFormat: validation.format || "base64",
|
|
782
|
-
wasConverted: false,
|
|
783
|
-
length: transactionBytes.length
|
|
784
|
-
},
|
|
785
|
-
raw: {}
|
|
786
|
-
};
|
|
135
|
+
static clearInstances() {
|
|
136
|
+
_Logger.instances.clear();
|
|
787
137
|
}
|
|
788
|
-
}
|
|
138
|
+
};
|
|
139
|
+
_Logger.instances = /* @__PURE__ */ new Map();
|
|
140
|
+
let Logger = _Logger;
|
|
789
141
|
export {
|
|
790
|
-
|
|
791
|
-
|
|
142
|
+
Logger,
|
|
143
|
+
setLoggerFactory
|
|
792
144
|
};
|
|
793
145
|
//# sourceMappingURL=standards-sdk.es116.js.map
|