@123456btc/123456btc-cli 1.0.3 → 1.0.5
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/api/auth.js +2 -2
- package/dist/api/auth.js.map +1 -1
- package/dist/api/client.d.ts +10 -6
- package/dist/api/client.d.ts.map +1 -1
- package/dist/api/client.js +62 -19
- package/dist/api/client.js.map +1 -1
- package/dist/api/client.test.js +24 -16
- package/dist/api/client.test.js.map +1 -1
- package/dist/api/token-manager.d.ts.map +1 -1
- package/dist/api/token-manager.js +4 -0
- package/dist/api/token-manager.js.map +1 -1
- package/dist/cli.js +17 -1
- package/dist/cli.js.map +1 -1
- package/dist/commands/auth.d.ts.map +1 -1
- package/dist/commands/auth.js +49 -80
- package/dist/commands/auth.js.map +1 -1
- package/dist/commands/gas.d.ts.map +1 -1
- package/dist/commands/gas.js +3 -2
- package/dist/commands/gas.js.map +1 -1
- package/dist/commands/health.d.ts.map +1 -1
- package/dist/commands/health.js +5 -3
- package/dist/commands/health.js.map +1 -1
- package/dist/commands/provider.d.ts.map +1 -1
- package/dist/commands/provider.js +17 -20
- package/dist/commands/provider.js.map +1 -1
- package/dist/commands/signals.d.ts.map +1 -1
- package/dist/commands/signals.js +3 -2
- package/dist/commands/signals.js.map +1 -1
- package/dist/commands/strategy.d.ts.map +1 -1
- package/dist/commands/strategy.js +10 -2
- package/dist/commands/strategy.js.map +1 -1
- package/dist/commands/tier.d.ts.map +1 -1
- package/dist/commands/tier.js +3 -2
- package/dist/commands/tier.js.map +1 -1
- package/dist/commands/wallet.d.ts.map +1 -1
- package/dist/commands/wallet.js +3 -2
- package/dist/commands/wallet.js.map +1 -1
- package/dist/config.d.ts +12 -4
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +28 -56
- package/dist/config.js.map +1 -1
- package/dist/index.d.ts +0 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -3
- package/dist/index.js.map +1 -1
- package/dist/session/store.d.ts +25 -0
- package/dist/session/store.d.ts.map +1 -0
- package/dist/session/store.js +108 -0
- package/dist/session/store.js.map +1 -0
- package/dist/session/store.test.d.ts +2 -0
- package/dist/session/store.test.d.ts.map +1 -0
- package/dist/session/store.test.js +118 -0
- package/dist/session/store.test.js.map +1 -0
- package/dist/utils/auth.d.ts +2 -5
- package/dist/utils/auth.d.ts.map +1 -1
- package/dist/utils/auth.js +5 -5
- package/dist/utils/auth.js.map +1 -1
- package/package.json +1 -1
package/dist/config.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAmB/C,wBAAgB,eAAe;;;;;;;;;;;;EAoB9B;AAED,wBAAgB,eAAe,IAAI,MAAM,CASxC"}
|
package/dist/config.js
CHANGED
|
@@ -1,75 +1,47 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SessionStore = void 0;
|
|
36
4
|
exports.loadCredentials = loadCredentials;
|
|
37
5
|
exports.getSolanaRpcUrl = getSolanaRpcUrl;
|
|
38
|
-
const fs = __importStar(require("fs"));
|
|
39
|
-
const path = __importStar(require("path"));
|
|
40
6
|
const dotenv_1 = require("dotenv");
|
|
7
|
+
const store_1 = require("./session/store");
|
|
41
8
|
// Load env file
|
|
42
9
|
(0, dotenv_1.config)();
|
|
43
|
-
|
|
10
|
+
var store_2 = require("./session/store");
|
|
11
|
+
Object.defineProperty(exports, "SessionStore", { enumerable: true, get: function () { return store_2.SessionStore; } });
|
|
12
|
+
function normalizeBaseUrl(raw) {
|
|
13
|
+
let url = raw.trim();
|
|
14
|
+
// Strip legacy /ext-api suffix
|
|
15
|
+
if (url.endsWith('/ext-api')) {
|
|
16
|
+
url = url.slice(0, -8);
|
|
17
|
+
}
|
|
18
|
+
// Strip trailing slash
|
|
19
|
+
if (url.endsWith('/')) {
|
|
20
|
+
url = url.slice(0, -1);
|
|
21
|
+
}
|
|
22
|
+
// Ensure /api suffix for unified routing
|
|
23
|
+
if (!url.endsWith('/api')) {
|
|
24
|
+
url = url + '/api';
|
|
25
|
+
}
|
|
26
|
+
return url;
|
|
27
|
+
}
|
|
44
28
|
function loadCredentials() {
|
|
45
|
-
|
|
29
|
+
const store = new store_1.SessionStore();
|
|
30
|
+
const creds = store.getCredentials();
|
|
31
|
+
// Check env file first (overrides stored credentials)
|
|
46
32
|
if (process.env.API_KEY) {
|
|
47
|
-
|
|
48
|
-
// 自动补全 /ext-api 后缀
|
|
49
|
-
if (baseUrl === 'https://platform.123456btc.com' || baseUrl === 'https://platform.123456btc.com/') {
|
|
50
|
-
baseUrl = 'https://platform.123456btc.com/ext-api';
|
|
51
|
-
}
|
|
33
|
+
const baseUrl = normalizeBaseUrl(process.env.API_BASE_URL || 'https://platform.123456btc.com');
|
|
52
34
|
return {
|
|
53
35
|
apiKey: process.env.API_KEY,
|
|
54
36
|
baseUrl,
|
|
55
37
|
env: process.env.API_ENV || 'live',
|
|
56
38
|
};
|
|
57
39
|
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
const parsed = JSON.parse(content);
|
|
62
|
-
// 兼容旧配置:如果 baseUrl 指向旧域名,自动切换到新平台
|
|
63
|
-
if (parsed.baseUrl && parsed.baseUrl.includes('api.123456btc.com') && !process.env.API_BASE_URL) {
|
|
64
|
-
parsed.baseUrl = 'https://platform.123456btc.com/ext-api';
|
|
65
|
-
}
|
|
66
|
-
// 自动补全 /ext-api 后缀
|
|
67
|
-
if (parsed.baseUrl === 'https://platform.123456btc.com' || parsed.baseUrl === 'https://platform.123456btc.com/') {
|
|
68
|
-
parsed.baseUrl = 'https://platform.123456btc.com/ext-api';
|
|
69
|
-
}
|
|
70
|
-
return parsed;
|
|
40
|
+
if (creds) {
|
|
41
|
+
const baseUrl = normalizeBaseUrl(creds.baseUrl);
|
|
42
|
+
return { ...creds, baseUrl };
|
|
71
43
|
}
|
|
72
|
-
throw new Error('No credentials found. Run "123456btc-cli auth login"');
|
|
44
|
+
throw new Error('No credentials found. Run "123456btc-cli auth login" or "123456btc-cli auth wallet-login"');
|
|
73
45
|
}
|
|
74
46
|
function getSolanaRpcUrl() {
|
|
75
47
|
const cluster = process.env.SOLANA_CLUSTER || 'mainnet-beta';
|
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":";;;AA4BA,0CAoBC;AAED,0CASC;AAzDD,mCAAgD;AAChD,2CAA+C;AAE/C,gBAAgB;AAChB,IAAA,eAAY,GAAE,CAAC;AAGf,yCAA+C;AAAtC,qGAAA,YAAY,OAAA;AAErB,SAAS,gBAAgB,CAAC,GAAW;IACnC,IAAI,GAAG,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;IACrB,+BAA+B;IAC/B,IAAI,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;QAC7B,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IACD,uBAAuB;IACvB,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QACtB,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IACD,yCAAyC;IACzC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1B,GAAG,GAAG,GAAG,GAAG,MAAM,CAAC;IACrB,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAED,SAAgB,eAAe;IAC7B,MAAM,KAAK,GAAG,IAAI,oBAAY,EAAE,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,CAAC,cAAc,EAAE,CAAC;IAErC,sDAAsD;IACtD,IAAI,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACxB,MAAM,OAAO,GAAG,gBAAgB,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,gCAAgC,CAAC,CAAC;QAC/F,OAAO;YACL,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO;YAC3B,OAAO;YACP,GAAG,EAAG,OAAO,CAAC,GAAG,CAAC,OAA2B,IAAI,MAAM;SACxD,CAAC;IACJ,CAAC;IAED,IAAI,KAAK,EAAE,CAAC;QACV,MAAM,OAAO,GAAG,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAChD,OAAO,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,CAAC;IAC/B,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,2FAA2F,CAAC,CAAC;AAC/G,CAAC;AAED,SAAgB,eAAe;IAC7B,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,cAAc,CAAC;IAC7D,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,qCAAqC,CAAC;IAEpF,IAAI,OAAO,KAAK,QAAQ,EAAE,CAAC;QACzB,OAAO,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,+BAA+B,CAAC;IAC1E,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -3,7 +3,6 @@
|
|
|
3
3
|
* Export main classes for programmatic usage
|
|
4
4
|
*/
|
|
5
5
|
export { ApiClient } from './api/client';
|
|
6
|
-
export { TokenManager } from './api/token-manager';
|
|
7
6
|
export { AuthApi } from './api/auth';
|
|
8
7
|
export { StrategyApi } from './api/strategy';
|
|
9
8
|
export { WalletApi } from './api/wallet';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAE5D,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAG5D,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC7D,YAAY,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAGzE,YAAY,EACV,MAAM,EACN,WAAW,EACX,QAAQ,EACR,QAAQ,EACR,uBAAuB,EACvB,wBAAwB,EACxB,cAAc,EACd,UAAU,EACV,aAAa,EACb,YAAY,EACZ,WAAW,GACZ,MAAM,aAAa,CAAC;AAErB,YAAY,EACV,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AAGvB,YAAY,EACV,cAAc,EACd,cAAc,EACd,eAAe,EACf,aAAa,EACb,WAAW,EACX,UAAU,EACV,oBAAoB,EACpB,eAAe,EACf,UAAU,EACV,eAAe,EACf,UAAU,EACV,UAAU,EACV,aAAa,EACb,aAAa,GACd,MAAM,kBAAkB,CAAC;AAE1B,YAAY,EACV,UAAU,EACV,aAAa,GACd,MAAM,cAAc,CAAC;AAGtB,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -4,11 +4,9 @@
|
|
|
4
4
|
* Export main classes for programmatic usage
|
|
5
5
|
*/
|
|
6
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.RiskGuard = exports.OrderStateManager = exports.ExecutionManager = exports.StrategyExecutor = exports.resetVault = exports.getVault = exports.VaultManager = exports.getSolanaRpcUrl = exports.loadCredentials = exports.IdentityVerifier = exports.SolanaProvider = exports.StrategyStream = exports.SignalsApi = exports.WalletApi = exports.StrategyApi = exports.AuthApi = exports.
|
|
7
|
+
exports.RiskGuard = exports.OrderStateManager = exports.ExecutionManager = exports.StrategyExecutor = exports.resetVault = exports.getVault = exports.VaultManager = exports.getSolanaRpcUrl = exports.loadCredentials = exports.IdentityVerifier = exports.SolanaProvider = exports.StrategyStream = exports.SignalsApi = exports.WalletApi = exports.StrategyApi = exports.AuthApi = exports.ApiClient = void 0;
|
|
8
8
|
var client_1 = require("./api/client");
|
|
9
9
|
Object.defineProperty(exports, "ApiClient", { enumerable: true, get: function () { return client_1.ApiClient; } });
|
|
10
|
-
var token_manager_1 = require("./api/token-manager");
|
|
11
|
-
Object.defineProperty(exports, "TokenManager", { enumerable: true, get: function () { return token_manager_1.TokenManager; } });
|
|
12
10
|
var auth_1 = require("./api/auth");
|
|
13
11
|
Object.defineProperty(exports, "AuthApi", { enumerable: true, get: function () { return auth_1.AuthApi; } });
|
|
14
12
|
var strategy_1 = require("./api/strategy");
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,uCAAyC;AAAhC,mGAAA,SAAS,OAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,uCAAyC;AAAhC,mGAAA,SAAS,OAAA;AAElB,mCAAqC;AAA5B,+FAAA,OAAO,OAAA;AAChB,2CAA6C;AAApC,uGAAA,WAAW,OAAA;AACpB,uCAAyC;AAAhC,mGAAA,SAAS,OAAA;AAClB,yCAA2C;AAAlC,qGAAA,UAAU,OAAA;AACnB,yDAAuD;AAA9C,iHAAA,cAAc,OAAA;AAEvB,6CAAoD;AAA3C,wGAAA,cAAc,OAAA;AACvB,yDAA4D;AAAnD,gHAAA,gBAAgB,OAAA;AAEzB,mCAA4D;AAAnD,yGAAA,eAAe,OAAA;AAAE,yGAAA,eAAe,OAAA;AAEzC,QAAQ;AACR,iCAA6D;AAApD,qGAAA,YAAY,OAAA;AAAE,iGAAA,QAAQ,OAAA;AAAE,mGAAA,UAAU,OAAA;AA8C3C,mBAAmB;AACnB,iDAA0E;AAAjE,4GAAA,gBAAgB,OAAA;AAAE,4GAAA,gBAAgB,OAAA;AAC3C,2CAAsD;AAA7C,0GAAA,iBAAiB,OAAA;AAC1B,yCAA6C;AAApC,iGAAA,SAAS,OAAA"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export interface Credentials {
|
|
2
|
+
apiKey?: string;
|
|
3
|
+
jwt?: string;
|
|
4
|
+
baseUrl: string;
|
|
5
|
+
walletAddress?: string;
|
|
6
|
+
environment: 'live' | 'test';
|
|
7
|
+
savedAt: string;
|
|
8
|
+
}
|
|
9
|
+
export interface AccessTokenSession {
|
|
10
|
+
token: string;
|
|
11
|
+
expiresAt: number;
|
|
12
|
+
scopes: string[];
|
|
13
|
+
}
|
|
14
|
+
export declare class SessionStore {
|
|
15
|
+
private get cliDir();
|
|
16
|
+
private get credentialsFile();
|
|
17
|
+
private get sessionFile();
|
|
18
|
+
getCredentials(): Credentials | null;
|
|
19
|
+
saveCredentials(creds: Credentials): void;
|
|
20
|
+
getAccessToken(): AccessTokenSession | null;
|
|
21
|
+
saveAccessToken(session: AccessTokenSession): void;
|
|
22
|
+
clearAccessToken(): void;
|
|
23
|
+
clearAll(): void;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../src/session/store.ts"],"names":[],"mappings":"AAYA,MAAM,WAAW,WAAW;IAC1B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,EAAE,MAAM,GAAG,MAAM,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,qBAAa,YAAY;IACvB,OAAO,KAAK,MAAM,GAKjB;IAED,OAAO,KAAK,eAAe,GAE1B;IAED,OAAO,KAAK,WAAW,GAEtB;IAED,cAAc,IAAI,WAAW,GAAG,IAAI;IASpC,eAAe,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI;IAOzC,cAAc,IAAI,kBAAkB,GAAG,IAAI;IAS3C,eAAe,CAAC,OAAO,EAAE,kBAAkB,GAAG,IAAI;IAOlD,gBAAgB,IAAI,IAAI;IAQxB,QAAQ,IAAI,IAAI;CAMjB"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.SessionStore = void 0;
|
|
37
|
+
/**
|
|
38
|
+
* SessionStore — Atomic CLI state management
|
|
39
|
+
*
|
|
40
|
+
* Manages two files in ~/.123456btc-cli/:
|
|
41
|
+
* credentials.json — long-lived credentials (apiKey, jwt, baseUrl)
|
|
42
|
+
* session.json — short-lived access token cache
|
|
43
|
+
*
|
|
44
|
+
* All operations are atomic: either fully succeed or leave no partial state.
|
|
45
|
+
*/
|
|
46
|
+
const fs = __importStar(require("fs"));
|
|
47
|
+
const path = __importStar(require("path"));
|
|
48
|
+
class SessionStore {
|
|
49
|
+
get cliDir() {
|
|
50
|
+
return path.join(process.env.HOME || process.env.USERPROFILE || '.', '.123456btc-cli');
|
|
51
|
+
}
|
|
52
|
+
get credentialsFile() {
|
|
53
|
+
return path.join(this.cliDir, 'credentials.json');
|
|
54
|
+
}
|
|
55
|
+
get sessionFile() {
|
|
56
|
+
return path.join(this.cliDir, 'session.json');
|
|
57
|
+
}
|
|
58
|
+
getCredentials() {
|
|
59
|
+
if (!fs.existsSync(this.credentialsFile))
|
|
60
|
+
return null;
|
|
61
|
+
try {
|
|
62
|
+
return JSON.parse(fs.readFileSync(this.credentialsFile, 'utf-8'));
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
return null;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
saveCredentials(creds) {
|
|
69
|
+
if (!fs.existsSync(this.cliDir)) {
|
|
70
|
+
fs.mkdirSync(this.cliDir, { recursive: true });
|
|
71
|
+
}
|
|
72
|
+
fs.writeFileSync(this.credentialsFile, JSON.stringify(creds, null, 2));
|
|
73
|
+
}
|
|
74
|
+
getAccessToken() {
|
|
75
|
+
if (!fs.existsSync(this.sessionFile))
|
|
76
|
+
return null;
|
|
77
|
+
try {
|
|
78
|
+
return JSON.parse(fs.readFileSync(this.sessionFile, 'utf-8'));
|
|
79
|
+
}
|
|
80
|
+
catch {
|
|
81
|
+
return null;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
saveAccessToken(session) {
|
|
85
|
+
if (!fs.existsSync(this.cliDir)) {
|
|
86
|
+
fs.mkdirSync(this.cliDir, { recursive: true });
|
|
87
|
+
}
|
|
88
|
+
fs.writeFileSync(this.sessionFile, JSON.stringify(session, null, 2), { mode: 0o600 });
|
|
89
|
+
}
|
|
90
|
+
clearAccessToken() {
|
|
91
|
+
try {
|
|
92
|
+
if (fs.existsSync(this.sessionFile)) {
|
|
93
|
+
fs.unlinkSync(this.sessionFile);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
catch { /* ignore */ }
|
|
97
|
+
}
|
|
98
|
+
clearAll() {
|
|
99
|
+
try {
|
|
100
|
+
if (fs.existsSync(this.credentialsFile))
|
|
101
|
+
fs.unlinkSync(this.credentialsFile);
|
|
102
|
+
}
|
|
103
|
+
catch { /* ignore */ }
|
|
104
|
+
this.clearAccessToken();
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
exports.SessionStore = SessionStore;
|
|
108
|
+
//# sourceMappingURL=store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/session/store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.test.d.ts","sourceRoot":"","sources":["../../src/session/store.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const fs = __importStar(require("fs"));
|
|
37
|
+
const path = __importStar(require("path"));
|
|
38
|
+
const store_1 = require("./store");
|
|
39
|
+
const TEST_DIR = path.join(process.cwd(), 'test-session-cli');
|
|
40
|
+
// Mock the CLI directory by overriding HOME
|
|
41
|
+
const originalHome = process.env.HOME;
|
|
42
|
+
beforeAll(() => {
|
|
43
|
+
process.env.HOME = TEST_DIR;
|
|
44
|
+
});
|
|
45
|
+
afterAll(() => {
|
|
46
|
+
process.env.HOME = originalHome;
|
|
47
|
+
if (fs.existsSync(TEST_DIR)) {
|
|
48
|
+
fs.rmSync(TEST_DIR, { recursive: true });
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
beforeEach(() => {
|
|
52
|
+
// Clean test directory
|
|
53
|
+
if (fs.existsSync(TEST_DIR)) {
|
|
54
|
+
fs.rmSync(TEST_DIR, { recursive: true });
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
describe('SessionStore', () => {
|
|
58
|
+
it('should return null when no credentials exist', () => {
|
|
59
|
+
const store = new store_1.SessionStore();
|
|
60
|
+
expect(store.getCredentials()).toBeNull();
|
|
61
|
+
});
|
|
62
|
+
it('should save and retrieve credentials', () => {
|
|
63
|
+
const store = new store_1.SessionStore();
|
|
64
|
+
const creds = {
|
|
65
|
+
apiKey: 'sk-bbt-test123',
|
|
66
|
+
baseUrl: 'https://platform.123456btc.com',
|
|
67
|
+
environment: 'live',
|
|
68
|
+
savedAt: new Date().toISOString(),
|
|
69
|
+
};
|
|
70
|
+
store.saveCredentials(creds);
|
|
71
|
+
expect(store.getCredentials()).toEqual(creds);
|
|
72
|
+
});
|
|
73
|
+
it('should clear all state atomically', () => {
|
|
74
|
+
const store = new store_1.SessionStore();
|
|
75
|
+
store.saveCredentials({
|
|
76
|
+
apiKey: 'sk-bbt-test123',
|
|
77
|
+
baseUrl: 'https://platform.123456btc.com',
|
|
78
|
+
environment: 'live',
|
|
79
|
+
savedAt: new Date().toISOString(),
|
|
80
|
+
});
|
|
81
|
+
store.saveAccessToken({
|
|
82
|
+
token: 'at-bbt-test',
|
|
83
|
+
expiresAt: Date.now() + 3600000,
|
|
84
|
+
scopes: ['signals:read'],
|
|
85
|
+
});
|
|
86
|
+
store.clearAll();
|
|
87
|
+
expect(store.getCredentials()).toBeNull();
|
|
88
|
+
expect(store.getAccessToken()).toBeNull();
|
|
89
|
+
});
|
|
90
|
+
it('should save and retrieve access token', () => {
|
|
91
|
+
const store = new store_1.SessionStore();
|
|
92
|
+
const session = {
|
|
93
|
+
token: 'at-bbt-test',
|
|
94
|
+
expiresAt: Date.now() + 3600000,
|
|
95
|
+
scopes: ['signals:read'],
|
|
96
|
+
};
|
|
97
|
+
store.saveAccessToken(session);
|
|
98
|
+
expect(store.getAccessToken()).toEqual(session);
|
|
99
|
+
});
|
|
100
|
+
it('should clear only access token while preserving credentials', () => {
|
|
101
|
+
const store = new store_1.SessionStore();
|
|
102
|
+
store.saveCredentials({
|
|
103
|
+
apiKey: 'sk-bbt-test123',
|
|
104
|
+
baseUrl: 'https://platform.123456btc.com',
|
|
105
|
+
environment: 'live',
|
|
106
|
+
savedAt: new Date().toISOString(),
|
|
107
|
+
});
|
|
108
|
+
store.saveAccessToken({
|
|
109
|
+
token: 'at-bbt-test',
|
|
110
|
+
expiresAt: Date.now() + 3600000,
|
|
111
|
+
scopes: ['signals:read'],
|
|
112
|
+
});
|
|
113
|
+
store.clearAccessToken();
|
|
114
|
+
expect(store.getCredentials()).not.toBeNull();
|
|
115
|
+
expect(store.getAccessToken()).toBeNull();
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
//# sourceMappingURL=store.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.test.js","sourceRoot":"","sources":["../../src/session/store.test.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/auth.d.ts
CHANGED
|
@@ -1,10 +1,7 @@
|
|
|
1
|
+
import { type Credentials } from '../session/store';
|
|
1
2
|
/**
|
|
2
3
|
* Check authentication and return credentials
|
|
3
4
|
* Exits with helpful message if not authenticated
|
|
4
5
|
*/
|
|
5
|
-
export declare function checkAuth():
|
|
6
|
-
apiKey: string;
|
|
7
|
-
baseUrl: string;
|
|
8
|
-
jwt?: string;
|
|
9
|
-
} | null;
|
|
6
|
+
export declare function checkAuth(): Credentials | null;
|
|
10
7
|
//# sourceMappingURL=auth.d.ts.map
|
package/dist/utils/auth.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/utils/auth.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/utils/auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAElE;;;GAGG;AACH,wBAAgB,SAAS,IAAI,WAAW,GAAG,IAAI,CAkB9C"}
|
package/dist/utils/auth.js
CHANGED
|
@@ -1,16 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.checkAuth = checkAuth;
|
|
4
|
-
const
|
|
4
|
+
const store_1 = require("../session/store");
|
|
5
5
|
/**
|
|
6
6
|
* Check authentication and return credentials
|
|
7
7
|
* Exits with helpful message if not authenticated
|
|
8
8
|
*/
|
|
9
9
|
function checkAuth() {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
catch (error) {
|
|
10
|
+
const store = new store_1.SessionStore();
|
|
11
|
+
const creds = store.getCredentials();
|
|
12
|
+
if (!creds) {
|
|
14
13
|
console.error('');
|
|
15
14
|
console.error('❌ Authentication required');
|
|
16
15
|
console.error('');
|
|
@@ -22,5 +21,6 @@ function checkAuth() {
|
|
|
22
21
|
console.error('');
|
|
23
22
|
process.exit(1);
|
|
24
23
|
}
|
|
24
|
+
return creds;
|
|
25
25
|
}
|
|
26
26
|
//# sourceMappingURL=auth.js.map
|
package/dist/utils/auth.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/utils/auth.ts"],"names":[],"mappings":";;AAMA,
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/utils/auth.ts"],"names":[],"mappings":";;AAMA,8BAkBC;AAxBD,4CAAkE;AAElE;;;GAGG;AACH,SAAgB,SAAS;IACvB,MAAM,KAAK,GAAG,IAAI,oBAAY,EAAE,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,CAAC,cAAc,EAAE,CAAC;IAErC,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAClB,OAAO,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;QAC3C,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAClB,OAAO,CAAC,KAAK,CAAC,+CAA+C,CAAC,CAAC;QAC/D,OAAO,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;QAC7C,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAClB,OAAO,CAAC,KAAK,CAAC,yCAAyC,CAAC,CAAC;QACzD,OAAO,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAC;QACpD,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC"}
|