@metamask-previews/perps-controller 1.2.0-preview-91888a29f → 1.2.0-preview-3f86f1cf7

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@metamask-previews/perps-controller",
3
- "version": "1.2.0-preview-91888a29f",
3
+ "version": "1.2.0-preview-3f86f1cf7",
4
4
  "description": "Controller for perpetual trading functionality in MetaMask",
5
5
  "keywords": [
6
6
  "MetaMask",
@@ -32,7 +32,9 @@
32
32
  "main": "./dist/index.cjs",
33
33
  "types": "./dist/index.d.cts",
34
34
  "files": [
35
- "dist/"
35
+ "dist/",
36
+ "!dist/providers/MYXProvider*",
37
+ "!dist/services/MYXClientService*"
36
38
  ],
37
39
  "scripts": {
38
40
  "build": "ts-bridge --project tsconfig.build.json --verbose --clean --no-references",
@@ -1,514 +0,0 @@
1
- "use strict";
2
- /**
3
- * MYXProvider
4
- *
5
- * Stage 1 provider implementation for MYX protocol.
6
- * Implements the PerpsProvider interface with read-only operations.
7
- * Trading functionality will be added in Stage 3.
8
- *
9
- * Key differences from HyperLiquid:
10
- * - Uses USDT collateral on BNB chain (vs USDC on Arbitrum)
11
- * - Multi-Pool Model: multiple pools can exist per symbol
12
- * - Uses REST polling for prices (WebSocket deferred to Stage 3)
13
- */
14
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
15
- if (kind === "m") throw new TypeError("Private method is not writable");
16
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
17
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
18
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
19
- };
20
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
21
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
22
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
23
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
24
- };
25
- var _MYXProvider_instances, _MYXProvider_deps, _MYXProvider_clientService, _MYXProvider_isTestnet, _MYXProvider_poolsCache, _MYXProvider_poolSymbolMap, _MYXProvider_tickersCache, _MYXProvider_getErrorContext, _MYXProvider_getAdaptedPrice;
26
- Object.defineProperty(exports, "__esModule", { value: true });
27
- exports.MYXProvider = void 0;
28
- const perpsConfig_1 = require("../constants/perpsConfig.cjs");
29
- const MYXClientService_1 = require("../services/MYXClientService.cjs");
30
- const types_1 = require("../types/index.cjs");
31
- const errorUtils_1 = require("../utils/errorUtils.cjs");
32
- const myxAdapter_1 = require("../utils/myxAdapter.cjs");
33
- // ============================================================================
34
- // Constants
35
- // ============================================================================
36
- const MYX_NOT_SUPPORTED_ERROR = 'MYX trading not yet supported';
37
- const MYX_BLOCK_EXPLORER_URL = 'https://bscscan.com';
38
- const MYX_TESTNET_EXPLORER_URL = 'https://testnet.bscscan.com';
39
- // ============================================================================
40
- // MYXProvider
41
- // ============================================================================
42
- /**
43
- * MYX provider implementation
44
- *
45
- * Stage 1: Read-only operations (markets, prices)
46
- * Trading operations return errors until Stage 3.
47
- */
48
- class MYXProvider {
49
- constructor(options) {
50
- _MYXProvider_instances.add(this);
51
- this.protocolId = 'myx';
52
- // Platform dependencies
53
- _MYXProvider_deps.set(this, void 0);
54
- // Client service
55
- _MYXProvider_clientService.set(this, void 0);
56
- // Configuration
57
- _MYXProvider_isTestnet.set(this, void 0);
58
- // Cache for pools (freshness delegated to MYXClientService)
59
- _MYXProvider_poolsCache.set(this, []);
60
- _MYXProvider_poolSymbolMap.set(this, new Map());
61
- // Ticker cache for price data
62
- _MYXProvider_tickersCache.set(this, new Map());
63
- __classPrivateFieldSet(this, _MYXProvider_deps, options.platformDependencies, "f");
64
- __classPrivateFieldSet(this, _MYXProvider_isTestnet, options.isTestnet ?? true, "f"); // Force testnet in Stage 1
65
- // Initialize client service
66
- __classPrivateFieldSet(this, _MYXProvider_clientService, new MYXClientService_1.MYXClientService(__classPrivateFieldGet(this, _MYXProvider_deps, "f"), {
67
- isTestnet: __classPrivateFieldGet(this, _MYXProvider_isTestnet, "f"),
68
- }), "f");
69
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").debugLogger.log('[MYXProvider] Constructor complete', {
70
- protocolId: this.protocolId,
71
- isTestnet: __classPrivateFieldGet(this, _MYXProvider_isTestnet, "f"),
72
- });
73
- }
74
- // ============================================================================
75
- // Initialization & Lifecycle
76
- // ============================================================================
77
- async initialize() {
78
- try {
79
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").debugLogger.log('[MYXProvider] Initializing...');
80
- // Fetch initial markets
81
- const pools = await __classPrivateFieldGet(this, _MYXProvider_clientService, "f").getMarkets();
82
- // Filter to MYX-exclusive markets
83
- __classPrivateFieldSet(this, _MYXProvider_poolsCache, (0, myxAdapter_1.filterMYXExclusiveMarkets)(pools), "f");
84
- __classPrivateFieldSet(this, _MYXProvider_poolSymbolMap, (0, myxAdapter_1.buildPoolSymbolMap)(__classPrivateFieldGet(this, _MYXProvider_poolsCache, "f")), "f");
85
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").debugLogger.log('[MYXProvider] Initialized successfully', {
86
- totalPools: pools.length,
87
- exclusivePools: __classPrivateFieldGet(this, _MYXProvider_poolsCache, "f").length,
88
- });
89
- return { success: true };
90
- }
91
- catch (caughtError) {
92
- const wrappedError = (0, errorUtils_1.ensureError)(caughtError, 'MYXProvider.initialize');
93
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").logger.error(wrappedError, __classPrivateFieldGet(this, _MYXProvider_instances, "m", _MYXProvider_getErrorContext).call(this, 'initialize'));
94
- return { success: false, error: wrappedError.message };
95
- }
96
- }
97
- async disconnect() {
98
- try {
99
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").debugLogger.log('[MYXProvider] Disconnecting...');
100
- __classPrivateFieldGet(this, _MYXProvider_clientService, "f").disconnect();
101
- __classPrivateFieldSet(this, _MYXProvider_poolsCache, [], "f");
102
- __classPrivateFieldGet(this, _MYXProvider_poolSymbolMap, "f").clear();
103
- __classPrivateFieldGet(this, _MYXProvider_tickersCache, "f").clear();
104
- return { success: true };
105
- }
106
- catch (caughtError) {
107
- const wrappedError = (0, errorUtils_1.ensureError)(caughtError, 'MYXProvider.disconnect');
108
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").logger.error(wrappedError, __classPrivateFieldGet(this, _MYXProvider_instances, "m", _MYXProvider_getErrorContext).call(this, 'disconnect'));
109
- return { success: false, error: wrappedError.message };
110
- }
111
- }
112
- async ping(timeoutMs) {
113
- await __classPrivateFieldGet(this, _MYXProvider_clientService, "f").ping(timeoutMs);
114
- }
115
- async toggleTestnet() {
116
- // Stage 1: Testnet only
117
- return {
118
- success: false,
119
- isTestnet: __classPrivateFieldGet(this, _MYXProvider_isTestnet, "f"),
120
- error: 'MYX mainnet not yet available',
121
- };
122
- }
123
- async isReadyToTrade() {
124
- // Stage 1: Trading not supported
125
- return {
126
- ready: false,
127
- error: 'MYX trading not yet supported',
128
- walletConnected: false,
129
- networkSupported: __classPrivateFieldGet(this, _MYXProvider_isTestnet, "f"),
130
- };
131
- }
132
- // ============================================================================
133
- // Market Data Operations (Stage 1 - Fully Implemented)
134
- // ============================================================================
135
- // TODO: Align error handling - read operations should return empty defaults
136
- // instead of throwing, matching HyperLiquid pattern
137
- async getMarkets(_params) {
138
- try {
139
- // Delegate cache freshness to MYXClientService
140
- const pools = await __classPrivateFieldGet(this, _MYXProvider_clientService, "f").getMarkets();
141
- __classPrivateFieldSet(this, _MYXProvider_poolsCache, (0, myxAdapter_1.filterMYXExclusiveMarkets)(pools), "f");
142
- __classPrivateFieldSet(this, _MYXProvider_poolSymbolMap, (0, myxAdapter_1.buildPoolSymbolMap)(__classPrivateFieldGet(this, _MYXProvider_poolsCache, "f")), "f");
143
- return __classPrivateFieldGet(this, _MYXProvider_poolsCache, "f").map((pool) => (0, myxAdapter_1.adaptMarketFromMYX)(pool));
144
- }
145
- catch (caughtError) {
146
- const wrappedError = (0, errorUtils_1.ensureError)(caughtError, 'MYXProvider.getMarkets');
147
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").logger.error(wrappedError, __classPrivateFieldGet(this, _MYXProvider_instances, "m", _MYXProvider_getErrorContext).call(this, 'getMarkets'));
148
- throw wrappedError;
149
- }
150
- }
151
- async getMarketDataWithPrices() {
152
- try {
153
- // Ensure we have markets
154
- if (__classPrivateFieldGet(this, _MYXProvider_poolsCache, "f").length === 0) {
155
- await this.getMarkets();
156
- }
157
- // Fetch tickers for all pools
158
- const poolIds = __classPrivateFieldGet(this, _MYXProvider_poolsCache, "f").map((pool) => pool.poolId);
159
- const tickers = await __classPrivateFieldGet(this, _MYXProvider_clientService, "f").getTickers(poolIds);
160
- // Build ticker map
161
- const tickerMap = new Map();
162
- for (const ticker of tickers) {
163
- tickerMap.set(ticker.poolId, ticker);
164
- __classPrivateFieldGet(this, _MYXProvider_tickersCache, "f").set(ticker.poolId, ticker);
165
- }
166
- // Transform to PerpsMarketData
167
- return __classPrivateFieldGet(this, _MYXProvider_poolsCache, "f").map((pool) => {
168
- const ticker = tickerMap.get(pool.poolId);
169
- return (0, myxAdapter_1.adaptMarketDataFromMYX)(pool, ticker, __classPrivateFieldGet(this, _MYXProvider_deps, "f").marketDataFormatters);
170
- });
171
- }
172
- catch (caughtError) {
173
- const wrappedError = (0, errorUtils_1.ensureError)(caughtError, 'MYXProvider.getMarketDataWithPrices');
174
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").logger.error(wrappedError, __classPrivateFieldGet(this, _MYXProvider_instances, "m", _MYXProvider_getErrorContext).call(this, 'getMarketDataWithPrices'));
175
- throw wrappedError;
176
- }
177
- }
178
- // ============================================================================
179
- // Price Subscriptions (Stage 1 - REST Polling)
180
- // ============================================================================
181
- subscribeToPrices(params) {
182
- const { symbols, callback, includeOrderBook } = params;
183
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").debugLogger.log('[MYXProvider] Setting up price subscription', {
184
- symbols: symbols.length,
185
- includeOrderBook,
186
- });
187
- // Map symbols to pool IDs
188
- const poolIds = [];
189
- for (const pool of __classPrivateFieldGet(this, _MYXProvider_poolsCache, "f")) {
190
- const symbol = pool.baseSymbol || pool.poolId;
191
- if (symbols.includes(symbol)) {
192
- poolIds.push(pool.poolId);
193
- }
194
- }
195
- if (poolIds.length === 0) {
196
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").debugLogger.log('[MYXProvider] subscribeToPrices: No pool IDs found. Ensure initialize() has been called.', { symbols });
197
- setTimeout(() => params.callback([]), 0);
198
- return () => {
199
- /* noop */
200
- };
201
- }
202
- // Start price polling
203
- __classPrivateFieldGet(this, _MYXProvider_clientService, "f").startPricePolling(poolIds, (tickers) => {
204
- // Convert tickers to PriceUpdate format
205
- const updates = tickers.map((ticker) => {
206
- const symbol = __classPrivateFieldGet(this, _MYXProvider_poolSymbolMap, "f").get(ticker.poolId) ?? ticker.poolId;
207
- const { price, change24h } = __classPrivateFieldGet(this, _MYXProvider_instances, "m", _MYXProvider_getAdaptedPrice).call(this, ticker);
208
- return {
209
- symbol,
210
- price,
211
- timestamp: Date.now(),
212
- percentChange24h: change24h.toFixed(2),
213
- providerId: 'myx',
214
- };
215
- });
216
- callback(updates);
217
- });
218
- // Return unsubscribe function
219
- return () => {
220
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").debugLogger.log('[MYXProvider] Unsubscribing from prices');
221
- __classPrivateFieldGet(this, _MYXProvider_clientService, "f").stopPricePolling();
222
- };
223
- }
224
- // ============================================================================
225
- // Asset Routes (Stage 1 - Stubbed)
226
- // ============================================================================
227
- getDepositRoutes(_params) {
228
- // Stage 1: No deposit support
229
- return [];
230
- }
231
- getWithdrawalRoutes(_params) {
232
- // Stage 1: No withdrawal support
233
- return [];
234
- }
235
- // ============================================================================
236
- // Trading Operations (Stage 1 - All Stubbed)
237
- // ============================================================================
238
- async placeOrder(_params) {
239
- return {
240
- success: false,
241
- error: MYX_NOT_SUPPORTED_ERROR,
242
- };
243
- }
244
- async editOrder(_params) {
245
- return {
246
- success: false,
247
- error: MYX_NOT_SUPPORTED_ERROR,
248
- };
249
- }
250
- async cancelOrder(_params) {
251
- return {
252
- success: false,
253
- error: MYX_NOT_SUPPORTED_ERROR,
254
- };
255
- }
256
- async cancelOrders(_params) {
257
- return {
258
- success: false,
259
- successCount: 0,
260
- failureCount: 0,
261
- results: [],
262
- };
263
- }
264
- async closePosition(_params) {
265
- return {
266
- success: false,
267
- error: MYX_NOT_SUPPORTED_ERROR,
268
- };
269
- }
270
- async closePositions(_params) {
271
- return {
272
- success: false,
273
- successCount: 0,
274
- failureCount: 0,
275
- results: [],
276
- };
277
- }
278
- async updatePositionTPSL(_params) {
279
- return {
280
- success: false,
281
- error: MYX_NOT_SUPPORTED_ERROR,
282
- };
283
- }
284
- async updateMargin(_params) {
285
- return {
286
- success: false,
287
- error: MYX_NOT_SUPPORTED_ERROR,
288
- };
289
- }
290
- async withdraw(_params) {
291
- return {
292
- success: false,
293
- error: MYX_NOT_SUPPORTED_ERROR,
294
- };
295
- }
296
- // ============================================================================
297
- // Account Operations (Stage 1 - Empty Returns)
298
- // ============================================================================
299
- async getPositions(_params) {
300
- // Stage 1: No position tracking
301
- return [];
302
- }
303
- async getAccountState(_params) {
304
- // Stage 1: Empty account state
305
- return {
306
- availableBalance: '0',
307
- totalBalance: '0',
308
- marginUsed: '0',
309
- unrealizedPnl: '0',
310
- returnOnEquity: '0',
311
- };
312
- }
313
- async getOrders(_params) {
314
- // Stage 1: No order tracking
315
- return [];
316
- }
317
- async getOpenOrders(_params) {
318
- // Stage 1: No order tracking
319
- return [];
320
- }
321
- async getOrderFills(_params) {
322
- // Stage 1: No fill tracking
323
- return [];
324
- }
325
- async getOrFetchFills(_params) {
326
- // Stage 1: No fill tracking
327
- return [];
328
- }
329
- async getFunding(_params) {
330
- // Stage 1: No funding tracking
331
- return [];
332
- }
333
- async getHistoricalPortfolio(_params) {
334
- return {
335
- accountValue1dAgo: '0',
336
- timestamp: Date.now(),
337
- };
338
- }
339
- async getUserNonFundingLedgerUpdates(_params) {
340
- return [];
341
- }
342
- async getUserHistory(_params) {
343
- return [];
344
- }
345
- // ============================================================================
346
- // Validation Operations (Stage 1 - All Invalid)
347
- // ============================================================================
348
- async validateDeposit(_params) {
349
- return { isValid: false, error: MYX_NOT_SUPPORTED_ERROR };
350
- }
351
- async validateOrder(_params) {
352
- return { isValid: false, error: MYX_NOT_SUPPORTED_ERROR };
353
- }
354
- async validateClosePosition(_params) {
355
- return { isValid: false, error: MYX_NOT_SUPPORTED_ERROR };
356
- }
357
- async validateWithdrawal(_params) {
358
- return { isValid: false, error: MYX_NOT_SUPPORTED_ERROR };
359
- }
360
- // ============================================================================
361
- // Protocol Calculations (Stage 1 - Default Values)
362
- // ============================================================================
363
- async calculateLiquidationPrice(_params) {
364
- return '0';
365
- }
366
- async calculateMaintenanceMargin(_params) {
367
- return 0;
368
- }
369
- async getMaxLeverage(_asset) {
370
- return 100; // MYX default max leverage
371
- }
372
- async calculateFees(_params) {
373
- // MYX fee structure (placeholder values)
374
- return {
375
- feeRate: 0.0005, // 0.05% total fee rate
376
- protocolFeeRate: 0.0005, // Protocol taker fee
377
- };
378
- }
379
- // ============================================================================
380
- // Subscriptions (Stage 1 - No-op)
381
- // ============================================================================
382
- subscribeToPositions(params) {
383
- // Stage 1: No position tracking - immediately call back with empty array
384
- // to signal loading is complete (no data to show)
385
- setTimeout(() => params.callback([]), 0);
386
- return () => {
387
- /* noop */
388
- };
389
- }
390
- subscribeToOrderFills(params) {
391
- // Stage 1: No fill tracking - immediately call back with empty array
392
- setTimeout(() => params.callback([]), 0);
393
- return () => {
394
- /* noop */
395
- };
396
- }
397
- subscribeToOrders(params) {
398
- // Stage 1: No order tracking - immediately call back with empty array
399
- setTimeout(() => params.callback([]), 0);
400
- return () => {
401
- /* noop */
402
- };
403
- }
404
- subscribeToAccount(params) {
405
- // Stage 1: Empty account state - immediately call back
406
- setTimeout(() => params.callback({
407
- availableBalance: '0',
408
- totalBalance: '0',
409
- marginUsed: '0',
410
- unrealizedPnl: '0',
411
- returnOnEquity: '0',
412
- }), 0);
413
- return () => {
414
- /* noop */
415
- };
416
- }
417
- subscribeToOICaps(params) {
418
- // Stage 1: No OI caps - immediately call back with empty array
419
- // (matches HyperLiquid pattern which calls callback with cached data)
420
- setTimeout(() => params.callback([]), 0);
421
- return () => {
422
- /* noop */
423
- };
424
- }
425
- subscribeToCandles(params) {
426
- // Stage 1: No candle data - immediately call back with empty candles
427
- // (matches HyperLiquid pattern which calls callback after initial fetch)
428
- setTimeout(() => params.callback({
429
- symbol: params.symbol,
430
- interval: params.interval,
431
- candles: [],
432
- }), 0);
433
- return () => {
434
- /* noop */
435
- };
436
- }
437
- subscribeToOrderBook(params) {
438
- // Stage 1: No order book - immediately call back with empty data
439
- setTimeout(() => params.callback({
440
- bids: [],
441
- asks: [],
442
- spread: '0',
443
- spreadPercentage: '0',
444
- midPrice: '0',
445
- lastUpdated: Date.now(),
446
- maxTotal: '0',
447
- }), 0);
448
- return () => {
449
- /* noop */
450
- };
451
- }
452
- setLiveDataConfig(_config) {
453
- // Stage 1: No-op
454
- }
455
- // ============================================================================
456
- // Connection State (Stage 1 - REST Only)
457
- // ============================================================================
458
- getWebSocketConnectionState() {
459
- // Stage 1: No WebSocket, report as connected (REST is always available)
460
- return types_1.WebSocketConnectionState.Connected;
461
- }
462
- subscribeToConnectionState(_listener) {
463
- // Stage 1: No WebSocket, no connection state changes
464
- return () => {
465
- /* noop */
466
- };
467
- }
468
- async reconnect() {
469
- // Stage 1: No WebSocket to reconnect
470
- __classPrivateFieldGet(this, _MYXProvider_deps, "f").debugLogger.log('[MYXProvider] reconnect() is no-op in Stage 1');
471
- }
472
- // ============================================================================
473
- // Block Explorer
474
- // ============================================================================
475
- getBlockExplorerUrl(address) {
476
- const baseUrl = __classPrivateFieldGet(this, _MYXProvider_isTestnet, "f")
477
- ? MYX_TESTNET_EXPLORER_URL
478
- : MYX_BLOCK_EXPLORER_URL;
479
- return address ? `${baseUrl}/address/${address}` : baseUrl;
480
- }
481
- // ============================================================================
482
- // Fee Discount (Stage 1 - No-op)
483
- // ============================================================================
484
- setUserFeeDiscount(_discountBips) {
485
- // Stage 1: No fee discount support
486
- }
487
- // ============================================================================
488
- // HIP-3 Operations (N/A for MYX)
489
- // ============================================================================
490
- async getAvailableDexs() {
491
- // MYX doesn't have HIP-3 equivalent
492
- return [];
493
- }
494
- }
495
- exports.MYXProvider = MYXProvider;
496
- _MYXProvider_deps = new WeakMap(), _MYXProvider_clientService = new WeakMap(), _MYXProvider_isTestnet = new WeakMap(), _MYXProvider_poolsCache = new WeakMap(), _MYXProvider_poolSymbolMap = new WeakMap(), _MYXProvider_tickersCache = new WeakMap(), _MYXProvider_instances = new WeakSet(), _MYXProvider_getErrorContext = function _MYXProvider_getErrorContext(method, extra) {
497
- return {
498
- tags: {
499
- feature: perpsConfig_1.PERPS_CONSTANTS.FeatureName,
500
- provider: 'MYXProvider',
501
- network: __classPrivateFieldGet(this, _MYXProvider_isTestnet, "f") ? 'testnet' : 'mainnet',
502
- },
503
- context: {
504
- name: `MYXProvider.${method}`,
505
- data: {
506
- isTestnet: __classPrivateFieldGet(this, _MYXProvider_isTestnet, "f"),
507
- ...extra,
508
- },
509
- },
510
- };
511
- }, _MYXProvider_getAdaptedPrice = function _MYXProvider_getAdaptedPrice(ticker) {
512
- return (0, myxAdapter_1.adaptPriceFromMYX)(ticker);
513
- };
514
- //# sourceMappingURL=MYXProvider.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MYXProvider.cjs","sourceRoot":"","sources":["../../src/providers/MYXProvider.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * MYXProvider\n *\n * Stage 1 provider implementation for MYX protocol.\n * Implements the PerpsProvider interface with read-only operations.\n * Trading functionality will be added in Stage 3.\n *\n * Key differences from HyperLiquid:\n * - Uses USDT collateral on BNB chain (vs USDC on Arbitrum)\n * - Multi-Pool Model: multiple pools can exist per symbol\n * - Uses REST polling for prices (WebSocket deferred to Stage 3)\n */\n\nimport type { CaipAccountId } from '@metamask/utils';\n\nimport { PERPS_CONSTANTS } from '../constants/perpsConfig';\nimport { MYXClientService } from '../services/MYXClientService';\nimport { WebSocketConnectionState } from '../types';\nimport type {\n AccountState,\n AssetRoute,\n BatchCancelOrdersParams,\n CancelOrderParams,\n CancelOrderResult,\n CancelOrdersResult,\n ClosePositionParams,\n ClosePositionsParams,\n ClosePositionsResult,\n DepositParams,\n DisconnectResult,\n EditOrderParams,\n FeeCalculationParams,\n FeeCalculationResult,\n Funding,\n GetAccountStateParams,\n GetFundingParams,\n GetHistoricalPortfolioParams,\n GetMarketsParams,\n GetOrderFillsParams,\n GetOrdersParams,\n GetOrFetchFillsParams,\n GetPositionsParams,\n GetSupportedPathsParams,\n HistoricalPortfolioResult,\n InitializeResult,\n LiquidationPriceParams,\n LiveDataConfig,\n MaintenanceMarginParams,\n MarginResult,\n MarketInfo,\n Order,\n OrderFill,\n OrderParams,\n OrderResult,\n PerpsPlatformDependencies,\n PerpsMarketData,\n PerpsProvider,\n Position,\n PriceUpdate,\n ReadyToTradeResult,\n SubscribeAccountParams,\n SubscribeCandlesParams,\n SubscribeOICapsParams,\n SubscribeOrderBookParams,\n SubscribeOrderFillsParams,\n SubscribeOrdersParams,\n SubscribePositionsParams,\n SubscribePricesParams,\n ToggleTestnetResult,\n UpdatePositionTPSLParams,\n UserHistoryItem,\n WithdrawParams,\n WithdrawResult,\n RawLedgerUpdate,\n} from '../types';\nimport type { MYXPoolSymbol, MYXTicker } from '../types/myx-types';\nimport { ensureError } from '../utils/errorUtils';\nimport {\n adaptMarketFromMYX,\n adaptMarketDataFromMYX,\n adaptPriceFromMYX,\n filterMYXExclusiveMarkets,\n buildPoolSymbolMap,\n} from '../utils/myxAdapter';\n\n// ============================================================================\n// Constants\n// ============================================================================\n\nconst MYX_NOT_SUPPORTED_ERROR = 'MYX trading not yet supported';\nconst MYX_BLOCK_EXPLORER_URL = 'https://bscscan.com';\nconst MYX_TESTNET_EXPLORER_URL = 'https://testnet.bscscan.com';\n\n// ============================================================================\n// MYXProvider\n// ============================================================================\n\n/**\n * MYX provider implementation\n *\n * Stage 1: Read-only operations (markets, prices)\n * Trading operations return errors until Stage 3.\n */\nexport class MYXProvider implements PerpsProvider {\n readonly protocolId = 'myx';\n\n // Platform dependencies\n readonly #deps: PerpsPlatformDependencies;\n\n // Client service\n readonly #clientService: MYXClientService;\n\n // Configuration\n readonly #isTestnet: boolean;\n\n // Cache for pools (freshness delegated to MYXClientService)\n #poolsCache: MYXPoolSymbol[] = [];\n\n #poolSymbolMap: Map<string, string> = new Map();\n\n // Ticker cache for price data\n readonly #tickersCache: Map<string, MYXTicker> = new Map();\n\n constructor(options: {\n isTestnet?: boolean;\n platformDependencies: PerpsPlatformDependencies;\n }) {\n this.#deps = options.platformDependencies;\n this.#isTestnet = options.isTestnet ?? true; // Force testnet in Stage 1\n\n // Initialize client service\n this.#clientService = new MYXClientService(this.#deps, {\n isTestnet: this.#isTestnet,\n });\n\n this.#deps.debugLogger.log('[MYXProvider] Constructor complete', {\n protocolId: this.protocolId,\n isTestnet: this.#isTestnet,\n });\n }\n\n // ============================================================================\n // Error Context Helper\n // ============================================================================\n\n #getErrorContext(\n method: string,\n extra?: Record<string, unknown>,\n ): {\n tags?: Record<string, string | number>;\n context?: { name: string; data: Record<string, unknown> };\n } {\n return {\n tags: {\n feature: PERPS_CONSTANTS.FeatureName,\n provider: 'MYXProvider',\n network: this.#isTestnet ? 'testnet' : 'mainnet',\n },\n context: {\n name: `MYXProvider.${method}`,\n data: {\n isTestnet: this.#isTestnet,\n ...extra,\n },\n },\n };\n }\n\n // ============================================================================\n // Initialization & Lifecycle\n // ============================================================================\n\n async initialize(): Promise<InitializeResult> {\n try {\n this.#deps.debugLogger.log('[MYXProvider] Initializing...');\n\n // Fetch initial markets\n const pools = await this.#clientService.getMarkets();\n\n // Filter to MYX-exclusive markets\n this.#poolsCache = filterMYXExclusiveMarkets(pools);\n this.#poolSymbolMap = buildPoolSymbolMap(this.#poolsCache);\n\n this.#deps.debugLogger.log('[MYXProvider] Initialized successfully', {\n totalPools: pools.length,\n exclusivePools: this.#poolsCache.length,\n });\n\n return { success: true };\n } catch (caughtError) {\n const wrappedError = ensureError(caughtError, 'MYXProvider.initialize');\n this.#deps.logger.error(\n wrappedError,\n this.#getErrorContext('initialize'),\n );\n return { success: false, error: wrappedError.message };\n }\n }\n\n async disconnect(): Promise<DisconnectResult> {\n try {\n this.#deps.debugLogger.log('[MYXProvider] Disconnecting...');\n\n this.#clientService.disconnect();\n this.#poolsCache = [];\n this.#poolSymbolMap.clear();\n this.#tickersCache.clear();\n\n return { success: true };\n } catch (caughtError) {\n const wrappedError = ensureError(caughtError, 'MYXProvider.disconnect');\n this.#deps.logger.error(\n wrappedError,\n this.#getErrorContext('disconnect'),\n );\n return { success: false, error: wrappedError.message };\n }\n }\n\n async ping(timeoutMs?: number): Promise<void> {\n await this.#clientService.ping(timeoutMs);\n }\n\n async toggleTestnet(): Promise<ToggleTestnetResult> {\n // Stage 1: Testnet only\n return {\n success: false,\n isTestnet: this.#isTestnet,\n error: 'MYX mainnet not yet available',\n };\n }\n\n async isReadyToTrade(): Promise<ReadyToTradeResult> {\n // Stage 1: Trading not supported\n return {\n ready: false,\n error: 'MYX trading not yet supported',\n walletConnected: false,\n networkSupported: this.#isTestnet,\n };\n }\n\n // ============================================================================\n // Market Data Operations (Stage 1 - Fully Implemented)\n // ============================================================================\n\n // TODO: Align error handling - read operations should return empty defaults\n // instead of throwing, matching HyperLiquid pattern\n async getMarkets(_params?: GetMarketsParams): Promise<MarketInfo[]> {\n try {\n // Delegate cache freshness to MYXClientService\n const pools = await this.#clientService.getMarkets();\n this.#poolsCache = filterMYXExclusiveMarkets(pools);\n this.#poolSymbolMap = buildPoolSymbolMap(this.#poolsCache);\n\n return this.#poolsCache.map((pool) => adaptMarketFromMYX(pool));\n } catch (caughtError) {\n const wrappedError = ensureError(caughtError, 'MYXProvider.getMarkets');\n this.#deps.logger.error(\n wrappedError,\n this.#getErrorContext('getMarkets'),\n );\n throw wrappedError;\n }\n }\n\n async getMarketDataWithPrices(): Promise<PerpsMarketData[]> {\n try {\n // Ensure we have markets\n if (this.#poolsCache.length === 0) {\n await this.getMarkets();\n }\n\n // Fetch tickers for all pools\n const poolIds = this.#poolsCache.map((pool) => pool.poolId);\n const tickers = await this.#clientService.getTickers(poolIds);\n\n // Build ticker map\n const tickerMap = new Map<string, MYXTicker>();\n for (const ticker of tickers) {\n tickerMap.set(ticker.poolId, ticker);\n this.#tickersCache.set(ticker.poolId, ticker);\n }\n\n // Transform to PerpsMarketData\n return this.#poolsCache.map((pool) => {\n const ticker = tickerMap.get(pool.poolId);\n return adaptMarketDataFromMYX(\n pool,\n ticker,\n this.#deps.marketDataFormatters,\n );\n });\n } catch (caughtError) {\n const wrappedError = ensureError(\n caughtError,\n 'MYXProvider.getMarketDataWithPrices',\n );\n this.#deps.logger.error(\n wrappedError,\n this.#getErrorContext('getMarketDataWithPrices'),\n );\n throw wrappedError;\n }\n }\n\n // ============================================================================\n // Price Subscriptions (Stage 1 - REST Polling)\n // ============================================================================\n\n subscribeToPrices(params: SubscribePricesParams): () => void {\n const { symbols, callback, includeOrderBook } = params;\n\n this.#deps.debugLogger.log('[MYXProvider] Setting up price subscription', {\n symbols: symbols.length,\n includeOrderBook,\n });\n\n // Map symbols to pool IDs\n const poolIds: string[] = [];\n for (const pool of this.#poolsCache) {\n const symbol = pool.baseSymbol || pool.poolId;\n if (symbols.includes(symbol)) {\n poolIds.push(pool.poolId);\n }\n }\n\n if (poolIds.length === 0) {\n this.#deps.debugLogger.log(\n '[MYXProvider] subscribeToPrices: No pool IDs found. Ensure initialize() has been called.',\n { symbols },\n );\n setTimeout(() => params.callback([]), 0);\n return () => {\n /* noop */\n };\n }\n\n // Start price polling\n this.#clientService.startPricePolling(poolIds, (tickers) => {\n // Convert tickers to PriceUpdate format\n const updates: PriceUpdate[] = tickers.map((ticker) => {\n const symbol = this.#poolSymbolMap.get(ticker.poolId) ?? ticker.poolId;\n const { price, change24h } = this.#getAdaptedPrice(ticker);\n\n return {\n symbol,\n price,\n timestamp: Date.now(),\n percentChange24h: change24h.toFixed(2),\n providerId: 'myx',\n };\n });\n\n callback(updates);\n });\n\n // Return unsubscribe function\n return () => {\n this.#deps.debugLogger.log('[MYXProvider] Unsubscribing from prices');\n this.#clientService.stopPricePolling();\n };\n }\n\n #getAdaptedPrice(ticker: MYXTicker): {\n price: string;\n change24h: number;\n } {\n return adaptPriceFromMYX(ticker);\n }\n\n // ============================================================================\n // Asset Routes (Stage 1 - Stubbed)\n // ============================================================================\n\n getDepositRoutes(_params?: GetSupportedPathsParams): AssetRoute[] {\n // Stage 1: No deposit support\n return [];\n }\n\n getWithdrawalRoutes(_params?: GetSupportedPathsParams): AssetRoute[] {\n // Stage 1: No withdrawal support\n return [];\n }\n\n // ============================================================================\n // Trading Operations (Stage 1 - All Stubbed)\n // ============================================================================\n\n async placeOrder(_params: OrderParams): Promise<OrderResult> {\n return {\n success: false,\n error: MYX_NOT_SUPPORTED_ERROR,\n };\n }\n\n async editOrder(_params: EditOrderParams): Promise<OrderResult> {\n return {\n success: false,\n error: MYX_NOT_SUPPORTED_ERROR,\n };\n }\n\n async cancelOrder(_params: CancelOrderParams): Promise<CancelOrderResult> {\n return {\n success: false,\n error: MYX_NOT_SUPPORTED_ERROR,\n };\n }\n\n async cancelOrders(\n _params: BatchCancelOrdersParams,\n ): Promise<CancelOrdersResult> {\n return {\n success: false,\n successCount: 0,\n failureCount: 0,\n results: [],\n };\n }\n\n async closePosition(_params: ClosePositionParams): Promise<OrderResult> {\n return {\n success: false,\n error: MYX_NOT_SUPPORTED_ERROR,\n };\n }\n\n async closePositions(\n _params: ClosePositionsParams,\n ): Promise<ClosePositionsResult> {\n return {\n success: false,\n successCount: 0,\n failureCount: 0,\n results: [],\n };\n }\n\n async updatePositionTPSL(\n _params: UpdatePositionTPSLParams,\n ): Promise<OrderResult> {\n return {\n success: false,\n error: MYX_NOT_SUPPORTED_ERROR,\n };\n }\n\n async updateMargin(_params: {\n symbol: string;\n amount: string;\n isAdd: boolean;\n }): Promise<MarginResult> {\n return {\n success: false,\n error: MYX_NOT_SUPPORTED_ERROR,\n };\n }\n\n async withdraw(_params: WithdrawParams): Promise<WithdrawResult> {\n return {\n success: false,\n error: MYX_NOT_SUPPORTED_ERROR,\n };\n }\n\n // ============================================================================\n // Account Operations (Stage 1 - Empty Returns)\n // ============================================================================\n\n async getPositions(_params?: GetPositionsParams): Promise<Position[]> {\n // Stage 1: No position tracking\n return [];\n }\n\n async getAccountState(\n _params?: GetAccountStateParams,\n ): Promise<AccountState> {\n // Stage 1: Empty account state\n return {\n availableBalance: '0',\n totalBalance: '0',\n marginUsed: '0',\n unrealizedPnl: '0',\n returnOnEquity: '0',\n };\n }\n\n async getOrders(_params?: GetOrdersParams): Promise<Order[]> {\n // Stage 1: No order tracking\n return [];\n }\n\n async getOpenOrders(_params?: GetOrdersParams): Promise<Order[]> {\n // Stage 1: No order tracking\n return [];\n }\n\n async getOrderFills(_params?: GetOrderFillsParams): Promise<OrderFill[]> {\n // Stage 1: No fill tracking\n return [];\n }\n\n async getOrFetchFills(_params?: GetOrFetchFillsParams): Promise<OrderFill[]> {\n // Stage 1: No fill tracking\n return [];\n }\n\n async getFunding(_params?: GetFundingParams): Promise<Funding[]> {\n // Stage 1: No funding tracking\n return [];\n }\n\n async getHistoricalPortfolio(\n _params?: GetHistoricalPortfolioParams,\n ): Promise<HistoricalPortfolioResult> {\n return {\n accountValue1dAgo: '0',\n timestamp: Date.now(),\n };\n }\n\n async getUserNonFundingLedgerUpdates(_params?: {\n accountId?: string;\n startTime?: number;\n endTime?: number;\n }): Promise<RawLedgerUpdate[]> {\n return [];\n }\n\n async getUserHistory(_params?: {\n accountId?: CaipAccountId;\n startTime?: number;\n endTime?: number;\n }): Promise<UserHistoryItem[]> {\n return [];\n }\n\n // ============================================================================\n // Validation Operations (Stage 1 - All Invalid)\n // ============================================================================\n\n async validateDeposit(\n _params: DepositParams,\n ): Promise<{ isValid: boolean; error?: string }> {\n return { isValid: false, error: MYX_NOT_SUPPORTED_ERROR };\n }\n\n async validateOrder(\n _params: OrderParams,\n ): Promise<{ isValid: boolean; error?: string }> {\n return { isValid: false, error: MYX_NOT_SUPPORTED_ERROR };\n }\n\n async validateClosePosition(\n _params: ClosePositionParams,\n ): Promise<{ isValid: boolean; error?: string }> {\n return { isValid: false, error: MYX_NOT_SUPPORTED_ERROR };\n }\n\n async validateWithdrawal(\n _params: WithdrawParams,\n ): Promise<{ isValid: boolean; error?: string }> {\n return { isValid: false, error: MYX_NOT_SUPPORTED_ERROR };\n }\n\n // ============================================================================\n // Protocol Calculations (Stage 1 - Default Values)\n // ============================================================================\n\n async calculateLiquidationPrice(\n _params: LiquidationPriceParams,\n ): Promise<string> {\n return '0';\n }\n\n async calculateMaintenanceMargin(\n _params: MaintenanceMarginParams,\n ): Promise<number> {\n return 0;\n }\n\n async getMaxLeverage(_asset: string): Promise<number> {\n return 100; // MYX default max leverage\n }\n\n async calculateFees(\n _params: FeeCalculationParams,\n ): Promise<FeeCalculationResult> {\n // MYX fee structure (placeholder values)\n return {\n feeRate: 0.0005, // 0.05% total fee rate\n protocolFeeRate: 0.0005, // Protocol taker fee\n };\n }\n\n // ============================================================================\n // Subscriptions (Stage 1 - No-op)\n // ============================================================================\n\n subscribeToPositions(params: SubscribePositionsParams): () => void {\n // Stage 1: No position tracking - immediately call back with empty array\n // to signal loading is complete (no data to show)\n setTimeout(() => params.callback([]), 0);\n return () => {\n /* noop */\n };\n }\n\n subscribeToOrderFills(params: SubscribeOrderFillsParams): () => void {\n // Stage 1: No fill tracking - immediately call back with empty array\n setTimeout(() => params.callback([]), 0);\n return () => {\n /* noop */\n };\n }\n\n subscribeToOrders(params: SubscribeOrdersParams): () => void {\n // Stage 1: No order tracking - immediately call back with empty array\n setTimeout(() => params.callback([]), 0);\n return () => {\n /* noop */\n };\n }\n\n subscribeToAccount(params: SubscribeAccountParams): () => void {\n // Stage 1: Empty account state - immediately call back\n setTimeout(\n () =>\n params.callback({\n availableBalance: '0',\n totalBalance: '0',\n marginUsed: '0',\n unrealizedPnl: '0',\n returnOnEquity: '0',\n }),\n 0,\n );\n return () => {\n /* noop */\n };\n }\n\n subscribeToOICaps(params: SubscribeOICapsParams): () => void {\n // Stage 1: No OI caps - immediately call back with empty array\n // (matches HyperLiquid pattern which calls callback with cached data)\n setTimeout(() => params.callback([]), 0);\n return () => {\n /* noop */\n };\n }\n\n subscribeToCandles(params: SubscribeCandlesParams): () => void {\n // Stage 1: No candle data - immediately call back with empty candles\n // (matches HyperLiquid pattern which calls callback after initial fetch)\n setTimeout(\n () =>\n params.callback({\n symbol: params.symbol,\n interval: params.interval,\n candles: [],\n }),\n 0,\n );\n return () => {\n /* noop */\n };\n }\n\n subscribeToOrderBook(params: SubscribeOrderBookParams): () => void {\n // Stage 1: No order book - immediately call back with empty data\n setTimeout(\n () =>\n params.callback({\n bids: [],\n asks: [],\n spread: '0',\n spreadPercentage: '0',\n midPrice: '0',\n lastUpdated: Date.now(),\n maxTotal: '0',\n }),\n 0,\n );\n return () => {\n /* noop */\n };\n }\n\n setLiveDataConfig(_config: Partial<LiveDataConfig>): void {\n // Stage 1: No-op\n }\n\n // ============================================================================\n // Connection State (Stage 1 - REST Only)\n // ============================================================================\n\n getWebSocketConnectionState(): WebSocketConnectionState {\n // Stage 1: No WebSocket, report as connected (REST is always available)\n return WebSocketConnectionState.Connected;\n }\n\n subscribeToConnectionState(\n _listener: (\n state: WebSocketConnectionState,\n reconnectionAttempt: number,\n ) => void,\n ): () => void {\n // Stage 1: No WebSocket, no connection state changes\n return () => {\n /* noop */\n };\n }\n\n async reconnect(): Promise<void> {\n // Stage 1: No WebSocket to reconnect\n this.#deps.debugLogger.log('[MYXProvider] reconnect() is no-op in Stage 1');\n }\n\n // ============================================================================\n // Block Explorer\n // ============================================================================\n\n getBlockExplorerUrl(address?: string): string {\n const baseUrl = this.#isTestnet\n ? MYX_TESTNET_EXPLORER_URL\n : MYX_BLOCK_EXPLORER_URL;\n\n return address ? `${baseUrl}/address/${address}` : baseUrl;\n }\n\n // ============================================================================\n // Fee Discount (Stage 1 - No-op)\n // ============================================================================\n\n setUserFeeDiscount(_discountBips: number | undefined): void {\n // Stage 1: No fee discount support\n }\n\n // ============================================================================\n // HIP-3 Operations (N/A for MYX)\n // ============================================================================\n\n async getAvailableDexs(): Promise<string[]> {\n // MYX doesn't have HIP-3 equivalent\n return [];\n }\n}\n"]}