@bolta-io/cli 0.0.4 → 0.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/bin/bolta.js CHANGED
@@ -6,7 +6,10 @@ import { registerInvoiceCommands } from '../src/commands/invoice/index.js';
6
6
  import { registerConfigCommands } from '../src/commands/config/index.js';
7
7
  import { registerExamplesCommand } from '../src/commands/examples/index.js';
8
8
  import { registerSchemaCommand } from '../src/commands/schema/index.js';
9
+ import { registerUpdateCommands } from '../src/commands/update/index.js';
9
10
  import { outputError } from '../src/utils/output.js';
11
+ import { getCurrentVersion, fetchLatestVersion, isUpdateAvailable } from '../src/utils/version.js';
12
+ import { loadConfig, saveConfig } from '../src/config/config-manager.js';
10
13
  const program = new Command();
11
14
  program
12
15
  .name('bolta')
@@ -16,11 +19,12 @@ program
16
19
  .option('--customer-key <key>', 'Customer Key (환경변수 BOLTA_CUSTOMER_KEY 대체)')
17
20
  .option('--verbose', '상세 로그 출력 (stderr)', false)
18
21
  .option('--dry-run', 'API 호출 없이 요청 데이터만 출력', false)
19
- .hook('preAction', (thisCommand) => {
22
+ .hook('preAction', (thisCommand, actionCommand) => {
20
23
  const opts = thisCommand.optsWithGlobals();
21
24
  if (opts.verbose) {
22
25
  process.env.BOLTA_VERBOSE = '1';
23
26
  }
27
+ checkForUpdateInBackground(actionCommand);
24
28
  });
25
29
  registerCustomerCommands(program);
26
30
  registerCertificateCommands(program);
@@ -28,6 +32,36 @@ registerInvoiceCommands(program);
28
32
  registerConfigCommands(program);
29
33
  registerExamplesCommand(program);
30
34
  registerSchemaCommand(program);
35
+ registerUpdateCommands(program);
36
+ const ONE_DAY_MS = 24 * 60 * 60 * 1000;
37
+ function checkForUpdateInBackground(actionCommand) {
38
+ // update 커맨드 자체에서는 중복 확인 안 함
39
+ if (actionCommand.name() === 'update' || actionCommand.parent?.name() === 'update')
40
+ return;
41
+ const config = loadConfig();
42
+ const now = Date.now();
43
+ const lastCheck = config.lastUpdateCheck || 0;
44
+ // 캐시된 결과가 있고 24시간 이내이면 캐시 사용
45
+ if (now - lastCheck < ONE_DAY_MS) {
46
+ if (config.latestKnownVersion && isUpdateAvailable(getCurrentVersion(), config.latestKnownVersion)) {
47
+ console.error(`\n[bolta] 새 버전 v${config.latestKnownVersion}이 있습니다. 'bolta update'로 업데이트하세요.\n`);
48
+ }
49
+ return;
50
+ }
51
+ // 비동기로 최신 버전 확인 (fire-and-forget)
52
+ fetchLatestVersion()
53
+ .then((latest) => {
54
+ config.lastUpdateCheck = now;
55
+ config.latestKnownVersion = latest.version;
56
+ saveConfig(config);
57
+ if (isUpdateAvailable(getCurrentVersion(), latest.version)) {
58
+ console.error(`\n[bolta] 새 버전 v${latest.version}이 있습니다. 'bolta update'로 업데이트하세요.\n`);
59
+ }
60
+ })
61
+ .catch(() => {
62
+ // 네트워크 실패는 무시
63
+ });
64
+ }
31
65
  program.parseAsync(process.argv).catch((err) => {
32
66
  outputError(err);
33
67
  });
@@ -1 +1 @@
1
- {"version":3,"file":"bolta.js","sourceRoot":"","sources":["../../bin/bolta.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAC7E,OAAO,EAAE,2BAA2B,EAAE,MAAM,sCAAsC,CAAC;AACnF,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AACzE,OAAO,EAAE,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AAC5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;AAE9B,OAAO;KACJ,IAAI,CAAC,OAAO,CAAC;KACb,WAAW,CAAC,mDAAmD,CAAC;KAChE,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,OAAO,CAAC;KACjD,MAAM,CAAC,iBAAiB,EAAE,qCAAqC,CAAC;KAChE,MAAM,CAAC,sBAAsB,EAAE,2CAA2C,CAAC;KAC3E,MAAM,CAAC,WAAW,EAAE,mBAAmB,EAAE,KAAK,CAAC;KAC/C,MAAM,CAAC,WAAW,EAAE,sBAAsB,EAAE,KAAK,CAAC;KAClD,IAAI,CAAC,WAAW,EAAE,CAAC,WAAW,EAAE,EAAE;IACjC,MAAM,IAAI,GAAG,WAAW,CAAC,eAAe,EAAE,CAAC;IAC3C,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,OAAO,CAAC,GAAG,CAAC,aAAa,GAAG,GAAG,CAAC;IAClC,CAAC;AACH,CAAC,CAAC,CAAC;AAEL,wBAAwB,CAAC,OAAO,CAAC,CAAC;AAClC,2BAA2B,CAAC,OAAO,CAAC,CAAC;AACrC,uBAAuB,CAAC,OAAO,CAAC,CAAC;AACjC,sBAAsB,CAAC,OAAO,CAAC,CAAC;AAChC,uBAAuB,CAAC,OAAO,CAAC,CAAC;AACjC,qBAAqB,CAAC,OAAO,CAAC,CAAC;AAE/B,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;IAC7C,WAAW,CAAC,GAAG,CAAC,CAAC;AACnB,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"bolta.js","sourceRoot":"","sources":["../../bin/bolta.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { Command } from 'commander';
2
+ export declare function registerUpdateCommands(program: Command): void;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/commands/update/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIzC,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAyB7D"}
@@ -0,0 +1,30 @@
1
+ import { checkUpdate, performUpdate } from './updater.js';
2
+ import { outputSuccess, outputError } from '../../utils/output.js';
3
+ export function registerUpdateCommands(program) {
4
+ const update = program
5
+ .command('update')
6
+ .description('CLI를 최신 버전으로 업데이트')
7
+ .option('--force', '같은 버전이라도 강제 업데이트', false)
8
+ .action(async (options) => {
9
+ try {
10
+ const result = await performUpdate(options.force);
11
+ outputSuccess(result);
12
+ }
13
+ catch (err) {
14
+ outputError(err);
15
+ }
16
+ });
17
+ update
18
+ .command('check')
19
+ .description('업데이트 가능 여부 확인')
20
+ .action(async () => {
21
+ try {
22
+ const result = await checkUpdate();
23
+ outputSuccess(result);
24
+ }
25
+ catch (err) {
26
+ outputError(err);
27
+ }
28
+ });
29
+ }
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/commands/update/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEnE,MAAM,UAAU,sBAAsB,CAAC,OAAgB;IACrD,MAAM,MAAM,GAAG,OAAO;SACnB,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,mBAAmB,CAAC;SAChC,MAAM,CAAC,SAAS,EAAE,kBAAkB,EAAE,KAAK,CAAC;SAC5C,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAClD,aAAa,CAAC,MAAM,CAAC,CAAC;QACxB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,MAAM;SACH,OAAO,CAAC,OAAO,CAAC;SAChB,WAAW,CAAC,eAAe,CAAC;SAC5B,MAAM,CAAC,KAAK,IAAI,EAAE;QACjB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,WAAW,EAAE,CAAC;YACnC,aAAa,CAAC,MAAM,CAAC,CAAC;QACxB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,16 @@
1
+ export interface UpdateResult {
2
+ previousVersion: string;
3
+ currentVersion: string;
4
+ message: string;
5
+ }
6
+ export interface CheckResult {
7
+ currentVersion: string;
8
+ latestVersion: string;
9
+ updateAvailable: boolean;
10
+ installMethod: string;
11
+ updateCommand: string;
12
+ changelog?: string;
13
+ }
14
+ export declare function checkUpdate(): Promise<CheckResult>;
15
+ export declare function performUpdate(force?: boolean): Promise<UpdateResult>;
16
+ //# sourceMappingURL=updater.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"updater.d.ts","sourceRoot":"","sources":["../../../../src/commands/update/updater.ts"],"names":[],"mappings":"AA8BA,MAAM,WAAW,YAAY;IAC3B,eAAe,EAAE,MAAM,CAAC;IACxB,cAAc,EAAE,MAAM,CAAC;IACvB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,WAAW;IAC1B,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,OAAO,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAsB,WAAW,IAAI,OAAO,CAAC,WAAW,CAAC,CA4BxD;AAED,wBAAsB,aAAa,CAAC,KAAK,GAAE,OAAe,GAAG,OAAO,CAAC,YAAY,CAAC,CA6FjF"}
@@ -0,0 +1,177 @@
1
+ import { createHash } from 'node:crypto';
2
+ import { accessSync, chmodSync, constants, copyFileSync, createReadStream, mkdtempSync, renameSync, rmSync, unlinkSync, } from 'node:fs';
3
+ import { tmpdir } from 'node:os';
4
+ import { dirname, join } from 'node:path';
5
+ import { execSync } from 'node:child_process';
6
+ import { pipeline } from 'node:stream/promises';
7
+ import { createWriteStream } from 'node:fs';
8
+ import { Readable } from 'node:stream';
9
+ import { detectInstallMethod, detectPlatform } from '../../utils/platform.js';
10
+ import { fetchLatestVersion, getCurrentVersion, isUpdateAvailable, } from '../../utils/version.js';
11
+ import { BoltaUpdateError } from '../../utils/errors.js';
12
+ import { verbose } from '../../utils/output.js';
13
+ export async function checkUpdate() {
14
+ const currentVersion = getCurrentVersion();
15
+ const installMethod = detectInstallMethod();
16
+ const latest = await fetchLatestVersion();
17
+ const updateAvailable = isUpdateAvailable(currentVersion, latest.version);
18
+ let updateCommand;
19
+ switch (installMethod) {
20
+ case 'homebrew':
21
+ updateCommand = 'brew upgrade bolta';
22
+ break;
23
+ case 'npm':
24
+ updateCommand = 'npm update -g @bolta-io/cli';
25
+ break;
26
+ default:
27
+ updateCommand = 'bolta update';
28
+ break;
29
+ }
30
+ return {
31
+ currentVersion,
32
+ latestVersion: latest.version,
33
+ updateAvailable,
34
+ installMethod,
35
+ updateCommand,
36
+ changelog: latest.changelog,
37
+ };
38
+ }
39
+ export async function performUpdate(force = false) {
40
+ const installMethod = detectInstallMethod();
41
+ // Homebrew/npm 설치인 경우 해당 패키지 매니저 안내
42
+ if (installMethod === 'homebrew') {
43
+ throw new BoltaUpdateError('Homebrew로 설치된 bolta는 직접 업데이트할 수 없습니다.', "'brew upgrade bolta' 명령을 사용하세요.");
44
+ }
45
+ if (installMethod === 'npm') {
46
+ throw new BoltaUpdateError('npm으로 설치된 bolta는 직접 업데이트할 수 없습니다.', "'npm update -g @bolta-io/cli' 명령을 사용하세요.");
47
+ }
48
+ const currentVersion = getCurrentVersion();
49
+ const latest = await fetchLatestVersion();
50
+ if (!force && !isUpdateAvailable(currentVersion, latest.version)) {
51
+ return {
52
+ previousVersion: currentVersion,
53
+ currentVersion: currentVersion,
54
+ message: '이미 최신 버전입니다.',
55
+ };
56
+ }
57
+ const platform = detectPlatform();
58
+ verbose(`플랫폼 감지: ${platform.target}`);
59
+ // 쓰기 권한 확인
60
+ const binaryPath = process.execPath;
61
+ const binaryDir = dirname(binaryPath);
62
+ try {
63
+ accessSync(binaryDir, constants.W_OK);
64
+ }
65
+ catch {
66
+ throw new BoltaUpdateError(`${binaryDir} 디렉토리에 쓰기 권한이 없습니다.`, "'sudo bolta update' 명령을 사용하세요.");
67
+ }
68
+ // 임시 디렉토리에 다운로드
69
+ const tmpDir = mkdtempSync(join(tmpdir(), 'bolta-update-'));
70
+ try {
71
+ const archivePath = join(tmpDir, platform.archiveName);
72
+ const downloadUrl = `https://cli.boltacorp.com/releases/v${latest.version}/${platform.archiveName}`;
73
+ verbose(`다운로드 URL: ${downloadUrl}`);
74
+ await downloadFile(downloadUrl, archivePath);
75
+ // 체크섬 검증
76
+ if (latest.checksums[platform.target]) {
77
+ verbose('체크섬 검증 중...');
78
+ const actualHash = await computeSha256(archivePath);
79
+ const expectedHash = latest.checksums[platform.target];
80
+ if (actualHash !== expectedHash) {
81
+ throw new BoltaUpdateError(`체크섬 불일치: 예상=${expectedHash}, 실제=${actualHash}`, '다운로드한 파일이 손상되었을 수 있습니다. 다시 시도하세요.');
82
+ }
83
+ verbose('체크섬 검증 완료');
84
+ }
85
+ else {
86
+ verbose('체크섬 정보 없음 (GitHub fallback), 검증 건너뜀');
87
+ }
88
+ // 아카이브 추출
89
+ verbose('아카이브 추출 중...');
90
+ extractArchive(archivePath, tmpDir, platform.platform === 'windows');
91
+ // 바이너리 교체
92
+ const newBinaryPath = join(tmpDir, platform.binaryName);
93
+ verbose(`바이너리 교체: ${newBinaryPath} → ${binaryPath}`);
94
+ await replaceBinary(newBinaryPath, binaryPath);
95
+ return {
96
+ previousVersion: currentVersion,
97
+ currentVersion: latest.version,
98
+ message: `bolta가 v${latest.version}으로 업데이트되었습니다.`,
99
+ };
100
+ }
101
+ finally {
102
+ // 임시 디렉토리 정리
103
+ try {
104
+ rmSync(tmpDir, { recursive: true, force: true });
105
+ }
106
+ catch {
107
+ // 무시
108
+ }
109
+ }
110
+ }
111
+ async function downloadFile(url, dest) {
112
+ const res = await fetch(url, { signal: AbortSignal.timeout(60000) });
113
+ if (!res.ok) {
114
+ throw new BoltaUpdateError(`다운로드 실패 (HTTP ${res.status}): ${url}`, '네트워크 연결을 확인하고 다시 시도하세요.');
115
+ }
116
+ if (!res.body) {
117
+ throw new BoltaUpdateError('다운로드 응답 본문이 비어있습니다.');
118
+ }
119
+ const fileStream = createWriteStream(dest);
120
+ await pipeline(Readable.fromWeb(res.body), fileStream);
121
+ }
122
+ async function computeSha256(filePath) {
123
+ return new Promise((resolve, reject) => {
124
+ const hash = createHash('sha256');
125
+ const stream = createReadStream(filePath);
126
+ stream.on('data', (chunk) => hash.update(chunk));
127
+ stream.on('end', () => resolve(hash.digest('hex')));
128
+ stream.on('error', reject);
129
+ });
130
+ }
131
+ function extractArchive(archivePath, destDir, isWindows) {
132
+ if (isWindows) {
133
+ execSync(`powershell -NoProfile -Command "Expand-Archive -Path '${archivePath}' -DestinationPath '${destDir}' -Force"`, { stdio: 'pipe' });
134
+ }
135
+ else {
136
+ execSync(`tar -xzf "${archivePath}" -C "${destDir}"`, { stdio: 'pipe' });
137
+ }
138
+ }
139
+ async function replaceBinary(newBinaryPath, currentBinaryPath) {
140
+ const targetDir = dirname(currentBinaryPath);
141
+ const tempInPlace = join(targetDir, `.bolta-update-${Date.now()}`);
142
+ const backupPath = currentBinaryPath + '.bak';
143
+ // 새 바이너리를 같은 디렉토리로 복사 (크로스-디바이스 방지)
144
+ copyFileSync(newBinaryPath, tempInPlace);
145
+ // 현재 바이너리를 백업
146
+ renameSync(currentBinaryPath, backupPath);
147
+ try {
148
+ // 새 바이너리를 원래 위치로 이동
149
+ renameSync(tempInPlace, currentBinaryPath);
150
+ chmodSync(currentBinaryPath, 0o755);
151
+ // 백업 삭제
152
+ try {
153
+ unlinkSync(backupPath);
154
+ }
155
+ catch {
156
+ // Windows에서는 실행 중인 바이너리 삭제 불가 - 다음 실행 시 정리
157
+ }
158
+ }
159
+ catch (err) {
160
+ // 롤백
161
+ try {
162
+ renameSync(backupPath, currentBinaryPath);
163
+ }
164
+ catch {
165
+ throw new BoltaUpdateError('바이너리 교체 중 오류가 발생했고 롤백에도 실패했습니다.', `'${backupPath}' 파일을 '${currentBinaryPath}'로 수동으로 이동하세요.`);
166
+ }
167
+ // 임시 파일 정리
168
+ try {
169
+ unlinkSync(tempInPlace);
170
+ }
171
+ catch {
172
+ // 무시
173
+ }
174
+ throw err;
175
+ }
176
+ }
177
+ //# sourceMappingURL=updater.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"updater.js","sourceRoot":"","sources":["../../../../src/commands/update/updater.ts"],"names":[],"mappings":"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"}
@@ -113,6 +113,8 @@ export interface BoltaConfig {
113
113
  baseUrl?: string;
114
114
  timeout?: number;
115
115
  maxRetries?: number;
116
+ lastUpdateCheck?: number;
117
+ latestKnownVersion?: string;
116
118
  }
117
119
  export interface GlobalOptions {
118
120
  json?: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../../src/types/api.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../../src/types/api.ts"],"names":[],"mappings":"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"}
@@ -20,4 +20,7 @@ export declare class BoltaInputError extends BoltaError {
20
20
  export declare class BoltaNetworkError extends BoltaError {
21
21
  constructor(message: string);
22
22
  }
23
+ export declare class BoltaUpdateError extends BoltaError {
24
+ constructor(message: string, suggestion?: string);
25
+ }
23
26
  //# sourceMappingURL=errors.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../src/utils/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,UAAW,SAAQ,KAAK;IAG1B,IAAI,EAAE,MAAM;IACZ,UAAU,CAAC,EAAE,MAAM;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;gBAHxC,OAAO,EAAE,MAAM,EACR,IAAI,EAAE,MAAM,EACZ,UAAU,CAAC,EAAE,MAAM,YAAA,EACnB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,YAAA;CAK3C;AAED,qBAAa,aAAc,SAAQ,UAAU;IAIlC,UAAU,EAAE,MAAM;gBAFzB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,EACL,UAAU,EAAE,MAAM,EACzB,UAAU,CAAC,EAAE,MAAM,EACnB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAKpC;AAED,qBAAa,oBAAqB,SAAQ,UAAU;gBACtC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAI/D;AAED,qBAAa,cAAe,SAAQ,UAAU;gBAChC,OAAO,EAAE,MAAM;CAQ5B;AAED,qBAAa,eAAgB,SAAQ,UAAU;gBACjC,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,iBAAkB,SAAQ,UAAU;gBACnC,OAAO,EAAE,MAAM;CAI5B"}
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../src/utils/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,UAAW,SAAQ,KAAK;IAG1B,IAAI,EAAE,MAAM;IACZ,UAAU,CAAC,EAAE,MAAM;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;gBAHxC,OAAO,EAAE,MAAM,EACR,IAAI,EAAE,MAAM,EACZ,UAAU,CAAC,EAAE,MAAM,YAAA,EACnB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,YAAA;CAK3C;AAED,qBAAa,aAAc,SAAQ,UAAU;IAIlC,UAAU,EAAE,MAAM;gBAFzB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,EACL,UAAU,EAAE,MAAM,EACzB,UAAU,CAAC,EAAE,MAAM,EACnB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAKpC;AAED,qBAAa,oBAAqB,SAAQ,UAAU;gBACtC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAI/D;AAED,qBAAa,cAAe,SAAQ,UAAU;gBAChC,OAAO,EAAE,MAAM;CAQ5B;AAED,qBAAa,eAAgB,SAAQ,UAAU;gBACjC,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,iBAAkB,SAAQ,UAAU;gBACnC,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,gBAAiB,SAAQ,UAAU;gBAClC,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM;CAIjD"}
@@ -42,4 +42,10 @@ export class BoltaNetworkError extends BoltaError {
42
42
  this.name = 'BoltaNetworkError';
43
43
  }
44
44
  }
45
+ export class BoltaUpdateError extends BoltaError {
46
+ constructor(message, suggestion) {
47
+ super(message, 'UPDATE_ERROR', suggestion || "'bolta update check'로 상태를 확인하세요.");
48
+ this.name = 'BoltaUpdateError';
49
+ }
50
+ }
45
51
  //# sourceMappingURL=errors.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../../src/utils/errors.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,UAAW,SAAQ,KAAK;IAG1B;IACA;IACA;IAJT,YACE,OAAe,EACR,IAAY,EACZ,UAAmB,EACnB,OAAiC;QAExC,KAAK,CAAC,OAAO,CAAC,CAAC;QAJR,SAAI,GAAJ,IAAI,CAAQ;QACZ,eAAU,GAAV,UAAU,CAAS;QACnB,YAAO,GAAP,OAAO,CAA0B;QAGxC,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;IAC3B,CAAC;CACF;AAED,MAAM,OAAO,aAAc,SAAQ,UAAU;IAIlC;IAHT,YACE,OAAe,EACf,IAAY,EACL,UAAkB,EACzB,UAAmB,EACnB,OAAiC;QAEjC,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;QAJnC,eAAU,GAAV,UAAU,CAAQ;QAKzB,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;IAC9B,CAAC;CACF;AAED,MAAM,OAAO,oBAAqB,SAAQ,UAAU;IAClD,YAAY,OAAe,EAAE,OAAiC;QAC5D,KAAK,CAAC,OAAO,EAAE,kBAAkB,EAAE,yDAAyD,EAAE,OAAO,CAAC,CAAC;QACvG,IAAI,CAAC,IAAI,GAAG,sBAAsB,CAAC;IACrC,CAAC;CACF;AAED,MAAM,OAAO,cAAe,SAAQ,UAAU;IAC5C,YAAY,OAAe;QACzB,KAAK,CACH,OAAO,EACP,YAAY,EACZ,uEAAuE,CACxE,CAAC;QACF,IAAI,CAAC,IAAI,GAAG,gBAAgB,CAAC;IAC/B,CAAC;CACF;AAED,MAAM,OAAO,eAAgB,SAAQ,UAAU;IAC7C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,EAAE,aAAa,EAAE,qDAAqD,CAAC,CAAC;QACrF,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC;IAChC,CAAC;CACF;AAED,MAAM,OAAO,iBAAkB,SAAQ,UAAU;IAC/C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,EAAE,eAAe,EAAE,6DAA6D,CAAC,CAAC;QAC/F,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC;IAClC,CAAC;CACF"}
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../../src/utils/errors.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,UAAW,SAAQ,KAAK;IAG1B;IACA;IACA;IAJT,YACE,OAAe,EACR,IAAY,EACZ,UAAmB,EACnB,OAAiC;QAExC,KAAK,CAAC,OAAO,CAAC,CAAC;QAJR,SAAI,GAAJ,IAAI,CAAQ;QACZ,eAAU,GAAV,UAAU,CAAS;QACnB,YAAO,GAAP,OAAO,CAA0B;QAGxC,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;IAC3B,CAAC;CACF;AAED,MAAM,OAAO,aAAc,SAAQ,UAAU;IAIlC;IAHT,YACE,OAAe,EACf,IAAY,EACL,UAAkB,EACzB,UAAmB,EACnB,OAAiC;QAEjC,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;QAJnC,eAAU,GAAV,UAAU,CAAQ;QAKzB,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;IAC9B,CAAC;CACF;AAED,MAAM,OAAO,oBAAqB,SAAQ,UAAU;IAClD,YAAY,OAAe,EAAE,OAAiC;QAC5D,KAAK,CAAC,OAAO,EAAE,kBAAkB,EAAE,yDAAyD,EAAE,OAAO,CAAC,CAAC;QACvG,IAAI,CAAC,IAAI,GAAG,sBAAsB,CAAC;IACrC,CAAC;CACF;AAED,MAAM,OAAO,cAAe,SAAQ,UAAU;IAC5C,YAAY,OAAe;QACzB,KAAK,CACH,OAAO,EACP,YAAY,EACZ,uEAAuE,CACxE,CAAC;QACF,IAAI,CAAC,IAAI,GAAG,gBAAgB,CAAC;IAC/B,CAAC;CACF;AAED,MAAM,OAAO,eAAgB,SAAQ,UAAU;IAC7C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,EAAE,aAAa,EAAE,qDAAqD,CAAC,CAAC;QACrF,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC;IAChC,CAAC;CACF;AAED,MAAM,OAAO,iBAAkB,SAAQ,UAAU;IAC/C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,EAAE,eAAe,EAAE,6DAA6D,CAAC,CAAC;QAC/F,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC;IAClC,CAAC;CACF;AAED,MAAM,OAAO,gBAAiB,SAAQ,UAAU;IAC9C,YAAY,OAAe,EAAE,UAAmB;QAC9C,KAAK,CAAC,OAAO,EAAE,cAAc,EAAE,UAAU,IAAI,kCAAkC,CAAC,CAAC;QACjF,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAC;IACjC,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ export interface PlatformInfo {
2
+ platform: string;
3
+ arch: string;
4
+ target: string;
5
+ archiveName: string;
6
+ binaryName: string;
7
+ }
8
+ export type InstallMethod = 'sea' | 'homebrew' | 'npm' | 'unknown';
9
+ export declare function detectPlatform(): PlatformInfo;
10
+ export declare function detectInstallMethod(): InstallMethod;
11
+ //# sourceMappingURL=platform.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"platform.d.ts","sourceRoot":"","sources":["../../../src/utils/platform.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,YAAY;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,UAAU,GAAG,KAAK,GAAG,SAAS,CAAC;AAanE,wBAAgB,cAAc,IAAI,YAAY,CAc7C;AAED,wBAAgB,mBAAmB,IAAI,aAAa,CA0BnD"}
@@ -0,0 +1,44 @@
1
+ import { basename } from 'node:path';
2
+ const PLATFORM_MAP = {
3
+ darwin: 'darwin',
4
+ linux: 'linux',
5
+ win32: 'windows',
6
+ };
7
+ const ARCH_MAP = {
8
+ arm64: 'arm64',
9
+ x64: 'x64',
10
+ };
11
+ export function detectPlatform() {
12
+ const platform = PLATFORM_MAP[process.platform];
13
+ const arch = ARCH_MAP[process.arch];
14
+ if (!platform || !arch) {
15
+ throw new Error(`지원하지 않는 플랫폼입니다: ${process.platform}-${process.arch}`);
16
+ }
17
+ const target = `${platform}-${arch}`;
18
+ const isWindows = platform === 'windows';
19
+ const binaryName = isWindows ? `bolta-${target}.exe` : `bolta-${target}`;
20
+ const archiveName = isWindows ? `bolta-${target}.zip` : `bolta-${target}.tar.gz`;
21
+ return { platform, arch, target, archiveName, binaryName };
22
+ }
23
+ export function detectInstallMethod() {
24
+ const execPath = process.execPath.toLowerCase();
25
+ // Homebrew
26
+ if (execPath.includes('/cellar/') || execPath.includes('/homebrew/')) {
27
+ return 'homebrew';
28
+ }
29
+ // npm: process.argv[1]이 .js로 끝나거나 node_modules 포함
30
+ const scriptPath = (process.argv[1] || '').toLowerCase();
31
+ if (scriptPath.endsWith('.js') ||
32
+ scriptPath.endsWith('.mjs') ||
33
+ scriptPath.endsWith('.cjs') ||
34
+ scriptPath.includes('node_modules')) {
35
+ return 'npm';
36
+ }
37
+ // SEA 바이너리: execPath 자체가 bolta
38
+ const bin = basename(execPath).toLowerCase();
39
+ if (bin.startsWith('bolta')) {
40
+ return 'sea';
41
+ }
42
+ return 'unknown';
43
+ }
44
+ //# sourceMappingURL=platform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"platform.js","sourceRoot":"","sources":["../../../src/utils/platform.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAYrC,MAAM,YAAY,GAA2B;IAC3C,MAAM,EAAE,QAAQ;IAChB,KAAK,EAAE,OAAO;IACd,KAAK,EAAE,SAAS;CACjB,CAAC;AAEF,MAAM,QAAQ,GAA2B;IACvC,KAAK,EAAE,OAAO;IACd,GAAG,EAAE,KAAK;CACX,CAAC;AAEF,MAAM,UAAU,cAAc;IAC5B,MAAM,QAAQ,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAChD,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,mBAAmB,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IACzE,CAAC;IAED,MAAM,MAAM,GAAG,GAAG,QAAQ,IAAI,IAAI,EAAE,CAAC;IACrC,MAAM,SAAS,GAAG,QAAQ,KAAK,SAAS,CAAC;IACzC,MAAM,UAAU,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS,MAAM,MAAM,CAAC,CAAC,CAAC,SAAS,MAAM,EAAE,CAAC;IACzE,MAAM,WAAW,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS,MAAM,MAAM,CAAC,CAAC,CAAC,SAAS,MAAM,SAAS,CAAC;IAEjF,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC;AAC7D,CAAC;AAED,MAAM,UAAU,mBAAmB;IACjC,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAEhD,WAAW;IACX,IAAI,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;QACrE,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,kDAAkD;IAClD,MAAM,UAAU,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;IACzD,IACE,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC;QAC1B,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC;QAC3B,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC;QAC3B,UAAU,CAAC,QAAQ,CAAC,cAAc,CAAC,EACnC,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,+BAA+B;IAC/B,MAAM,GAAG,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;IAC7C,IAAI,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { z } from 'zod';
2
+ declare const latestVersionInfoSchema: z.ZodObject<{
3
+ version: z.ZodString;
4
+ releasedAt: z.ZodString;
5
+ checksums: z.ZodRecord<z.ZodString, z.ZodString>;
6
+ changelog: z.ZodString;
7
+ }, "strip", z.ZodTypeAny, {
8
+ version: string;
9
+ releasedAt: string;
10
+ checksums: Record<string, string>;
11
+ changelog: string;
12
+ }, {
13
+ version: string;
14
+ releasedAt: string;
15
+ checksums: Record<string, string>;
16
+ changelog: string;
17
+ }>;
18
+ export type LatestVersionInfo = z.infer<typeof latestVersionInfoSchema>;
19
+ export declare function getCurrentVersion(): string;
20
+ export declare function fetchLatestVersion(): Promise<LatestVersionInfo>;
21
+ export declare function isUpdateAvailable(current: string, latest: string): boolean;
22
+ export {};
23
+ //# sourceMappingURL=version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/utils/version.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,QAAA,MAAM,uBAAuB;;;;;;;;;;;;;;;EAK3B,CAAC;AAEH,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,uBAAuB,CAAC,CAAC;AAWxE,wBAAgB,iBAAiB,IAAI,MAAM,CAE1C;AAED,wBAAsB,kBAAkB,IAAI,OAAO,CAAC,iBAAiB,CAAC,CAgCrE;AAED,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAE1E"}
@@ -0,0 +1,62 @@
1
+ import { z } from 'zod';
2
+ const latestVersionInfoSchema = z.object({
3
+ version: z.string(),
4
+ releasedAt: z.string(),
5
+ checksums: z.record(z.string()),
6
+ changelog: z.string(),
7
+ });
8
+ const githubReleaseSchema = z.object({
9
+ tag_name: z.string(),
10
+ published_at: z.string(),
11
+ html_url: z.string(),
12
+ });
13
+ const LATEST_JSON_URL = 'https://cli.boltacorp.com/releases/latest.json';
14
+ const GITHUB_RELEASES_URL = 'https://api.github.com/repos/bolta-io/bolta-cli/releases/latest';
15
+ export function getCurrentVersion() {
16
+ return process.env.BOLTA_CLI_VERSION || '0.1.0';
17
+ }
18
+ export async function fetchLatestVersion() {
19
+ // 1차: CloudFront latest.json
20
+ try {
21
+ const res = await fetch(LATEST_JSON_URL, {
22
+ signal: AbortSignal.timeout(5000),
23
+ });
24
+ if (res.ok) {
25
+ return latestVersionInfoSchema.parse(await res.json());
26
+ }
27
+ }
28
+ catch {
29
+ // fallback to GitHub
30
+ }
31
+ // 2차: GitHub Releases API
32
+ const res = await fetch(GITHUB_RELEASES_URL, {
33
+ signal: AbortSignal.timeout(5000),
34
+ headers: { Accept: 'application/vnd.github.v3+json' },
35
+ });
36
+ if (!res.ok) {
37
+ throw new Error(`최신 버전 정보를 가져올 수 없습니다 (HTTP ${res.status})`);
38
+ }
39
+ const data = githubReleaseSchema.parse(await res.json());
40
+ const version = data.tag_name.replace(/^v/, '');
41
+ return {
42
+ version,
43
+ releasedAt: data.published_at,
44
+ checksums: {},
45
+ changelog: data.html_url,
46
+ };
47
+ }
48
+ export function isUpdateAvailable(current, latest) {
49
+ return compareSemver(current, latest) < 0;
50
+ }
51
+ function compareSemver(a, b) {
52
+ const pa = a.split('.').map(Number);
53
+ const pb = b.split('.').map(Number);
54
+ for (let i = 0; i < 3; i++) {
55
+ const va = pa[i] || 0;
56
+ const vb = pb[i] || 0;
57
+ if (va !== vb)
58
+ return va - vb;
59
+ }
60
+ return 0;
61
+ }
62
+ //# sourceMappingURL=version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/utils/version.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bolta-io/cli",
3
- "version": "0.0.4",
3
+ "version": "0.0.5",
4
4
  "description": "Bolta API CLI for Korean electronic tax invoices (전자세금계산서)",
5
5
  "type": "module",
6
6
  "bin": {