@hashgraphonline/standards-sdk 0.1.143-feat-solana-register.canary.b3bfd5e.67 → 0.1.143-feat-solana-register.canary.f10b0fe.69
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-10/sdk.d.ts +8 -0
- package/dist/cjs/hcs-10/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-15/browser.d.ts +2 -0
- package/dist/cjs/hcs-15/browser.d.ts.map +1 -1
- package/dist/cjs/hcs-15/sdk.d.ts +2 -0
- package/dist/cjs/hcs-15/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-15/tx.d.ts +4 -0
- package/dist/cjs/hcs-15/tx.d.ts.map +1 -1
- package/dist/cjs/hcs-16/tx.d.ts +9 -0
- package/dist/cjs/hcs-16/tx.d.ts.map +1 -1
- package/dist/cjs/standards-sdk.cjs +2 -2
- package/dist/cjs/standards-sdk.cjs.map +1 -1
- package/dist/cjs/utils/dynamic-import.d.ts.map +1 -1
- package/dist/es/hcs-10/sdk.d.ts +8 -0
- package/dist/es/hcs-10/sdk.d.ts.map +1 -1
- package/dist/es/hcs-15/browser.d.ts +2 -0
- package/dist/es/hcs-15/browser.d.ts.map +1 -1
- package/dist/es/hcs-15/sdk.d.ts +2 -0
- package/dist/es/hcs-15/sdk.d.ts.map +1 -1
- package/dist/es/hcs-15/tx.d.ts +4 -0
- package/dist/es/hcs-15/tx.d.ts.map +1 -1
- package/dist/es/hcs-16/tx.d.ts +9 -0
- package/dist/es/hcs-16/tx.d.ts.map +1 -1
- package/dist/es/standards-sdk.es.js +8 -2
- package/dist/es/standards-sdk.es110.js +1 -0
- package/dist/es/standards-sdk.es110.js.map +1 -1
- package/dist/es/standards-sdk.es111.js +5 -5
- package/dist/es/standards-sdk.es121.js +1 -1
- package/dist/es/standards-sdk.es122.js +1 -1
- package/dist/es/standards-sdk.es123.js +5 -5
- package/dist/es/standards-sdk.es125.js +1 -1
- package/dist/es/standards-sdk.es126.js +1 -1
- package/dist/es/standards-sdk.es128.js +1 -1
- package/dist/es/standards-sdk.es131.js +1 -1
- package/dist/es/standards-sdk.es138.js +1 -1
- package/dist/es/standards-sdk.es147.js +54 -12287
- package/dist/es/standards-sdk.es147.js.map +1 -1
- package/dist/es/standards-sdk.es148.js +81 -15
- package/dist/es/standards-sdk.es148.js.map +1 -1
- package/dist/es/standards-sdk.es149.js +12286 -53
- package/dist/es/standards-sdk.es149.js.map +1 -1
- package/dist/es/standards-sdk.es150.js +161 -71
- package/dist/es/standards-sdk.es150.js.map +1 -1
- package/dist/es/standards-sdk.es151.js +289 -139
- package/dist/es/standards-sdk.es151.js.map +1 -1
- package/dist/es/standards-sdk.es152.js +298 -274
- package/dist/es/standards-sdk.es152.js.map +1 -1
- package/dist/es/standards-sdk.es153.js +369 -262
- package/dist/es/standards-sdk.es153.js.map +1 -1
- package/dist/es/standards-sdk.es154.js +194 -316
- package/dist/es/standards-sdk.es154.js.map +1 -1
- package/dist/es/standards-sdk.es155.js +64 -319
- package/dist/es/standards-sdk.es155.js.map +1 -1
- package/dist/es/standards-sdk.es156.js +15 -74
- package/dist/es/standards-sdk.es156.js.map +1 -1
- package/dist/es/standards-sdk.es17.js +1 -0
- package/dist/es/standards-sdk.es17.js.map +1 -1
- package/dist/es/standards-sdk.es19.js +19 -1
- package/dist/es/standards-sdk.es19.js.map +1 -1
- package/dist/es/standards-sdk.es20.js +2 -1
- package/dist/es/standards-sdk.es20.js.map +1 -1
- package/dist/es/standards-sdk.es28.js +2 -1
- package/dist/es/standards-sdk.es28.js.map +1 -1
- package/dist/es/standards-sdk.es31.js +1 -1
- package/dist/es/standards-sdk.es32.js +1 -1
- package/dist/es/standards-sdk.es36.js +2 -1
- package/dist/es/standards-sdk.es36.js.map +1 -1
- package/dist/es/standards-sdk.es37.js +1 -1
- package/dist/es/standards-sdk.es38.js +1 -1
- package/dist/es/standards-sdk.es57.js +1 -1
- package/dist/es/standards-sdk.es59.js +1 -1
- package/dist/es/standards-sdk.es60.js +1 -1
- package/dist/es/standards-sdk.es61.js +1 -0
- package/dist/es/standards-sdk.es61.js.map +1 -1
- package/dist/es/standards-sdk.es63.js +1 -1
- package/dist/es/standards-sdk.es65.js +1 -1
- package/dist/es/standards-sdk.es66.js +1 -1
- package/dist/es/standards-sdk.es78.js +1 -0
- package/dist/es/standards-sdk.es78.js.map +1 -1
- package/dist/es/standards-sdk.es87.js +22 -0
- package/dist/es/standards-sdk.es87.js.map +1 -1
- package/dist/es/standards-sdk.es88.js +4 -2
- package/dist/es/standards-sdk.es88.js.map +1 -1
- package/dist/es/standards-sdk.es89.js +4 -2
- package/dist/es/standards-sdk.es89.js.map +1 -1
- package/dist/es/standards-sdk.es92.js +70 -9
- package/dist/es/standards-sdk.es92.js.map +1 -1
- package/dist/es/utils/dynamic-import.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1,67 +1,299 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
1
|
+
import { proto } from "@hashgraph/proto";
|
|
2
|
+
import { Long, Hbar, HbarUnit, ContractId, AccountId, FileId } from "@hashgraph/sdk";
|
|
3
|
+
import { Buffer } from "buffer";
|
|
4
|
+
import { hasTransactionType, parseKey } from "./standards-sdk.es155.js";
|
|
5
|
+
class SCSParser {
|
|
6
|
+
/**
|
|
7
|
+
* Parse Smart Contract Service transaction using unified dual-branch approach
|
|
8
|
+
* This handles both regular transactions and signed transaction variants
|
|
9
|
+
*/
|
|
10
|
+
static parseSCSTransaction(transaction, originalBytes) {
|
|
11
|
+
try {
|
|
12
|
+
if (originalBytes || transaction.toBytes) {
|
|
13
|
+
try {
|
|
14
|
+
const bytesToParse = originalBytes || transaction.toBytes();
|
|
15
|
+
const decoded = proto.TransactionList.decode(bytesToParse);
|
|
16
|
+
if (decoded.transactionList && decoded.transactionList.length > 0) {
|
|
17
|
+
const tx = decoded.transactionList[0];
|
|
18
|
+
let txBody = null;
|
|
19
|
+
if (tx.bodyBytes && tx.bodyBytes.length > 0) {
|
|
20
|
+
txBody = proto.TransactionBody.decode(tx.bodyBytes);
|
|
21
|
+
} else if (tx.signedTransactionBytes && tx.signedTransactionBytes.length > 0) {
|
|
22
|
+
const signedTx = proto.SignedTransaction.decode(
|
|
23
|
+
tx.signedTransactionBytes
|
|
24
|
+
);
|
|
25
|
+
if (signedTx.bodyBytes) {
|
|
26
|
+
txBody = proto.TransactionBody.decode(signedTx.bodyBytes);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
if (txBody) {
|
|
30
|
+
const protoResult = this.parseFromProtobufTxBody(txBody);
|
|
31
|
+
if (protoResult.type && protoResult.type !== "UNKNOWN") {
|
|
32
|
+
return protoResult;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
} catch (protoError) {
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return this.parseFromTransactionInternals(transaction);
|
|
40
|
+
} catch (error) {
|
|
41
|
+
return {
|
|
42
|
+
type: "UNKNOWN",
|
|
43
|
+
humanReadableType: "Unknown Contract Transaction"
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Parse contract transaction from protobuf TransactionBody
|
|
49
|
+
* Handles all contract operations from decoded protobuf data
|
|
50
|
+
*/
|
|
51
|
+
static parseFromProtobufTxBody(txBody) {
|
|
52
|
+
if (txBody.contractCall) {
|
|
53
|
+
const contractCall = this.parseContractCall(txBody.contractCall);
|
|
54
|
+
if (contractCall) {
|
|
13
55
|
return {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
56
|
+
type: "CONTRACTCALL",
|
|
57
|
+
humanReadableType: "Contract Call",
|
|
58
|
+
contractCall
|
|
17
59
|
};
|
|
18
|
-
}
|
|
60
|
+
}
|
|
19
61
|
}
|
|
20
|
-
if (
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
62
|
+
if (txBody.contractCreateInstance) {
|
|
63
|
+
const contractCreate = this.parseContractCreate(
|
|
64
|
+
txBody.contractCreateInstance
|
|
65
|
+
);
|
|
66
|
+
if (contractCreate) {
|
|
67
|
+
return {
|
|
68
|
+
type: "CONTRACTCREATE",
|
|
69
|
+
humanReadableType: "Contract Create",
|
|
70
|
+
contractCreate
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
if (txBody.contractUpdateInstance) {
|
|
75
|
+
const contractUpdate = this.parseContractUpdate(
|
|
76
|
+
txBody.contractUpdateInstance
|
|
77
|
+
);
|
|
78
|
+
if (contractUpdate) {
|
|
79
|
+
return {
|
|
80
|
+
type: "CONTRACTUPDATE",
|
|
81
|
+
humanReadableType: "Contract Update",
|
|
82
|
+
contractUpdate
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
if (txBody.contractDeleteInstance) {
|
|
87
|
+
const contractDelete = this.parseContractDelete(
|
|
88
|
+
txBody.contractDeleteInstance
|
|
89
|
+
);
|
|
90
|
+
if (contractDelete) {
|
|
91
|
+
return {
|
|
92
|
+
type: "CONTRACTDELETE",
|
|
93
|
+
humanReadableType: "Contract Delete",
|
|
94
|
+
contractDelete
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
if (txBody.ethereumTransaction) {
|
|
99
|
+
const ethereumCall = this.parseEthereumTransaction(
|
|
100
|
+
txBody.ethereumTransaction
|
|
101
|
+
);
|
|
102
|
+
if (ethereumCall) {
|
|
103
|
+
return {
|
|
104
|
+
type: "ETHEREUMTRANSACTION",
|
|
105
|
+
humanReadableType: "Ethereum Transaction",
|
|
106
|
+
ethereumTransaction: ethereumCall
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return {};
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Extract contract data from Transaction internal fields
|
|
114
|
+
* This handles cases where data is stored in Transaction object internals
|
|
115
|
+
*/
|
|
116
|
+
static parseFromTransactionInternals(transaction) {
|
|
117
|
+
try {
|
|
118
|
+
const tx = transaction;
|
|
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);
|
|
41
131
|
}
|
|
132
|
+
return {
|
|
133
|
+
type: "CONTRACTCALL",
|
|
134
|
+
humanReadableType: "Contract Call",
|
|
135
|
+
contractCall
|
|
136
|
+
};
|
|
42
137
|
}
|
|
138
|
+
if (hasTransactionType(transaction, "contractCreateInstance")) {
|
|
139
|
+
const contractCreate = {
|
|
140
|
+
gas: tx._gas.toString(),
|
|
141
|
+
initialBalance: tx._initialBalance?.toString() || "0"
|
|
142
|
+
};
|
|
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");
|
|
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();
|
|
171
|
+
return {
|
|
172
|
+
type: "CONTRACTCREATE",
|
|
173
|
+
humanReadableType: "Contract Create",
|
|
174
|
+
contractCreate
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
if (hasTransactionType(transaction, "contractUpdateInstance")) {
|
|
178
|
+
const contractUpdate = {
|
|
179
|
+
contractIdToUpdate: tx._contractId.toString()
|
|
180
|
+
};
|
|
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;
|
|
185
|
+
}
|
|
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();
|
|
192
|
+
}
|
|
193
|
+
if (tx._declineReward !== void 0)
|
|
194
|
+
contractUpdate.declineReward = tx._declineReward;
|
|
195
|
+
if (tx._autoRenewPeriod)
|
|
196
|
+
contractUpdate.autoRenewPeriod = tx._autoRenewPeriod.toString();
|
|
197
|
+
return {
|
|
198
|
+
type: "CONTRACTUPDATE",
|
|
199
|
+
humanReadableType: "Contract Update",
|
|
200
|
+
contractUpdate
|
|
201
|
+
};
|
|
202
|
+
}
|
|
203
|
+
if (hasTransactionType(transaction, "contractDeleteInstance")) {
|
|
204
|
+
const contractDelete = {
|
|
205
|
+
contractIdToDelete: tx._contractId.toString()
|
|
206
|
+
};
|
|
207
|
+
if (tx._transferAccountId) {
|
|
208
|
+
contractDelete.transferAccountId = tx._transferAccountId.toString();
|
|
209
|
+
} else if (tx._transferContractId) {
|
|
210
|
+
contractDelete.transferContractId = tx._transferContractId.toString();
|
|
211
|
+
}
|
|
212
|
+
return {
|
|
213
|
+
type: "CONTRACTDELETE",
|
|
214
|
+
humanReadableType: "Contract Delete",
|
|
215
|
+
contractDelete
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
return {};
|
|
219
|
+
} catch (error) {
|
|
220
|
+
return {};
|
|
43
221
|
}
|
|
44
222
|
}
|
|
45
|
-
|
|
223
|
+
/**
|
|
224
|
+
* Enhanced function name extraction from contract call parameters
|
|
225
|
+
* Attempts to decode function selector and map to known function names
|
|
226
|
+
*/
|
|
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) {
|
|
46
259
|
if (!body) return void 0;
|
|
47
|
-
const data = {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
).toString();
|
|
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);
|
|
270
|
+
}
|
|
54
271
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
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);
|
|
292
|
+
}
|
|
61
293
|
}
|
|
62
294
|
return data;
|
|
63
295
|
}
|
|
64
|
-
static
|
|
296
|
+
static parseContractCreate(body) {
|
|
65
297
|
if (!body) return void 0;
|
|
66
298
|
const data = {};
|
|
67
299
|
if (body.initialBalance) {
|
|
@@ -69,22 +301,24 @@ class CryptoParser {
|
|
|
69
301
|
Long.fromValue(body.initialBalance)
|
|
70
302
|
).toString(HbarUnit.Hbar);
|
|
71
303
|
}
|
|
72
|
-
if (body.
|
|
73
|
-
data.
|
|
304
|
+
if (body.gas) {
|
|
305
|
+
data.gas = Long.fromValue(body.gas).toString();
|
|
74
306
|
}
|
|
75
|
-
if (body.
|
|
76
|
-
data.
|
|
307
|
+
if (body.adminKey) {
|
|
308
|
+
data.adminKey = parseKey(body.adminKey);
|
|
77
309
|
}
|
|
78
|
-
if (body.
|
|
79
|
-
data.
|
|
80
|
-
body.
|
|
81
|
-
).toString();
|
|
310
|
+
if (body.constructorParameters) {
|
|
311
|
+
data.constructorParameters = Buffer.from(
|
|
312
|
+
body.constructorParameters
|
|
313
|
+
).toString("hex");
|
|
82
314
|
}
|
|
83
315
|
if (body.memo) {
|
|
84
316
|
data.memo = body.memo;
|
|
85
317
|
}
|
|
86
|
-
if (body.
|
|
87
|
-
data.
|
|
318
|
+
if (body.autoRenewPeriod?.seconds) {
|
|
319
|
+
data.autoRenewPeriod = Long.fromValue(
|
|
320
|
+
body.autoRenewPeriod.seconds
|
|
321
|
+
).toString();
|
|
88
322
|
}
|
|
89
323
|
if (body.stakedAccountId) {
|
|
90
324
|
data.stakedAccountId = new AccountId(
|
|
@@ -98,42 +332,61 @@ class CryptoParser {
|
|
|
98
332
|
if (body.declineReward !== void 0) {
|
|
99
333
|
data.declineReward = body.declineReward;
|
|
100
334
|
}
|
|
101
|
-
if (body.
|
|
102
|
-
data.
|
|
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");
|
|
103
348
|
}
|
|
104
349
|
return data;
|
|
105
350
|
}
|
|
106
|
-
static
|
|
351
|
+
static parseContractUpdate(body) {
|
|
107
352
|
if (!body) return void 0;
|
|
108
353
|
const data = {};
|
|
109
|
-
if (body.
|
|
110
|
-
data.
|
|
111
|
-
body.
|
|
112
|
-
body.
|
|
113
|
-
body.
|
|
354
|
+
if (body.contractID) {
|
|
355
|
+
data.contractIdToUpdate = new ContractId(
|
|
356
|
+
body.contractID.shardNum ?? 0,
|
|
357
|
+
body.contractID.realmNum ?? 0,
|
|
358
|
+
body.contractID.contractNum ?? 0
|
|
114
359
|
).toString();
|
|
115
360
|
}
|
|
116
|
-
if (body.
|
|
117
|
-
data.
|
|
361
|
+
if (body.adminKey) {
|
|
362
|
+
data.adminKey = parseKey(body.adminKey);
|
|
118
363
|
}
|
|
119
364
|
if (body.expirationTime?.seconds) {
|
|
120
365
|
data.expirationTime = `${Long.fromValue(
|
|
121
366
|
body.expirationTime.seconds
|
|
122
367
|
).toString()}.${body.expirationTime.nanos}`;
|
|
123
368
|
}
|
|
124
|
-
if (body.receiverSigRequired !== null && body.receiverSigRequired !== void 0) {
|
|
125
|
-
data.receiverSigRequired = Boolean(body.receiverSigRequired);
|
|
126
|
-
}
|
|
127
369
|
if (body.autoRenewPeriod?.seconds) {
|
|
128
370
|
data.autoRenewPeriod = Long.fromValue(
|
|
129
371
|
body.autoRenewPeriod.seconds
|
|
130
372
|
).toString();
|
|
131
373
|
}
|
|
132
|
-
if (body.memo
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
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;
|
|
137
390
|
}
|
|
138
391
|
if (body.stakedAccountId) {
|
|
139
392
|
data.stakedAccountId = new AccountId(
|
|
@@ -142,208 +395,62 @@ class CryptoParser {
|
|
|
142
395
|
body.stakedAccountId.accountNum ?? 0
|
|
143
396
|
).toString();
|
|
144
397
|
data.stakedNodeId = void 0;
|
|
145
|
-
} else if (body.stakedNodeId !== null && body.stakedNodeId !== void 0) {
|
|
398
|
+
} else if (body.stakedNodeId !== null && body.stakedNodeId !== void 0 && Long.fromValue(body.stakedNodeId).notEquals(-1)) {
|
|
146
399
|
data.stakedNodeId = Long.fromValue(body.stakedNodeId).toString();
|
|
147
400
|
data.stakedAccountId = void 0;
|
|
148
401
|
} else {
|
|
149
|
-
data.stakedAccountId = void 0;
|
|
150
402
|
data.stakedNodeId = void 0;
|
|
403
|
+
data.stakedAccountId = void 0;
|
|
151
404
|
}
|
|
152
|
-
if (body.declineReward !==
|
|
153
|
-
data.declineReward =
|
|
405
|
+
if (body.declineReward?.value !== void 0) {
|
|
406
|
+
data.declineReward = body.declineReward.value;
|
|
154
407
|
}
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
static parseCryptoApproveAllowance(body) {
|
|
158
|
-
if (!body) return void 0;
|
|
159
|
-
const data = {};
|
|
160
|
-
if (body.cryptoAllowances && body.cryptoAllowances.length > 0) {
|
|
161
|
-
data.hbarAllowances = body.cryptoAllowances.map((a) => ({
|
|
162
|
-
ownerAccountId: new AccountId(
|
|
163
|
-
a.owner.shardNum ?? 0,
|
|
164
|
-
a.owner.realmNum ?? 0,
|
|
165
|
-
a.owner.accountNum ?? 0
|
|
166
|
-
).toString(),
|
|
167
|
-
spenderAccountId: new AccountId(
|
|
168
|
-
a.spender.shardNum ?? 0,
|
|
169
|
-
a.spender.realmNum ?? 0,
|
|
170
|
-
a.spender.accountNum ?? 0
|
|
171
|
-
).toString(),
|
|
172
|
-
amount: Hbar.fromTinybars(Long.fromValue(a.amount)).toString(
|
|
173
|
-
HbarUnit.Hbar
|
|
174
|
-
)
|
|
175
|
-
}));
|
|
176
|
-
}
|
|
177
|
-
if (body.tokenAllowances && body.tokenAllowances.length > 0) {
|
|
178
|
-
data.tokenAllowances = body.tokenAllowances.map((a) => ({
|
|
179
|
-
tokenId: new TokenId(
|
|
180
|
-
a.tokenId.shardNum ?? 0,
|
|
181
|
-
a.tokenId.realmNum ?? 0,
|
|
182
|
-
a.tokenId.tokenNum ?? 0
|
|
183
|
-
).toString(),
|
|
184
|
-
ownerAccountId: new AccountId(
|
|
185
|
-
a.owner.shardNum ?? 0,
|
|
186
|
-
a.owner.realmNum ?? 0,
|
|
187
|
-
a.owner.accountNum ?? 0
|
|
188
|
-
).toString(),
|
|
189
|
-
spenderAccountId: new AccountId(
|
|
190
|
-
a.spender.shardNum ?? 0,
|
|
191
|
-
a.spender.realmNum ?? 0,
|
|
192
|
-
a.spender.accountNum ?? 0
|
|
193
|
-
).toString(),
|
|
194
|
-
amount: Long.fromValue(a.amount).toString()
|
|
195
|
-
}));
|
|
408
|
+
if (body.maxAutomaticTokenAssociations?.value !== void 0) {
|
|
409
|
+
data.maxAutomaticTokenAssociations = body.maxAutomaticTokenAssociations.value;
|
|
196
410
|
}
|
|
197
|
-
if (body.
|
|
198
|
-
data.
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
a.tokenId.realmNum ?? 0,
|
|
204
|
-
a.tokenId.tokenNum ?? 0
|
|
205
|
-
).toString();
|
|
206
|
-
if (a.owner)
|
|
207
|
-
allowance.ownerAccountId = new AccountId(
|
|
208
|
-
a.owner.shardNum ?? 0,
|
|
209
|
-
a.owner.realmNum ?? 0,
|
|
210
|
-
a.owner.accountNum ?? 0
|
|
211
|
-
).toString();
|
|
212
|
-
if (a.spender)
|
|
213
|
-
allowance.spenderAccountId = new AccountId(
|
|
214
|
-
a.spender.shardNum ?? 0,
|
|
215
|
-
a.spender.realmNum ?? 0,
|
|
216
|
-
a.spender.accountNum ?? 0
|
|
217
|
-
).toString();
|
|
218
|
-
if (a.serialNumbers && a.serialNumbers.length > 0)
|
|
219
|
-
allowance.serialNumbers = a.serialNumbers.map(
|
|
220
|
-
(sn) => Long.fromValue(sn).toString()
|
|
221
|
-
);
|
|
222
|
-
if (a.approvedForAll?.value !== void 0)
|
|
223
|
-
allowance.approvedForAll = a.approvedForAll.value;
|
|
224
|
-
if (a.delegatingSpender)
|
|
225
|
-
allowance.delegatingSpender = new AccountId(
|
|
226
|
-
a.delegatingSpender.shardNum ?? 0,
|
|
227
|
-
a.delegatingSpender.realmNum ?? 0,
|
|
228
|
-
a.delegatingSpender.accountNum ?? 0
|
|
229
|
-
).toString();
|
|
230
|
-
return allowance;
|
|
231
|
-
});
|
|
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();
|
|
232
417
|
}
|
|
233
418
|
return data;
|
|
234
419
|
}
|
|
235
|
-
static
|
|
420
|
+
static parseContractDelete(body) {
|
|
236
421
|
if (!body) return void 0;
|
|
237
422
|
const data = {};
|
|
238
|
-
if (body.
|
|
239
|
-
data.
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
).toString(),
|
|
245
|
-
tokenId: new TokenId(
|
|
246
|
-
a.tokenId.shardNum ?? 0,
|
|
247
|
-
a.tokenId.realmNum ?? 0,
|
|
248
|
-
a.tokenId.tokenNum ?? 0
|
|
249
|
-
).toString(),
|
|
250
|
-
serialNumbers: a.serialNumbers ? a.serialNumbers.map((sn) => Long.fromValue(sn).toString()) : []
|
|
251
|
-
}));
|
|
252
|
-
}
|
|
253
|
-
return data;
|
|
254
|
-
}
|
|
255
|
-
/**
|
|
256
|
-
* Extract HBAR transfers from Transaction object
|
|
257
|
-
*/
|
|
258
|
-
static extractHbarTransfersFromTransaction(transaction) {
|
|
259
|
-
const transfers = [];
|
|
260
|
-
try {
|
|
261
|
-
const hbarTransfers = transaction._hbarTransfers;
|
|
262
|
-
if (Array.isArray(hbarTransfers)) {
|
|
263
|
-
hbarTransfers.forEach((transfer) => {
|
|
264
|
-
if (transfer.accountId && transfer.amount) {
|
|
265
|
-
const amountInTinybars = transfer.amount.toTinybars();
|
|
266
|
-
const amountInHbar = Number(amountInTinybars) / 1e8;
|
|
267
|
-
transfers.push({
|
|
268
|
-
accountId: transfer.accountId.toString(),
|
|
269
|
-
amount: amountInHbar
|
|
270
|
-
});
|
|
271
|
-
}
|
|
272
|
-
});
|
|
273
|
-
}
|
|
274
|
-
} catch (error) {
|
|
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();
|
|
275
429
|
}
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
const transfers = tokenTransfer.transfers.map((transfer) => ({
|
|
289
|
-
accountId: transfer.accountId?.toString() || "Unknown",
|
|
290
|
-
amount: Number(transfer.amount || 0)
|
|
291
|
-
}));
|
|
292
|
-
tokenTransfers.push({
|
|
293
|
-
tokenId: tokenTransfer.tokenId.toString(),
|
|
294
|
-
transfers
|
|
295
|
-
});
|
|
296
|
-
}
|
|
297
|
-
});
|
|
298
|
-
}
|
|
299
|
-
} catch (error) {
|
|
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();
|
|
300
442
|
}
|
|
301
|
-
return
|
|
443
|
+
return data;
|
|
302
444
|
}
|
|
303
445
|
/**
|
|
304
|
-
* Parse
|
|
305
|
-
* This is the unified entry point that
|
|
446
|
+
* Parse SCS (Smart Contract Service) transaction from Transaction object
|
|
447
|
+
* This is the unified entry point that delegates to the comprehensive parsing logic
|
|
306
448
|
*/
|
|
307
449
|
static parseFromTransactionObject(transaction) {
|
|
308
|
-
|
|
309
|
-
const hbarTransfers = this.extractHbarTransfersFromTransaction(transaction);
|
|
310
|
-
const tokenTransfers = this.extractTokenTransfersFromTransaction(transaction);
|
|
311
|
-
if (hbarTransfers.length > 0 || tokenTransfers.length > 0) {
|
|
312
|
-
const convertedTransfers = hbarTransfers.map((transfer) => ({
|
|
313
|
-
accountId: transfer.accountId,
|
|
314
|
-
amount: transfer.amount.toString() + " ℏ",
|
|
315
|
-
isDecimal: true
|
|
316
|
-
}));
|
|
317
|
-
const convertedTokenTransfers = tokenTransfers.flatMap(
|
|
318
|
-
(tokenGroup) => tokenGroup.transfers.map((transfer) => ({
|
|
319
|
-
tokenId: tokenGroup.tokenId,
|
|
320
|
-
accountId: transfer.accountId,
|
|
321
|
-
amount: transfer.amount
|
|
322
|
-
}))
|
|
323
|
-
);
|
|
324
|
-
if (hbarTransfers.length > 0) {
|
|
325
|
-
return {
|
|
326
|
-
type: "CRYPTOTRANSFER",
|
|
327
|
-
humanReadableType: "Crypto Transfer",
|
|
328
|
-
transfers: convertedTransfers,
|
|
329
|
-
tokenTransfers: convertedTokenTransfers
|
|
330
|
-
};
|
|
331
|
-
} else if (tokenTransfers.length > 0) {
|
|
332
|
-
return {
|
|
333
|
-
type: "TOKENTRANSFER",
|
|
334
|
-
humanReadableType: "Token Transfer",
|
|
335
|
-
transfers: convertedTransfers,
|
|
336
|
-
tokenTransfers: convertedTokenTransfers
|
|
337
|
-
};
|
|
338
|
-
}
|
|
339
|
-
}
|
|
340
|
-
return {};
|
|
341
|
-
} catch (error) {
|
|
342
|
-
return {};
|
|
343
|
-
}
|
|
450
|
+
return this.parseSCSTransaction(transaction);
|
|
344
451
|
}
|
|
345
452
|
}
|
|
346
453
|
export {
|
|
347
|
-
|
|
454
|
+
SCSParser
|
|
348
455
|
};
|
|
349
456
|
//# sourceMappingURL=standards-sdk.es153.js.map
|