@nktkas/hyperliquid 0.25.0-beta.3 → 0.25.0-beta.4
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/README.md +108 -116
- package/esm/bin/_utils.d.ts +80 -0
- package/esm/bin/_utils.d.ts.map +1 -0
- package/esm/bin/_utils.js +112 -0
- package/esm/bin/_utils.js.map +1 -0
- package/esm/bin/cli.js +43 -161
- package/esm/bin/cli.js.map +1 -1
- package/esm/src/clients/exchange.d.ts +93 -93
- package/esm/src/clients/exchange.d.ts.map +1 -1
- package/esm/src/clients/exchange.js +63 -58
- package/esm/src/clients/exchange.js.map +1 -1
- package/esm/src/clients/info.d.ts +113 -113
- package/esm/src/clients/info.d.ts.map +1 -1
- package/esm/src/clients/info.js +70 -73
- package/esm/src/clients/info.js.map +1 -1
- package/esm/src/clients/multiSign.d.ts +3 -3
- package/esm/src/clients/multiSign.d.ts.map +1 -1
- package/esm/src/clients/multiSign.js +4 -2
- package/esm/src/clients/multiSign.js.map +1 -1
- package/esm/src/clients/subscription.d.ts +23 -23
- package/esm/src/clients/subscription.d.ts.map +1 -1
- package/esm/src/clients/subscription.js +8 -11
- package/esm/src/clients/subscription.js.map +1 -1
- package/esm/src/schemas/_base.d.ts +6 -8
- package/esm/src/schemas/_base.d.ts.map +1 -1
- package/esm/src/schemas/_base.js +5 -28
- package/esm/src/schemas/_base.js.map +1 -1
- package/esm/src/schemas/exchange/requests.d.ts +1676 -1657
- package/esm/src/schemas/exchange/requests.d.ts.map +1 -1
- package/esm/src/schemas/exchange/requests.js +195 -199
- package/esm/src/schemas/exchange/requests.js.map +1 -1
- package/esm/src/schemas/exchange/responses.d.ts +10 -10
- package/esm/src/schemas/exchange/responses.js +3 -3
- package/esm/src/schemas/exchange/responses.js.map +1 -1
- package/esm/src/schemas/explorer/requests.d.ts +2 -2
- package/esm/src/schemas/explorer/requests.js +3 -3
- package/esm/src/schemas/explorer/requests.js.map +1 -1
- package/esm/src/schemas/explorer/responses.d.ts +16 -16
- package/esm/src/schemas/explorer/responses.js +3 -3
- package/esm/src/schemas/explorer/responses.js.map +1 -1
- package/esm/src/schemas/info/accounts.d.ts +298 -298
- package/esm/src/schemas/info/accounts.js +24 -24
- package/esm/src/schemas/info/accounts.js.map +1 -1
- package/esm/src/schemas/info/assets.d.ts +110 -110
- package/esm/src/schemas/info/assets.js +9 -9
- package/esm/src/schemas/info/assets.js.map +1 -1
- package/esm/src/schemas/info/markets.d.ts +25 -25
- package/esm/src/schemas/info/markets.js +3 -3
- package/esm/src/schemas/info/markets.js.map +1 -1
- package/esm/src/schemas/info/orders.d.ts +104 -104
- package/esm/src/schemas/info/orders.js +3 -3
- package/esm/src/schemas/info/orders.js.map +1 -1
- package/esm/src/schemas/info/requests.d.ts +32 -32
- package/esm/src/schemas/info/requests.js +55 -55
- package/esm/src/schemas/info/requests.js.map +1 -1
- package/esm/src/schemas/info/validators.d.ts +27 -27
- package/esm/src/schemas/info/validators.js +6 -6
- package/esm/src/schemas/info/validators.js.map +1 -1
- package/esm/src/schemas/info/vaults.d.ts +46 -46
- package/esm/src/schemas/info/vaults.js +10 -10
- package/esm/src/schemas/info/vaults.js.map +1 -1
- package/esm/src/schemas/subscriptions/requests.d.ts +4 -4
- package/esm/src/schemas/subscriptions/requests.js +17 -17
- package/esm/src/schemas/subscriptions/requests.js.map +1 -1
- package/esm/src/schemas/subscriptions/responses.d.ts +401 -401
- package/esm/src/schemas/subscriptions/responses.js +14 -14
- package/esm/src/schemas/subscriptions/responses.js.map +1 -1
- package/esm/src/signing/mod.js +4 -4
- package/esm/src/signing/mod.js.map +1 -1
- package/esm/src/signing/signTypedData/private_key.js +16 -16
- package/esm/src/signing/signTypedData/private_key.js.map +1 -1
- package/esm/src/transports/_polyfills.d.ts +12 -0
- package/esm/src/transports/_polyfills.d.ts.map +1 -0
- package/esm/src/transports/_polyfills.js +40 -0
- package/esm/src/transports/_polyfills.js.map +1 -0
- package/esm/src/transports/base.d.ts +6 -6
- package/esm/src/transports/base.d.ts.map +1 -1
- package/esm/src/transports/http/http_transport.d.ts +11 -4
- package/esm/src/transports/http/http_transport.d.ts.map +1 -1
- package/esm/src/transports/http/http_transport.js +17 -6
- package/esm/src/transports/http/http_transport.js.map +1 -1
- package/esm/src/transports/websocket/_hyperliquid_event_target.d.ts +8 -7
- package/esm/src/transports/websocket/_hyperliquid_event_target.d.ts.map +1 -1
- package/esm/src/transports/websocket/_hyperliquid_event_target.js +14 -33
- package/esm/src/transports/websocket/_hyperliquid_event_target.js.map +1 -1
- package/esm/src/transports/websocket/_reconnecting_websocket.d.ts +26 -29
- package/esm/src/transports/websocket/_reconnecting_websocket.d.ts.map +1 -1
- package/esm/src/transports/websocket/_reconnecting_websocket.js +82 -76
- package/esm/src/transports/websocket/_reconnecting_websocket.js.map +1 -1
- package/esm/src/transports/websocket/_websocket_async_request.d.ts +6 -0
- package/esm/src/transports/websocket/_websocket_async_request.d.ts.map +1 -1
- package/esm/src/transports/websocket/_websocket_async_request.js +49 -41
- package/esm/src/transports/websocket/_websocket_async_request.js.map +1 -1
- package/esm/src/transports/websocket/websocket_transport.d.ts +48 -70
- package/esm/src/transports/websocket/websocket_transport.d.ts.map +1 -1
- package/esm/src/transports/websocket/websocket_transport.js +90 -103
- package/esm/src/transports/websocket/websocket_transport.js.map +1 -1
- package/package.json +3 -7
- package/script/bin/_utils.d.ts +80 -0
- package/script/bin/_utils.d.ts.map +1 -0
- package/script/bin/_utils.js +116 -0
- package/script/bin/_utils.js.map +1 -0
- package/script/bin/cli.js +43 -164
- package/script/bin/cli.js.map +1 -1
- package/script/src/clients/exchange.d.ts +93 -93
- package/script/src/clients/exchange.d.ts.map +1 -1
- package/script/src/clients/exchange.js +62 -57
- package/script/src/clients/exchange.js.map +1 -1
- package/script/src/clients/info.d.ts +113 -113
- package/script/src/clients/info.d.ts.map +1 -1
- package/script/src/clients/info.js +70 -73
- package/script/src/clients/info.js.map +1 -1
- package/script/src/clients/multiSign.d.ts +3 -3
- package/script/src/clients/multiSign.d.ts.map +1 -1
- package/script/src/clients/multiSign.js +10 -8
- package/script/src/clients/multiSign.js.map +1 -1
- package/script/src/clients/subscription.d.ts +23 -23
- package/script/src/clients/subscription.d.ts.map +1 -1
- package/script/src/clients/subscription.js +8 -11
- package/script/src/clients/subscription.js.map +1 -1
- package/script/src/schemas/_base.d.ts +6 -8
- package/script/src/schemas/_base.d.ts.map +1 -1
- package/script/src/schemas/_base.js +6 -29
- package/script/src/schemas/_base.js.map +1 -1
- package/script/src/schemas/exchange/requests.d.ts +1676 -1657
- package/script/src/schemas/exchange/requests.d.ts.map +1 -1
- package/script/src/schemas/exchange/requests.js +194 -198
- package/script/src/schemas/exchange/requests.js.map +1 -1
- package/script/src/schemas/exchange/responses.d.ts +10 -10
- package/script/src/schemas/exchange/responses.js +2 -2
- package/script/src/schemas/exchange/responses.js.map +1 -1
- package/script/src/schemas/explorer/requests.d.ts +2 -2
- package/script/src/schemas/explorer/requests.js +2 -2
- package/script/src/schemas/explorer/requests.js.map +1 -1
- package/script/src/schemas/explorer/responses.d.ts +16 -16
- package/script/src/schemas/explorer/responses.js +2 -2
- package/script/src/schemas/explorer/responses.js.map +1 -1
- package/script/src/schemas/info/accounts.d.ts +298 -298
- package/script/src/schemas/info/accounts.js +23 -23
- package/script/src/schemas/info/accounts.js.map +1 -1
- package/script/src/schemas/info/assets.d.ts +110 -110
- package/script/src/schemas/info/assets.js +8 -8
- package/script/src/schemas/info/assets.js.map +1 -1
- package/script/src/schemas/info/markets.d.ts +25 -25
- package/script/src/schemas/info/markets.js +2 -2
- package/script/src/schemas/info/markets.js.map +1 -1
- package/script/src/schemas/info/orders.d.ts +104 -104
- package/script/src/schemas/info/orders.js +2 -2
- package/script/src/schemas/info/orders.js.map +1 -1
- package/script/src/schemas/info/requests.d.ts +32 -32
- package/script/src/schemas/info/requests.js +54 -54
- package/script/src/schemas/info/requests.js.map +1 -1
- package/script/src/schemas/info/validators.d.ts +27 -27
- package/script/src/schemas/info/validators.js +5 -5
- package/script/src/schemas/info/validators.js.map +1 -1
- package/script/src/schemas/info/vaults.d.ts +46 -46
- package/script/src/schemas/info/vaults.js +9 -9
- package/script/src/schemas/info/vaults.js.map +1 -1
- package/script/src/schemas/subscriptions/requests.d.ts +4 -4
- package/script/src/schemas/subscriptions/requests.js +16 -16
- package/script/src/schemas/subscriptions/requests.js.map +1 -1
- package/script/src/schemas/subscriptions/responses.d.ts +401 -401
- package/script/src/schemas/subscriptions/responses.js +13 -13
- package/script/src/schemas/subscriptions/responses.js.map +1 -1
- package/script/src/signing/mod.js +37 -4
- package/script/src/signing/mod.js.map +1 -1
- package/script/src/signing/signTypedData/private_key.js +49 -16
- package/script/src/signing/signTypedData/private_key.js.map +1 -1
- package/script/src/transports/_polyfills.d.ts +12 -0
- package/script/src/transports/_polyfills.d.ts.map +1 -0
- package/script/src/transports/_polyfills.js +43 -0
- package/script/src/transports/_polyfills.js.map +1 -0
- package/script/src/transports/base.d.ts +6 -6
- package/script/src/transports/base.d.ts.map +1 -1
- package/script/src/transports/http/http_transport.d.ts +11 -4
- package/script/src/transports/http/http_transport.d.ts.map +1 -1
- package/script/src/transports/http/http_transport.js +17 -6
- package/script/src/transports/http/http_transport.js.map +1 -1
- package/script/src/transports/websocket/_hyperliquid_event_target.d.ts +8 -7
- package/script/src/transports/websocket/_hyperliquid_event_target.d.ts.map +1 -1
- package/script/src/transports/websocket/_hyperliquid_event_target.js +47 -33
- package/script/src/transports/websocket/_hyperliquid_event_target.js.map +1 -1
- package/script/src/transports/websocket/_reconnecting_websocket.d.ts +26 -29
- package/script/src/transports/websocket/_reconnecting_websocket.d.ts.map +1 -1
- package/script/src/transports/websocket/_reconnecting_websocket.js +82 -76
- package/script/src/transports/websocket/_reconnecting_websocket.js.map +1 -1
- package/script/src/transports/websocket/_websocket_async_request.d.ts +6 -0
- package/script/src/transports/websocket/_websocket_async_request.d.ts.map +1 -1
- package/script/src/transports/websocket/_websocket_async_request.js +52 -43
- package/script/src/transports/websocket/_websocket_async_request.js.map +1 -1
- package/script/src/transports/websocket/websocket_transport.d.ts +48 -70
- package/script/src/transports/websocket/websocket_transport.d.ts.map +1 -1
- package/script/src/transports/websocket/websocket_transport.js +92 -105
- package/script/src/transports/websocket/websocket_transport.js.map +1 -1
- package/src/bin/_utils.ts +185 -0
- package/src/bin/cli.ts +49 -171
- package/src/src/clients/exchange.ts +160 -149
- package/src/src/clients/info.ts +128 -128
- package/src/src/clients/multiSign.ts +15 -13
- package/src/src/clients/subscription.ts +32 -32
- package/src/src/schemas/_base.ts +18 -40
- package/src/src/schemas/exchange/requests.ts +202 -199
- package/src/src/schemas/exchange/responses.ts +3 -3
- package/src/src/schemas/explorer/requests.ts +3 -3
- package/src/src/schemas/explorer/responses.ts +3 -3
- package/src/src/schemas/info/accounts.ts +24 -24
- package/src/src/schemas/info/assets.ts +9 -9
- package/src/src/schemas/info/markets.ts +3 -3
- package/src/src/schemas/info/orders.ts +3 -3
- package/src/src/schemas/info/requests.ts +55 -55
- package/src/src/schemas/info/validators.ts +6 -6
- package/src/src/schemas/info/vaults.ts +10 -10
- package/src/src/schemas/subscriptions/requests.ts +17 -17
- package/src/src/schemas/subscriptions/responses.ts +14 -14
- package/src/src/signing/mod.ts +4 -4
- package/src/src/signing/signTypedData/private_key.ts +17 -17
- package/src/src/transports/_polyfills.ts +41 -0
- package/src/src/transports/base.ts +6 -6
- package/src/src/transports/http/http_transport.ts +25 -14
- package/src/src/transports/websocket/_hyperliquid_event_target.ts +24 -51
- package/src/src/transports/websocket/_reconnecting_websocket.ts +107 -119
- package/src/src/transports/websocket/_websocket_async_request.ts +57 -59
- package/src/src/transports/websocket/websocket_transport.ts +126 -167
package/script/bin/cli.js
CHANGED
|
@@ -33,15 +33,11 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
return result;
|
|
34
34
|
};
|
|
35
35
|
})();
|
|
36
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
37
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
38
|
-
};
|
|
39
36
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
40
37
|
const hl = __importStar(require("../src/mod.js"));
|
|
41
38
|
const mod_js_1 = require("../src/schemas/mod.js");
|
|
42
39
|
const v = __importStar(require("valibot"));
|
|
43
|
-
const
|
|
44
|
-
const node_process_1 = __importDefault(require("node:process"));
|
|
40
|
+
const _utils_js_1 = require("./_utils.js");
|
|
45
41
|
// deno-lint-ignore no-explicit-any
|
|
46
42
|
function getClassMethods(classConstructor) {
|
|
47
43
|
return Object.getOwnPropertyNames(classConstructor.prototype)
|
|
@@ -60,87 +56,6 @@ function isClassMethod(classConstructor, method) {
|
|
|
60
56
|
}
|
|
61
57
|
function transformParams(method, params) {
|
|
62
58
|
switch (method) {
|
|
63
|
-
case "modify": {
|
|
64
|
-
v.assert(v.string(), params?.order);
|
|
65
|
-
return {
|
|
66
|
-
...params,
|
|
67
|
-
order: JSON.parse(params.order),
|
|
68
|
-
};
|
|
69
|
-
}
|
|
70
|
-
case "convertToMultiSigUser": {
|
|
71
|
-
v.assert(v.string(), params?.authorizedUsers);
|
|
72
|
-
return {
|
|
73
|
-
...params,
|
|
74
|
-
authorizedUsers: JSON.parse(params.authorizedUsers),
|
|
75
|
-
};
|
|
76
|
-
}
|
|
77
|
-
case "cSignerAction": {
|
|
78
|
-
return {
|
|
79
|
-
...params,
|
|
80
|
-
jailSelf: "jailSelf" in params ? null : undefined,
|
|
81
|
-
unjailSelf: "unjailSelf" in params ? null : undefined,
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
case "order": {
|
|
85
|
-
v.assert(v.string(), params?.orders);
|
|
86
|
-
return {
|
|
87
|
-
...params,
|
|
88
|
-
orders: JSON.parse(params.orders),
|
|
89
|
-
grouping: params.grouping ?? "na",
|
|
90
|
-
};
|
|
91
|
-
}
|
|
92
|
-
case "approveAgent": {
|
|
93
|
-
return {
|
|
94
|
-
...params,
|
|
95
|
-
agentName: params.agentName ?? null,
|
|
96
|
-
};
|
|
97
|
-
}
|
|
98
|
-
case "sendAsset": {
|
|
99
|
-
return {
|
|
100
|
-
...params,
|
|
101
|
-
fromSubAccount: params.fromSubAccount ?? "",
|
|
102
|
-
};
|
|
103
|
-
}
|
|
104
|
-
case "vaultModify": {
|
|
105
|
-
return {
|
|
106
|
-
...params,
|
|
107
|
-
allowDeposits: params.allowDeposits ?? null,
|
|
108
|
-
alwaysCloseOnWithdraw: params.alwaysCloseOnWithdraw ?? null,
|
|
109
|
-
};
|
|
110
|
-
}
|
|
111
|
-
case "setDisplayName": {
|
|
112
|
-
return {
|
|
113
|
-
...params,
|
|
114
|
-
displayName: params.displayName ?? "",
|
|
115
|
-
};
|
|
116
|
-
}
|
|
117
|
-
case "batchModify": {
|
|
118
|
-
v.assert(v.string(), params?.modifies);
|
|
119
|
-
return {
|
|
120
|
-
...params,
|
|
121
|
-
modifies: JSON.parse(params.modifies),
|
|
122
|
-
};
|
|
123
|
-
}
|
|
124
|
-
case "cancel": {
|
|
125
|
-
v.assert(v.string(), params?.cancels);
|
|
126
|
-
return {
|
|
127
|
-
...params,
|
|
128
|
-
cancels: JSON.parse(params.cancels),
|
|
129
|
-
};
|
|
130
|
-
}
|
|
131
|
-
case "cancelByCloid": {
|
|
132
|
-
v.assert(v.string(), params?.cancels);
|
|
133
|
-
return {
|
|
134
|
-
...params,
|
|
135
|
-
cancels: JSON.parse(params.cancels),
|
|
136
|
-
};
|
|
137
|
-
}
|
|
138
|
-
case "createVault": {
|
|
139
|
-
return {
|
|
140
|
-
...params,
|
|
141
|
-
nonce: Date.now(),
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
59
|
case "spotUser": {
|
|
145
60
|
return {
|
|
146
61
|
toggleSpotDusting: {
|
|
@@ -156,9 +71,7 @@ function transformParams(method, params) {
|
|
|
156
71
|
};
|
|
157
72
|
}
|
|
158
73
|
default: {
|
|
159
|
-
return
|
|
160
|
-
...params,
|
|
161
|
-
};
|
|
74
|
+
return params;
|
|
162
75
|
}
|
|
163
76
|
}
|
|
164
77
|
}
|
|
@@ -187,25 +100,25 @@ class EchoTransport {
|
|
|
187
100
|
class ExchangeClientWithoutValidation extends hl.ExchangeClient {
|
|
188
101
|
_validateResponse = () => true;
|
|
189
102
|
}
|
|
190
|
-
async function executeEndpointMethod(endpoint, method,
|
|
191
|
-
const isTestnet =
|
|
192
|
-
const timeout = Number(
|
|
193
|
-
const isOffline =
|
|
103
|
+
async function executeEndpointMethod(endpoint, method, args) {
|
|
104
|
+
const isTestnet = "testnet" in args;
|
|
105
|
+
const timeout = Number(args.timeout) || undefined;
|
|
106
|
+
const isOffline = "offline" in args;
|
|
194
107
|
const transport = isOffline ? new EchoTransport(isTestnet) : new hl.HttpTransport({ isTestnet, timeout });
|
|
195
108
|
let client;
|
|
196
109
|
if (endpoint === "info") {
|
|
197
110
|
if (!isClassMethod(hl.InfoClient, method)) {
|
|
198
|
-
throw new Error(`CLI does not support the "${method}" method in the "
|
|
111
|
+
throw new Error(`CLI does not support the "${method}" method in the "${endpoint}" endpoint`);
|
|
199
112
|
}
|
|
200
113
|
client = new hl.InfoClient({ transport });
|
|
201
114
|
}
|
|
202
115
|
else if (endpoint === "exchange") {
|
|
203
116
|
if (!isClassMethod(hl.ExchangeClient, method)) {
|
|
204
|
-
throw new Error(`CLI does not support the "${method}" method in the "
|
|
117
|
+
throw new Error(`CLI does not support the "${method}" method in the "${endpoint}" endpoint`);
|
|
205
118
|
}
|
|
206
|
-
const privateKey = v.parse(v.pipe(mod_js_1.Hex, v.minLength(66)),
|
|
207
|
-
delete
|
|
208
|
-
const vaultAddress = v.parse(v.optional(v.pipe(mod_js_1.Hex, v.minLength(42))),
|
|
119
|
+
const privateKey = v.parse(v.pipe(mod_js_1.Hex, v.minLength(66)), args["private-key"], { message: 'Invalid format "private-key": Expected 32-byte hexadecimal string' });
|
|
120
|
+
delete args["private-key"]; // just in case
|
|
121
|
+
const vaultAddress = v.parse(v.optional(v.pipe(mod_js_1.Hex, v.minLength(42))), args.vault, { message: 'Invalid format "vault": Expected 20-byte hexadecimal string OR nothing' });
|
|
209
122
|
client = isOffline
|
|
210
123
|
? new ExchangeClientWithoutValidation({
|
|
211
124
|
transport,
|
|
@@ -222,7 +135,7 @@ async function executeEndpointMethod(endpoint, method, cliArgs) {
|
|
|
222
135
|
throw new Error(`Invalid endpoint "${endpoint}". Use "info" or "exchange"`);
|
|
223
136
|
}
|
|
224
137
|
// @ts-ignore - dynamic method access
|
|
225
|
-
return await client[method](transformParams(method,
|
|
138
|
+
return await client[method](transformParams(method, args));
|
|
226
139
|
}
|
|
227
140
|
// ──────────────────── Main ────────────────────
|
|
228
141
|
function printHelp() {
|
|
@@ -296,12 +209,14 @@ User Account Data:
|
|
|
296
209
|
|
|
297
210
|
User Trading History:
|
|
298
211
|
userFills --user <address> [--aggregateByTime <bool>]
|
|
299
|
-
userFillsByTime --user <address> --startTime <number> [--endTime <number>]
|
|
212
|
+
userFillsByTime --user <address> --startTime <number> [--endTime <number>]
|
|
213
|
+
[--aggregateByTime <bool>]
|
|
300
214
|
userFunding --user <address> --startTime <number> [--endTime <number>]
|
|
301
215
|
userNonFundingLedgerUpdates --user <address> --startTime <number> [--endTime <number>]
|
|
302
216
|
twapHistory --user <address>
|
|
303
217
|
userTwapSliceFills --user <address>
|
|
304
|
-
userTwapSliceFillsByTime --user <address> --startTime <number> [--endTime <number>]
|
|
218
|
+
userTwapSliceFillsByTime --user <address> --startTime <number> [--endTime <number>]
|
|
219
|
+
[--aggregateByTime <bool>]
|
|
305
220
|
|
|
306
221
|
Sub-Account & Multi-Sig:
|
|
307
222
|
subAccounts --user <address>
|
|
@@ -342,7 +257,7 @@ Trading Operations:
|
|
|
342
257
|
scheduleCancel [--time <number>]
|
|
343
258
|
|
|
344
259
|
TWAP Operations:
|
|
345
|
-
twapOrder --a <number> --b <bool> --s <
|
|
260
|
+
twapOrder --a <number> --b <bool> --s <number> --r <bool> --m <number> --t <bool>
|
|
346
261
|
twapCancel --a <number> --t <number>
|
|
347
262
|
|
|
348
263
|
Position Management:
|
|
@@ -350,19 +265,19 @@ Position Management:
|
|
|
350
265
|
updateIsolatedMargin --asset <number> --isBuy <bool> --ntli <number>
|
|
351
266
|
|
|
352
267
|
Fund Transfers:
|
|
353
|
-
withdraw3 --destination <address> --amount <
|
|
354
|
-
usdSend --destination <address> --amount <
|
|
355
|
-
spotSend --destination <address> --token <name:address> --amount <
|
|
356
|
-
sendAsset --destination <address> --token <name:address> --amount <
|
|
268
|
+
withdraw3 --destination <address> --amount <number>
|
|
269
|
+
usdSend --destination <address> --amount <number>
|
|
270
|
+
spotSend --destination <address> --token <name:address> --amount <number>
|
|
271
|
+
sendAsset --destination <address> --token <name:address> --amount <number>
|
|
357
272
|
--sourceDex <string> --destinationDex <string> [--fromSubAccount <address>]
|
|
358
|
-
usdClassTransfer --amount <
|
|
273
|
+
usdClassTransfer --amount <number> --toPerp <bool>
|
|
359
274
|
|
|
360
275
|
Sub-Account Management:
|
|
361
276
|
createSubAccount --name <string>
|
|
362
277
|
subAccountModify --subAccountUser <address> --name <string>
|
|
363
278
|
subAccountTransfer --subAccountUser <address> --isDeposit <bool> --usd <number>
|
|
364
279
|
subAccountSpotTransfer --subAccountUser <address> --isDeposit <bool>
|
|
365
|
-
--token <name:address> --amount <
|
|
280
|
+
--token <name:address> --amount <number>
|
|
366
281
|
|
|
367
282
|
Vault Operations:
|
|
368
283
|
createVault --name <string> --description <string> --initialUsd <number>
|
|
@@ -376,7 +291,7 @@ Agent & Referrer:
|
|
|
376
291
|
approveBuilderFee --maxFeeRate <number> --builder <address>
|
|
377
292
|
registerReferrer --code <string>
|
|
378
293
|
setReferrer --code <string>
|
|
379
|
-
setDisplayName
|
|
294
|
+
setDisplayName --displayName <string>
|
|
380
295
|
|
|
381
296
|
Staking & Delegation:
|
|
382
297
|
tokenDelegate --validator <address> --wei <number> --isUndelegate <bool>
|
|
@@ -389,9 +304,15 @@ Spot & EVM Operations:
|
|
|
389
304
|
evmUserModify --usingBigBlocks <bool>
|
|
390
305
|
reserveRequestWeight --weight <number>
|
|
391
306
|
|
|
307
|
+
Deploy Market:
|
|
308
|
+
perpDeploy --registerAsset <json> | --setOracle <json>
|
|
309
|
+
spotDeploy --genesis <json> | --registerHyperliquidity <json> | --registerSpot <json> |
|
|
310
|
+
--registerToken2 <json> | --setDeployerTradingFeeShare <json> | --userGenesis <json>
|
|
311
|
+
|
|
392
312
|
Multi-Sig & Advanced:
|
|
393
313
|
convertToMultiSigUser --authorizedUsers <json> --threshold <number>
|
|
394
|
-
cSignerAction --jailSelf | --unjailSelf
|
|
314
|
+
cSignerAction --jailSelf null | --unjailSelf null
|
|
315
|
+
cValidatorAction --changeProfile <json> | --register <json> | --unregister null
|
|
395
316
|
noop (no params)
|
|
396
317
|
|
|
397
318
|
=============================================================================
|
|
@@ -410,10 +331,10 @@ Examples:
|
|
|
410
331
|
npx @nktkas/hyperliquid info candleSnapshot --coin BTC --interval 1h --startTime 1700000000000
|
|
411
332
|
|
|
412
333
|
# Place a limit order
|
|
413
|
-
npx @nktkas/hyperliquid exchange order --private-key 0x... --orders '[{\\"a\\":0,\\"b\\":true,\\"p\\"
|
|
334
|
+
npx @nktkas/hyperliquid exchange order --private-key 0x... --orders '[{\\"a\\":0,\\"b\\":true,\\"p\\":30000,\\"s\\":0.1,\\"r\\":false,\\"t\\":{\\"limit\\":{\\"tif\\":\\"Gtc\\"}}}]'
|
|
414
335
|
|
|
415
336
|
# Modify an existing order
|
|
416
|
-
npx @nktkas/hyperliquid exchange modify --private-key 0x... --oid 12345 --order '{\\"a\\":0,\\"b\\":true,\\"p\\"
|
|
337
|
+
npx @nktkas/hyperliquid exchange modify --private-key 0x... --oid 12345 --order '{\\"a\\":0,\\"b\\":true,\\"p\\":31000,\\"s\\":0.1,\\"r\\":false,\\"t\\":{\\"limit\\":{\\"tif\\":\\"Gtc\\"}}}'
|
|
417
338
|
|
|
418
339
|
# Cancel orders
|
|
419
340
|
npx @nktkas/hyperliquid exchange cancel --private-key 0x... --cancels '[{\\"a\\":0,\\"o\\":12345}]'
|
|
@@ -422,68 +343,26 @@ Examples:
|
|
|
422
343
|
npx @nktkas/hyperliquid exchange updateLeverage --private-key 0x... --asset 0 --isCross true --leverage 5
|
|
423
344
|
|
|
424
345
|
# Withdraw funds
|
|
425
|
-
npx @nktkas/hyperliquid exchange withdraw3 --private-key 0x... --destination 0x... --amount
|
|
346
|
+
npx @nktkas/hyperliquid exchange withdraw3 --private-key 0x... --destination 0x... --amount 100.5
|
|
426
347
|
|
|
427
348
|
# Send USD to another user
|
|
428
|
-
npx @nktkas/hyperliquid exchange usdSend --private-key 0x... --destination 0x... --amount
|
|
349
|
+
npx @nktkas/hyperliquid exchange usdSend --private-key 0x... --destination 0x... --amount 50
|
|
429
350
|
|
|
430
351
|
# Create a vault
|
|
431
352
|
npx @nktkas/hyperliquid exchange createVault --private-key 0x... --name "My Vault" --description "Test vault" --initialUsd 1000`);
|
|
432
353
|
}
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
// to avoid converting them to numbers
|
|
439
|
-
hex: (value) => /^0[xX][0-9a-fA-F]+$/.test(value),
|
|
440
|
-
// to avoid converting them to strings
|
|
441
|
-
bool: (value) => /^(true|false)$/i.test(value),
|
|
442
|
-
// to avoid losing precision in fractional numbers
|
|
443
|
-
number: (value) => /^-?\d+(\.\d+)?([eE][+-]?\d+)?$/.test(value),
|
|
444
|
-
// to avoid converting them to booleans
|
|
445
|
-
empty: (value) => value === "",
|
|
446
|
-
};
|
|
447
|
-
const foundKeys = [];
|
|
448
|
-
for (let i = 0; i < node_process_1.default.argv.length; i++) {
|
|
449
|
-
const arg = node_process_1.default.argv[i];
|
|
450
|
-
// Processing format --key=value
|
|
451
|
-
if (arg.startsWith("--") && arg.includes("=")) {
|
|
452
|
-
const eqIndex = arg.indexOf("=");
|
|
453
|
-
const key = arg.slice(2, eqIndex);
|
|
454
|
-
const value = arg.slice(eqIndex + 1);
|
|
455
|
-
// Check value for all requested types
|
|
456
|
-
for (const type of typeArray) {
|
|
457
|
-
if (validators[type] && validators[type](value)) {
|
|
458
|
-
foundKeys.push(key);
|
|
459
|
-
break; // Don't add duplicates
|
|
460
|
-
}
|
|
461
|
-
}
|
|
462
|
-
} // Processing format --key value
|
|
463
|
-
else if (arg.startsWith("--") && i + 1 < node_process_1.default.argv.length) {
|
|
464
|
-
const nextArg = node_process_1.default.argv[i + 1];
|
|
465
|
-
const key = arg.slice(2);
|
|
466
|
-
// Check value for all requested types
|
|
467
|
-
for (const type of typeArray) {
|
|
468
|
-
if (validators[type] && validators[type](nextArg)) {
|
|
469
|
-
foundKeys.push(key);
|
|
470
|
-
break; // Don't add duplicates
|
|
471
|
-
}
|
|
472
|
-
}
|
|
473
|
-
}
|
|
474
|
-
}
|
|
475
|
-
return foundKeys;
|
|
476
|
-
}
|
|
477
|
-
const cliArgs = (0, minimist_1.default)(node_process_1.default.argv.slice(2), {
|
|
478
|
-
boolean: ["testnet", "offline", ...findInArgv("bool")],
|
|
479
|
-
string: ["_", ...findInArgv(["hex", "number", "empty"])],
|
|
354
|
+
const rawArgs = (0, _utils_js_1.parseArgs)(process.argv.slice(2), {
|
|
355
|
+
flags: ["testnet", "help", "h", "offline"],
|
|
356
|
+
});
|
|
357
|
+
const args = (0, _utils_js_1.transformArgs)(rawArgs, {
|
|
358
|
+
number: "string",
|
|
480
359
|
});
|
|
481
|
-
const [endpoint, method] =
|
|
482
|
-
if (
|
|
360
|
+
const [endpoint, method] = args._;
|
|
361
|
+
if (args.help || args.h || !endpoint || !method) {
|
|
483
362
|
printHelp();
|
|
484
363
|
}
|
|
485
364
|
else {
|
|
486
|
-
executeEndpointMethod(endpoint, method,
|
|
365
|
+
executeEndpointMethod(endpoint, method, args)
|
|
487
366
|
.then((result) => console.log(JSON.stringify(result)))
|
|
488
367
|
.catch((error) => console.error("Error:", error instanceof Error ? error.message : String(error)));
|
|
489
368
|
}
|
package/script/bin/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/bin/cli.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/bin/cli.ts"],"names":[],"mappings":"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"}
|