@haneullabs/haneul 2.4.0 → 2.5.0
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/bcs/bcs.mjs +1 -1
- package/dist/bcs/bcs.mjs.map +1 -1
- package/dist/bcs/index.d.mts +4 -4
- package/dist/client/core-resolver.mjs +2 -2
- package/dist/client/core-resolver.mjs.map +1 -1
- package/dist/client/core.mjs +1 -1
- package/dist/client/core.mjs.map +1 -1
- package/dist/cryptography/keypair.d.mts +1 -1
- package/dist/cryptography/keypair.mjs +3 -3
- package/dist/cryptography/keypair.mjs.map +1 -1
- package/dist/cryptography/publickey.d.mts +1 -1
- package/dist/cryptography/publickey.mjs +2 -2
- package/dist/cryptography/publickey.mjs.map +1 -1
- package/dist/cryptography/signature.d.mts +6 -6
- package/dist/grpc/proto/haneul/rpc/v2/ledger_service.client.d.mts +4 -4
- package/dist/grpc/proto/haneul/rpc/v2/move_package_service.client.d.mts +4 -4
- package/dist/grpc/proto/haneul/rpc/v2/state_service.client.d.mts +4 -4
- package/dist/grpc/proto/haneul/rpc/v2/subscription_service.client.d.mts +4 -4
- package/dist/grpc/proto/haneul/rpc/v2/system_state.d.mts +2 -2
- package/dist/grpc/proto/haneul/rpc/v2/system_state.mjs +1 -1
- package/dist/grpc/proto/haneul/rpc/v2/system_state.mjs.map +1 -1
- package/dist/grpc/proto/haneul/rpc/v2/transaction_execution_service.client.d.mts +4 -4
- package/dist/jsonRpc/client.d.mts +5 -5
- package/dist/jsonRpc/client.d.mts.map +1 -1
- package/dist/jsonRpc/client.mjs +56 -56
- package/dist/jsonRpc/client.mjs.map +1 -1
- package/dist/jsonRpc/core.mjs +6 -6
- package/dist/jsonRpc/core.mjs.map +1 -1
- package/dist/jsonRpc/index.d.mts +4 -4
- package/dist/jsonRpc/index.mjs +2 -2
- package/dist/jsonRpc/types/generated.d.mts +14 -14
- package/dist/jsonRpc/types/generated.d.mts.map +1 -1
- package/dist/jsonRpc/types/index.d.mts +2 -2
- package/dist/jsonRpc/types/params.d.mts +8 -8
- package/dist/jsonRpc/types/params.d.mts.map +1 -1
- package/dist/multisig/publickey.d.mts +1 -1
- package/dist/multisig/publickey.mjs +1 -1
- package/dist/multisig/publickey.mjs.map +1 -1
- package/dist/multisig/signer.mjs +2 -2
- package/dist/multisig/signer.mjs.map +1 -1
- package/dist/transactions/Commands.mjs +3 -3
- package/dist/transactions/Commands.mjs.map +1 -1
- package/dist/transactions/executor/caching.mjs +1 -1
- package/dist/transactions/executor/caching.mjs.map +1 -1
- package/dist/transactions/executor/parallel.mjs +3 -3
- package/dist/transactions/executor/parallel.mjs.map +1 -1
- package/dist/transactions/executor/serial.mjs +1 -1
- package/dist/transactions/executor/serial.mjs.map +1 -1
- package/dist/utils/haneul-types.d.mts +2 -2
- package/dist/utils/haneul-types.d.mts.map +1 -1
- package/dist/utils/haneul-types.mjs +2 -2
- package/dist/utils/haneul-types.mjs.map +1 -1
- package/dist/utils/index.d.mts +2 -2
- package/dist/utils/index.mjs +2 -2
- package/dist/verify/verify.mjs +1 -1
- package/dist/verify/verify.mjs.map +1 -1
- package/dist/zklogin/publickey.d.mts +1 -1
- package/dist/zklogin/publickey.d.mts.map +1 -1
- package/dist/zklogin/publickey.mjs +9 -9
- package/dist/zklogin/publickey.mjs.map +1 -1
- package/package.json +199 -199
- package/src/bcs/bcs.ts +1 -1
- package/src/client/core-resolver.ts +2 -2
- package/src/client/core.ts +1 -1
- package/src/cryptography/keypair.ts +3 -3
- package/src/cryptography/publickey.ts +2 -2
- package/src/grpc/proto/haneul/rpc/v2/system_state.ts +3 -3
- package/src/jsonRpc/client.ts +57 -57
- package/src/jsonRpc/core.ts +7 -7
- package/src/jsonRpc/index.ts +1 -1
- package/src/jsonRpc/types/generated.ts +13 -13
- package/src/jsonRpc/types/params.ts +7 -7
- package/src/multisig/publickey.ts +1 -1
- package/src/multisig/signer.ts +2 -2
- package/src/transactions/Commands.ts +3 -3
- package/src/transactions/executor/caching.ts +1 -1
- package/src/transactions/executor/parallel.ts +3 -3
- package/src/transactions/executor/serial.ts +1 -1
- package/src/utils/haneul-types.ts +1 -1
- package/src/utils/index.ts +1 -1
- package/src/verify/verify.ts +1 -1
- package/src/zklogin/publickey.ts +9 -9
package/src/client/core.ts
CHANGED
|
@@ -253,7 +253,7 @@ export abstract class CoreClient extends BaseClient implements HaneulClientTypes
|
|
|
253
253
|
if (transaction instanceof Uint8Array) {
|
|
254
254
|
transactionBytes = transaction;
|
|
255
255
|
} else {
|
|
256
|
-
transaction.setSenderIfNotSet(signer.
|
|
256
|
+
transaction.setSenderIfNotSet(signer.toHaneulAddress());
|
|
257
257
|
transactionBytes = await transaction.build({ client: this });
|
|
258
258
|
}
|
|
259
259
|
|
|
@@ -84,7 +84,7 @@ export abstract class Signer {
|
|
|
84
84
|
}: SignAndExecuteOptions): Promise<
|
|
85
85
|
HaneulClientTypes.TransactionResult<{ transaction: true; effects: true }>
|
|
86
86
|
> {
|
|
87
|
-
transaction.setSenderIfNotSet(this.
|
|
87
|
+
transaction.setSenderIfNotSet(this.toHaneulAddress());
|
|
88
88
|
const bytes = await transaction.build({ client });
|
|
89
89
|
const { signature } = await this.signTransaction(bytes);
|
|
90
90
|
|
|
@@ -95,8 +95,8 @@ export abstract class Signer {
|
|
|
95
95
|
});
|
|
96
96
|
}
|
|
97
97
|
|
|
98
|
-
|
|
99
|
-
return this.getPublicKey().
|
|
98
|
+
toHaneulAddress(): string {
|
|
99
|
+
return this.getPublicKey().toHaneulAddress();
|
|
100
100
|
}
|
|
101
101
|
|
|
102
102
|
/**
|
|
@@ -98,7 +98,7 @@ export abstract class PublicKey {
|
|
|
98
98
|
* Verifies that the public key is associated with the provided address
|
|
99
99
|
*/
|
|
100
100
|
verifyAddress(address: string): boolean {
|
|
101
|
-
return this.
|
|
101
|
+
return this.toHaneulAddress() === address;
|
|
102
102
|
}
|
|
103
103
|
|
|
104
104
|
/**
|
|
@@ -117,7 +117,7 @@ export abstract class PublicKey {
|
|
|
117
117
|
/**
|
|
118
118
|
* Return the Haneul address associated with this Ed25519 public key
|
|
119
119
|
*/
|
|
120
|
-
|
|
120
|
+
toHaneulAddress(): string {
|
|
121
121
|
// Each hex char represents half a byte, hence hex address doubles the length
|
|
122
122
|
return normalizeHaneulAddress(
|
|
123
123
|
bytesToHex(blake2b(this.toSuiBytes(), { dkLen: 32 })).slice(0, HANEUL_ADDRESS_LENGTH * 2),
|
|
@@ -575,7 +575,7 @@ export interface StakingPool {
|
|
|
575
575
|
deactivationEpoch?: bigint;
|
|
576
576
|
/**
|
|
577
577
|
* The total number of HANEUL tokens in this pool, including the HANEUL in the rewards_pool, as well as in all the principal
|
|
578
|
-
* in the `
|
|
578
|
+
* in the `StakedHaneul` object, updated at epoch boundaries.
|
|
579
579
|
*
|
|
580
580
|
* @generated from protobuf field: optional uint64 sui_balance = 4;
|
|
581
581
|
*/
|
|
@@ -615,7 +615,7 @@ export interface StakingPool {
|
|
|
615
615
|
*
|
|
616
616
|
* @generated from protobuf field: optional uint64 pending_total_sui_withdraw = 9;
|
|
617
617
|
*/
|
|
618
|
-
|
|
618
|
+
pendingTotalHaneulWithdraw?: bigint;
|
|
619
619
|
/**
|
|
620
620
|
* Pending pool token withdrawn during the current epoch, emptied at epoch boundaries.
|
|
621
621
|
*
|
|
@@ -1127,7 +1127,7 @@ class StakingPool$Type extends MessageType<StakingPool> {
|
|
|
1127
1127
|
},
|
|
1128
1128
|
{
|
|
1129
1129
|
no: 4,
|
|
1130
|
-
name: '
|
|
1130
|
+
name: 'haneul_balance',
|
|
1131
1131
|
kind: 'scalar',
|
|
1132
1132
|
opt: true,
|
|
1133
1133
|
T: 4 /*ScalarType.UINT64*/,
|
package/src/jsonRpc/client.ts
CHANGED
|
@@ -12,7 +12,7 @@ import {
|
|
|
12
12
|
isValidHaneulObjectId,
|
|
13
13
|
isValidTransactionDigest,
|
|
14
14
|
normalizeHaneulAddress,
|
|
15
|
-
|
|
15
|
+
normalizeHaneulObjectId,
|
|
16
16
|
} from '../utils/haneul-types.js';
|
|
17
17
|
import { normalizeHaneulNSName } from '../utils/haneulns.js';
|
|
18
18
|
import { JsonRpcHTTPTransport } from './http-transport.js';
|
|
@@ -47,7 +47,7 @@ import type {
|
|
|
47
47
|
GetDynamicFieldObjectParams,
|
|
48
48
|
GetDynamicFieldsParams,
|
|
49
49
|
GetLatestCheckpointSequenceNumberParams,
|
|
50
|
-
|
|
50
|
+
GetLatestHaneulSystemStateParams,
|
|
51
51
|
GetMoveFunctionArgTypesParams,
|
|
52
52
|
GetNormalizedMoveFunctionParams,
|
|
53
53
|
GetNormalizedMoveModuleParams,
|
|
@@ -147,7 +147,7 @@ function isCoinReservationDigest(digestBase58: string): boolean {
|
|
|
147
147
|
return last20Bytes.every((byte, i) => byte === COIN_RESERVATION_MAGIC[i]);
|
|
148
148
|
}
|
|
149
149
|
|
|
150
|
-
export function
|
|
150
|
+
export function isHaneulJsonRpcClient(client: unknown): client is HaneulJsonRpcClient {
|
|
151
151
|
return (
|
|
152
152
|
typeof client === 'object' && client !== null && (client as any)[SUI_CLIENT_BRAND] === true
|
|
153
153
|
);
|
|
@@ -209,7 +209,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
209
209
|
}
|
|
210
210
|
|
|
211
211
|
const result: PaginatedCoins = await this.transport.request({
|
|
212
|
-
method: '
|
|
212
|
+
method: 'haneulx_getCoins',
|
|
213
213
|
params: [owner, coinType, cursor, limit],
|
|
214
214
|
signal: signal,
|
|
215
215
|
});
|
|
@@ -229,7 +229,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
229
229
|
}
|
|
230
230
|
|
|
231
231
|
const result: PaginatedCoins = await this.transport.request({
|
|
232
|
-
method: '
|
|
232
|
+
method: 'haneulx_getAllCoins',
|
|
233
233
|
params: [input.owner, input.cursor, input.limit],
|
|
234
234
|
signal: input.signal,
|
|
235
235
|
});
|
|
@@ -257,7 +257,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
257
257
|
}
|
|
258
258
|
|
|
259
259
|
return await this.transport.request({
|
|
260
|
-
method: '
|
|
260
|
+
method: 'haneulx_getBalance',
|
|
261
261
|
params: [owner, coinType],
|
|
262
262
|
signal: signal,
|
|
263
263
|
});
|
|
@@ -271,7 +271,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
271
271
|
throw new Error('Invalid Haneul address');
|
|
272
272
|
}
|
|
273
273
|
return await this.transport.request({
|
|
274
|
-
method: '
|
|
274
|
+
method: 'haneulx_getAllBalances',
|
|
275
275
|
params: [input.owner],
|
|
276
276
|
signal: input.signal,
|
|
277
277
|
});
|
|
@@ -290,7 +290,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
290
290
|
}
|
|
291
291
|
|
|
292
292
|
return await this.transport.request({
|
|
293
|
-
method: '
|
|
293
|
+
method: 'haneulx_getCoinMetadata',
|
|
294
294
|
params: [coinType],
|
|
295
295
|
signal: signal,
|
|
296
296
|
});
|
|
@@ -309,7 +309,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
309
309
|
}
|
|
310
310
|
|
|
311
311
|
return await this.transport.request({
|
|
312
|
-
method: '
|
|
312
|
+
method: 'haneulx_getTotalSupply',
|
|
313
313
|
params: [coinType],
|
|
314
314
|
signal: signal,
|
|
315
315
|
});
|
|
@@ -346,7 +346,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
346
346
|
}
|
|
347
347
|
|
|
348
348
|
return await this.transport.request({
|
|
349
|
-
method: '
|
|
349
|
+
method: 'haneul_getMoveFunctionArgTypes',
|
|
350
350
|
params: [pkg, module, fn],
|
|
351
351
|
signal: signal,
|
|
352
352
|
});
|
|
@@ -369,7 +369,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
369
369
|
}
|
|
370
370
|
|
|
371
371
|
return await this.transport.request({
|
|
372
|
-
method: '
|
|
372
|
+
method: 'haneul_getNormalizedMoveModulesByPackage',
|
|
373
373
|
params: [pkg],
|
|
374
374
|
signal: signal,
|
|
375
375
|
});
|
|
@@ -392,7 +392,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
392
392
|
}
|
|
393
393
|
|
|
394
394
|
return await this.transport.request({
|
|
395
|
-
method: '
|
|
395
|
+
method: 'haneul_getNormalizedMoveModule',
|
|
396
396
|
params: [pkg, module],
|
|
397
397
|
signal: signal,
|
|
398
398
|
});
|
|
@@ -416,7 +416,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
416
416
|
}
|
|
417
417
|
|
|
418
418
|
return await this.transport.request({
|
|
419
|
-
method: '
|
|
419
|
+
method: 'haneul_getNormalizedMoveFunction',
|
|
420
420
|
params: [pkg, module, fn],
|
|
421
421
|
signal: signal,
|
|
422
422
|
});
|
|
@@ -440,7 +440,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
440
440
|
}
|
|
441
441
|
|
|
442
442
|
return await this.transport.request({
|
|
443
|
-
method: '
|
|
443
|
+
method: 'haneul_getNormalizedMoveStruct',
|
|
444
444
|
params: [pkg, module, struct],
|
|
445
445
|
signal: signal,
|
|
446
446
|
});
|
|
@@ -478,7 +478,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
478
478
|
}
|
|
479
479
|
|
|
480
480
|
return await this.transport.request({
|
|
481
|
-
method: '
|
|
481
|
+
method: 'haneulx_getOwnedObjects',
|
|
482
482
|
params: [
|
|
483
483
|
input.owner,
|
|
484
484
|
{
|
|
@@ -496,11 +496,11 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
496
496
|
* Get details about an object
|
|
497
497
|
*/
|
|
498
498
|
async getObject(input: GetObjectParams): Promise<HaneulObjectResponse> {
|
|
499
|
-
if (!input.id || !isValidHaneulObjectId(
|
|
499
|
+
if (!input.id || !isValidHaneulObjectId(normalizeHaneulObjectId(input.id))) {
|
|
500
500
|
throw new Error('Invalid Haneul Object id');
|
|
501
501
|
}
|
|
502
502
|
return await this.transport.request({
|
|
503
|
-
method: '
|
|
503
|
+
method: 'haneul_getObject',
|
|
504
504
|
params: [input.id, input.options],
|
|
505
505
|
signal: input.signal,
|
|
506
506
|
});
|
|
@@ -508,7 +508,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
508
508
|
|
|
509
509
|
async tryGetPastObject(input: TryGetPastObjectParams): Promise<ObjectRead> {
|
|
510
510
|
return await this.transport.request({
|
|
511
|
-
method: '
|
|
511
|
+
method: 'haneul_tryGetPastObject',
|
|
512
512
|
params: [input.id, input.version, input.options],
|
|
513
513
|
signal: input.signal,
|
|
514
514
|
});
|
|
@@ -519,7 +519,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
519
519
|
*/
|
|
520
520
|
async multiGetObjects(input: MultiGetObjectsParams): Promise<HaneulObjectResponse[]> {
|
|
521
521
|
input.ids.forEach((id) => {
|
|
522
|
-
if (!id || !isValidHaneulObjectId(
|
|
522
|
+
if (!id || !isValidHaneulObjectId(normalizeHaneulObjectId(id))) {
|
|
523
523
|
throw new Error(`Invalid Haneul Object id ${id}`);
|
|
524
524
|
}
|
|
525
525
|
});
|
|
@@ -529,7 +529,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
529
529
|
}
|
|
530
530
|
|
|
531
531
|
return await this.transport.request({
|
|
532
|
-
method: '
|
|
532
|
+
method: 'haneul_multiGetObjects',
|
|
533
533
|
params: [input.ids, input.options],
|
|
534
534
|
signal: input.signal,
|
|
535
535
|
});
|
|
@@ -560,7 +560,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
560
560
|
}
|
|
561
561
|
|
|
562
562
|
return await this.transport.request({
|
|
563
|
-
method: '
|
|
563
|
+
method: 'haneulx_queryTransactionBlocks',
|
|
564
564
|
params: [
|
|
565
565
|
{
|
|
566
566
|
filter,
|
|
@@ -581,7 +581,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
581
581
|
throw new Error('Invalid Transaction digest');
|
|
582
582
|
}
|
|
583
583
|
return await this.transport.request({
|
|
584
|
-
method: '
|
|
584
|
+
method: 'haneul_getTransactionBlock',
|
|
585
585
|
params: [input.digest, input.options],
|
|
586
586
|
signal: input.signal,
|
|
587
587
|
});
|
|
@@ -602,7 +602,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
602
602
|
}
|
|
603
603
|
|
|
604
604
|
return await this.transport.request({
|
|
605
|
-
method: '
|
|
605
|
+
method: 'haneul_multiGetTransactionBlocks',
|
|
606
606
|
params: [input.digests, input.options],
|
|
607
607
|
signal: input.signal,
|
|
608
608
|
});
|
|
@@ -615,7 +615,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
615
615
|
signal,
|
|
616
616
|
}: ExecuteTransactionBlockParams): Promise<HaneulTransactionBlockResponse> {
|
|
617
617
|
const result: HaneulTransactionBlockResponse = await this.transport.request({
|
|
618
|
-
method: '
|
|
618
|
+
method: 'haneul_executeTransactionBlock',
|
|
619
619
|
params: [
|
|
620
620
|
typeof transactionBlock === 'string' ? transactionBlock : toBase64(transactionBlock),
|
|
621
621
|
Array.isArray(signature) ? signature : [signature],
|
|
@@ -643,7 +643,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
643
643
|
if (transaction instanceof Uint8Array) {
|
|
644
644
|
transactionBytes = transaction;
|
|
645
645
|
} else {
|
|
646
|
-
transaction.setSenderIfNotSet(signer.
|
|
646
|
+
transaction.setSenderIfNotSet(signer.toHaneulAddress());
|
|
647
647
|
transactionBytes = await transaction.build({ client: this });
|
|
648
648
|
}
|
|
649
649
|
|
|
@@ -662,7 +662,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
662
662
|
|
|
663
663
|
async getTotalTransactionBlocks({ signal }: { signal?: AbortSignal } = {}): Promise<bigint> {
|
|
664
664
|
const resp = await this.transport.request<string>({
|
|
665
|
-
method: '
|
|
665
|
+
method: 'haneul_getTotalTransactionBlocks',
|
|
666
666
|
params: [],
|
|
667
667
|
signal,
|
|
668
668
|
});
|
|
@@ -674,7 +674,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
674
674
|
*/
|
|
675
675
|
async getReferenceGasPrice({ signal }: GetReferenceGasPriceParams = {}): Promise<bigint> {
|
|
676
676
|
const resp = await this.transport.request<string>({
|
|
677
|
-
method: '
|
|
677
|
+
method: 'haneulx_getReferenceGasPrice',
|
|
678
678
|
params: [],
|
|
679
679
|
signal,
|
|
680
680
|
});
|
|
@@ -689,7 +689,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
689
689
|
throw new Error('Invalid Haneul address');
|
|
690
690
|
}
|
|
691
691
|
return await this.transport.request({
|
|
692
|
-
method: '
|
|
692
|
+
method: 'haneulx_getStakes',
|
|
693
693
|
params: [input.owner],
|
|
694
694
|
signal: input.signal,
|
|
695
695
|
});
|
|
@@ -699,14 +699,14 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
699
699
|
* Return the delegated stakes queried by id.
|
|
700
700
|
*/
|
|
701
701
|
async getStakesByIds(input: GetStakesByIdsParams): Promise<DelegatedStake[]> {
|
|
702
|
-
input.
|
|
703
|
-
if (!id || !isValidHaneulObjectId(
|
|
702
|
+
input.stakedHaneulIds.forEach((id) => {
|
|
703
|
+
if (!id || !isValidHaneulObjectId(normalizeHaneulObjectId(id))) {
|
|
704
704
|
throw new Error(`Invalid Haneul Stake id ${id}`);
|
|
705
705
|
}
|
|
706
706
|
});
|
|
707
707
|
return await this.transport.request({
|
|
708
|
-
method: '
|
|
709
|
-
params: [input.
|
|
708
|
+
method: 'haneulx_getStakesByIds',
|
|
709
|
+
params: [input.stakedHaneulIds],
|
|
710
710
|
signal: input.signal,
|
|
711
711
|
});
|
|
712
712
|
}
|
|
@@ -714,11 +714,11 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
714
714
|
/**
|
|
715
715
|
* Return the latest system state content.
|
|
716
716
|
*/
|
|
717
|
-
async
|
|
717
|
+
async getLatestHaneulSystemState({
|
|
718
718
|
signal,
|
|
719
|
-
}:
|
|
719
|
+
}: GetLatestHaneulSystemStateParams = {}): Promise<HaneulSystemStateSummary> {
|
|
720
720
|
return await this.transport.request({
|
|
721
|
-
method: '
|
|
721
|
+
method: 'haneulx_getLatestHaneulSystemState',
|
|
722
722
|
params: [],
|
|
723
723
|
signal,
|
|
724
724
|
});
|
|
@@ -774,7 +774,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
774
774
|
}
|
|
775
775
|
|
|
776
776
|
return await this.transport.request({
|
|
777
|
-
method: '
|
|
777
|
+
method: 'haneulx_queryEvents',
|
|
778
778
|
params: [query, cursor, limit, (order || 'descending') === 'descending'],
|
|
779
779
|
signal,
|
|
780
780
|
});
|
|
@@ -808,7 +808,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
808
808
|
input.signal?.throwIfAborted();
|
|
809
809
|
|
|
810
810
|
return await this.transport.request({
|
|
811
|
-
method: '
|
|
811
|
+
method: 'haneul_devInspectTransactionBlock',
|
|
812
812
|
params: [input.sender, devInspectTxBytes, input.gasPrice?.toString(), input.epoch],
|
|
813
813
|
signal: input.signal,
|
|
814
814
|
});
|
|
@@ -821,7 +821,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
821
821
|
input: DryRunTransactionBlockParams,
|
|
822
822
|
): Promise<DryRunTransactionBlockResponse> {
|
|
823
823
|
return await this.transport.request({
|
|
824
|
-
method: '
|
|
824
|
+
method: 'haneul_dryRunTransactionBlock',
|
|
825
825
|
params: [
|
|
826
826
|
typeof input.transactionBlock === 'string'
|
|
827
827
|
? input.transactionBlock
|
|
@@ -834,11 +834,11 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
834
834
|
* Return the list of dynamic field objects owned by an object
|
|
835
835
|
*/
|
|
836
836
|
async getDynamicFields(input: GetDynamicFieldsParams): Promise<DynamicFieldPage> {
|
|
837
|
-
if (!input.parentId || !isValidHaneulObjectId(
|
|
837
|
+
if (!input.parentId || !isValidHaneulObjectId(normalizeHaneulObjectId(input.parentId))) {
|
|
838
838
|
throw new Error('Invalid Haneul Object id');
|
|
839
839
|
}
|
|
840
840
|
return await this.transport.request({
|
|
841
|
-
method: '
|
|
841
|
+
method: 'haneulx_getDynamicFields',
|
|
842
842
|
params: [input.parentId, input.cursor, input.limit],
|
|
843
843
|
signal: input.signal,
|
|
844
844
|
});
|
|
@@ -849,7 +849,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
849
849
|
*/
|
|
850
850
|
async getDynamicFieldObject(input: GetDynamicFieldObjectParams): Promise<HaneulObjectResponse> {
|
|
851
851
|
return await this.transport.request({
|
|
852
|
-
method: '
|
|
852
|
+
method: 'haneulx_getDynamicFieldObject',
|
|
853
853
|
params: [input.parentId, input.name],
|
|
854
854
|
signal: input.signal,
|
|
855
855
|
});
|
|
@@ -862,7 +862,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
862
862
|
signal,
|
|
863
863
|
}: GetLatestCheckpointSequenceNumberParams = {}): Promise<string> {
|
|
864
864
|
const resp = await this.transport.request({
|
|
865
|
-
method: '
|
|
865
|
+
method: 'haneul_getLatestCheckpointSequenceNumber',
|
|
866
866
|
params: [],
|
|
867
867
|
signal,
|
|
868
868
|
});
|
|
@@ -874,7 +874,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
874
874
|
*/
|
|
875
875
|
async getCheckpoint(input: GetCheckpointParams): Promise<Checkpoint> {
|
|
876
876
|
return await this.transport.request({
|
|
877
|
-
method: '
|
|
877
|
+
method: 'haneul_getCheckpoint',
|
|
878
878
|
params: [input.id],
|
|
879
879
|
signal: input.signal,
|
|
880
880
|
});
|
|
@@ -887,7 +887,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
887
887
|
input: PaginationArguments<CheckpointPage['nextCursor']> & GetCheckpointsParams,
|
|
888
888
|
): Promise<CheckpointPage> {
|
|
889
889
|
return await this.transport.request({
|
|
890
|
-
method: '
|
|
890
|
+
method: 'haneul_getCheckpoints',
|
|
891
891
|
params: [input.cursor, input?.limit, input.descendingOrder],
|
|
892
892
|
signal: input.signal,
|
|
893
893
|
});
|
|
@@ -898,7 +898,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
898
898
|
*/
|
|
899
899
|
async getCommitteeInfo(input?: GetCommitteeInfoParams): Promise<CommitteeInfo> {
|
|
900
900
|
return await this.transport.request({
|
|
901
|
-
method: '
|
|
901
|
+
method: 'haneulx_getCommitteeInfo',
|
|
902
902
|
params: [input?.epoch],
|
|
903
903
|
signal: input?.signal,
|
|
904
904
|
});
|
|
@@ -906,7 +906,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
906
906
|
|
|
907
907
|
async getNetworkMetrics({ signal }: { signal?: AbortSignal } = {}): Promise<NetworkMetrics> {
|
|
908
908
|
return await this.transport.request({
|
|
909
|
-
method: '
|
|
909
|
+
method: 'haneulx_getNetworkMetrics',
|
|
910
910
|
params: [],
|
|
911
911
|
signal,
|
|
912
912
|
});
|
|
@@ -914,7 +914,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
914
914
|
|
|
915
915
|
async getAddressMetrics({ signal }: { signal?: AbortSignal } = {}): Promise<AddressMetrics> {
|
|
916
916
|
return await this.transport.request({
|
|
917
|
-
method: '
|
|
917
|
+
method: 'haneulx_getLatestAddressMetrics',
|
|
918
918
|
params: [],
|
|
919
919
|
signal,
|
|
920
920
|
});
|
|
@@ -927,7 +927,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
927
927
|
} & PaginationArguments<EpochMetricsPage['nextCursor']>,
|
|
928
928
|
): Promise<EpochMetricsPage> {
|
|
929
929
|
return await this.transport.request({
|
|
930
|
-
method: '
|
|
930
|
+
method: 'haneulx_getEpochMetrics',
|
|
931
931
|
params: [input?.cursor, input?.limit, input?.descendingOrder],
|
|
932
932
|
signal: input?.signal,
|
|
933
933
|
});
|
|
@@ -938,7 +938,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
938
938
|
signal?: AbortSignal;
|
|
939
939
|
}): Promise<AllEpochsAddressMetrics> {
|
|
940
940
|
return await this.transport.request({
|
|
941
|
-
method: '
|
|
941
|
+
method: 'haneulx_getAllEpochAddressMetrics',
|
|
942
942
|
params: [input?.descendingOrder],
|
|
943
943
|
signal: input?.signal,
|
|
944
944
|
});
|
|
@@ -954,7 +954,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
954
954
|
} & PaginationArguments<EpochPage['nextCursor']>,
|
|
955
955
|
): Promise<EpochPage> {
|
|
956
956
|
return await this.transport.request({
|
|
957
|
-
method: '
|
|
957
|
+
method: 'haneulx_getEpochs',
|
|
958
958
|
params: [input?.cursor, input?.limit, input?.descendingOrder],
|
|
959
959
|
signal: input?.signal,
|
|
960
960
|
});
|
|
@@ -965,7 +965,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
965
965
|
*/
|
|
966
966
|
async getMoveCallMetrics({ signal }: { signal?: AbortSignal } = {}): Promise<MoveCallMetrics> {
|
|
967
967
|
return await this.transport.request({
|
|
968
|
-
method: '
|
|
968
|
+
method: 'haneulx_getMoveCallMetrics',
|
|
969
969
|
params: [],
|
|
970
970
|
signal,
|
|
971
971
|
});
|
|
@@ -976,7 +976,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
976
976
|
*/
|
|
977
977
|
async getCurrentEpoch({ signal }: { signal?: AbortSignal } = {}): Promise<EpochInfo> {
|
|
978
978
|
return await this.transport.request({
|
|
979
|
-
method: '
|
|
979
|
+
method: 'haneulx_getCurrentEpoch',
|
|
980
980
|
params: [],
|
|
981
981
|
signal,
|
|
982
982
|
});
|
|
@@ -987,7 +987,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
987
987
|
*/
|
|
988
988
|
async getValidatorsApy({ signal }: { signal?: AbortSignal } = {}): Promise<ValidatorsApy> {
|
|
989
989
|
return await this.transport.request({
|
|
990
|
-
method: '
|
|
990
|
+
method: 'haneulx_getValidatorsApy',
|
|
991
991
|
params: [],
|
|
992
992
|
signal,
|
|
993
993
|
});
|
|
@@ -1002,7 +1002,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
1002
1002
|
|
|
1003
1003
|
async resolveNameServiceAddress(input: ResolveNameServiceAddressParams): Promise<string | null> {
|
|
1004
1004
|
return await this.transport.request({
|
|
1005
|
-
method: '
|
|
1005
|
+
method: 'haneulx_resolveNameServiceAddress',
|
|
1006
1006
|
params: [input.name],
|
|
1007
1007
|
signal: input.signal,
|
|
1008
1008
|
});
|
|
@@ -1016,7 +1016,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
1016
1016
|
}): Promise<ResolvedNameServiceNames> {
|
|
1017
1017
|
const { nextCursor, hasNextPage, data }: ResolvedNameServiceNames =
|
|
1018
1018
|
await this.transport.request({
|
|
1019
|
-
method: '
|
|
1019
|
+
method: 'haneulx_resolveNameServiceNames',
|
|
1020
1020
|
params: [input.address, input.cursor, input.limit],
|
|
1021
1021
|
signal: input.signal,
|
|
1022
1022
|
});
|
|
@@ -1030,7 +1030,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
1030
1030
|
|
|
1031
1031
|
async getProtocolConfig(input?: GetProtocolConfigParams): Promise<ProtocolConfig> {
|
|
1032
1032
|
return await this.transport.request({
|
|
1033
|
-
method: '
|
|
1033
|
+
method: 'haneul_getProtocolConfig',
|
|
1034
1034
|
params: [input?.version],
|
|
1035
1035
|
signal: input?.signal,
|
|
1036
1036
|
});
|
|
@@ -1038,7 +1038,7 @@ export class HaneulJsonRpcClient extends BaseClient {
|
|
|
1038
1038
|
|
|
1039
1039
|
async verifyZkLoginSignature(input: VerifyZkLoginSignatureParams): Promise<ZkLoginVerifyResult> {
|
|
1040
1040
|
return await this.transport.request({
|
|
1041
|
-
method: '
|
|
1041
|
+
method: 'haneul_verifyZkLoginSignature',
|
|
1042
1042
|
params: [input.bytes, input.signature, input.intentScope, input.author],
|
|
1043
1043
|
signal: input.signal,
|
|
1044
1044
|
});
|
package/src/jsonRpc/core.ts
CHANGED
|
@@ -456,7 +456,7 @@ export class JSONRpcCoreClient extends CoreClient {
|
|
|
456
456
|
async getCurrentSystemState(
|
|
457
457
|
options?: HaneulClientTypes.GetCurrentSystemStateOptions,
|
|
458
458
|
): Promise<HaneulClientTypes.GetCurrentSystemStateResponse> {
|
|
459
|
-
const systemState = await this.#jsonRpcClient.
|
|
459
|
+
const systemState = await this.#jsonRpcClient.getLatestHaneulSystemState({
|
|
460
460
|
signal: options?.signal,
|
|
461
461
|
});
|
|
462
462
|
|
|
@@ -604,21 +604,21 @@ function serializeObjectToBcs(object: HaneulObjectData): Uint8Array | undefined
|
|
|
604
604
|
let moveObjectType: InferBcsInput<typeof bcs.MoveObjectType>;
|
|
605
605
|
|
|
606
606
|
// Normalize constants for comparison
|
|
607
|
-
const
|
|
607
|
+
const normalizedHaneulFramework = normalizeHaneulAddress(HANEUL_FRAMEWORK_ADDRESS);
|
|
608
608
|
const gasCoinType = normalizeStructTag(
|
|
609
609
|
`${HANEUL_FRAMEWORK_ADDRESS}::coin::Coin<${HANEUL_FRAMEWORK_ADDRESS}::haneul::HANEUL>`,
|
|
610
610
|
);
|
|
611
|
-
const
|
|
612
|
-
const coinPrefix = `${
|
|
611
|
+
const stakedHaneulType = normalizeStructTag(`${HANEUL_SYSTEM_ADDRESS}::staking_pool::StakedHaneul`);
|
|
612
|
+
const coinPrefix = `${normalizedHaneulFramework}::coin::Coin<`;
|
|
613
613
|
|
|
614
614
|
if (typeStr === gasCoinType) {
|
|
615
615
|
moveObjectType = { GasCoin: null };
|
|
616
|
-
} else if (typeStr ===
|
|
617
|
-
moveObjectType = {
|
|
616
|
+
} else if (typeStr === stakedHaneulType) {
|
|
617
|
+
moveObjectType = { StakedHaneul: null };
|
|
618
618
|
} else if (typeStr.startsWith(coinPrefix)) {
|
|
619
619
|
const innerTypeMatch = typeStr.match(
|
|
620
620
|
new RegExp(
|
|
621
|
-
`${
|
|
621
|
+
`${normalizedHaneulFramework.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')}::coin::Coin<(.+)>$`,
|
|
622
622
|
),
|
|
623
623
|
);
|
|
624
624
|
if (innerTypeMatch) {
|
package/src/jsonRpc/index.ts
CHANGED
|
@@ -14,7 +14,7 @@ export {
|
|
|
14
14
|
type HaneulJsonRpcClientOptions,
|
|
15
15
|
type PaginationArguments,
|
|
16
16
|
type OrderArguments,
|
|
17
|
-
|
|
17
|
+
isHaneulJsonRpcClient,
|
|
18
18
|
HaneulJsonRpcClient,
|
|
19
19
|
} from './client.js';
|
|
20
20
|
export { HaneulHTTPStatusError, HaneulHTTPTransportError, JsonRpcError } from './errors.js';
|
|
@@ -873,29 +873,29 @@ export type RawData =
|
|
|
873
873
|
};
|
|
874
874
|
export type Signature =
|
|
875
875
|
| {
|
|
876
|
-
|
|
876
|
+
Ed25519HaneulSignature: string;
|
|
877
877
|
}
|
|
878
878
|
| {
|
|
879
|
-
|
|
879
|
+
Secp256k1HaneulSignature: string;
|
|
880
880
|
}
|
|
881
881
|
| {
|
|
882
|
-
|
|
882
|
+
Secp256r1HaneulSignature: string;
|
|
883
883
|
};
|
|
884
884
|
export type StakeObject =
|
|
885
885
|
| {
|
|
886
886
|
principal: string;
|
|
887
887
|
stakeActiveEpoch: string;
|
|
888
888
|
stakeRequestEpoch: string;
|
|
889
|
-
/** ID of the
|
|
890
|
-
|
|
889
|
+
/** ID of the StakedHaneul receipt object. */
|
|
890
|
+
stakedHaneulId: string;
|
|
891
891
|
status: 'Pending';
|
|
892
892
|
}
|
|
893
893
|
| {
|
|
894
894
|
principal: string;
|
|
895
895
|
stakeActiveEpoch: string;
|
|
896
896
|
stakeRequestEpoch: string;
|
|
897
|
-
/** ID of the
|
|
898
|
-
|
|
897
|
+
/** ID of the StakedHaneul receipt object. */
|
|
898
|
+
stakedHaneulId: string;
|
|
899
899
|
estimatedReward: string;
|
|
900
900
|
status: 'Active';
|
|
901
901
|
}
|
|
@@ -903,8 +903,8 @@ export type StakeObject =
|
|
|
903
903
|
principal: string;
|
|
904
904
|
stakeActiveEpoch: string;
|
|
905
905
|
stakeRequestEpoch: string;
|
|
906
|
-
/** ID of the
|
|
907
|
-
|
|
906
|
+
/** ID of the StakedHaneul receipt object. */
|
|
907
|
+
stakedHaneulId: string;
|
|
908
908
|
status: 'Unstaked';
|
|
909
909
|
};
|
|
910
910
|
export interface HaneulActiveJwk {
|
|
@@ -1157,7 +1157,7 @@ export interface HaneulObjectResponse {
|
|
|
1157
1157
|
* The transaction for calling a Move function, either an entry function or a public function (which
|
|
1158
1158
|
* cannot return references).
|
|
1159
1159
|
*/
|
|
1160
|
-
export interface
|
|
1160
|
+
export interface MoveCallHaneulTransaction {
|
|
1161
1161
|
/** The arguments to the function. */
|
|
1162
1162
|
arguments?: HaneulArgument[];
|
|
1163
1163
|
/** The function to be called. */
|
|
@@ -1289,7 +1289,7 @@ export interface HaneulSystemStateSummary {
|
|
|
1289
1289
|
export type HaneulTransaction =
|
|
1290
1290
|
/** A call to either an entry or a public Move function */
|
|
1291
1291
|
| {
|
|
1292
|
-
MoveCall:
|
|
1292
|
+
MoveCall: MoveCallHaneulTransaction;
|
|
1293
1293
|
} /**
|
|
1294
1294
|
* `(Vec<forall T:key+store. T>, address)` It sends n-objects to the specified address. These objects
|
|
1295
1295
|
* must have store (public transfer) and either the previous owner must be an address or the object
|
|
@@ -1357,7 +1357,7 @@ export interface HaneulValidatorSummary {
|
|
|
1357
1357
|
/** Pending stake amount for this epoch. */
|
|
1358
1358
|
pendingStake: string;
|
|
1359
1359
|
/** Pending stake withdrawn during the current epoch, emptied at epoch boundaries. */
|
|
1360
|
-
|
|
1360
|
+
pendingTotalHaneulWithdraw: string;
|
|
1361
1361
|
/** Total number of pool tokens issued by the pool. */
|
|
1362
1362
|
poolTokenBalance: string;
|
|
1363
1363
|
primaryAddress: string;
|
|
@@ -1373,7 +1373,7 @@ export interface HaneulValidatorSummary {
|
|
|
1373
1373
|
/** ID of the staking pool object. */
|
|
1374
1374
|
stakingPoolId: string;
|
|
1375
1375
|
/** The total number of HANEUL tokens in this pool. */
|
|
1376
|
-
|
|
1376
|
+
stakingPoolHaneulBalance: string;
|
|
1377
1377
|
suiAddress: string;
|
|
1378
1378
|
votingPower: string;
|
|
1379
1379
|
workerAddress: string;
|