refactor(npm-data): avoid running external npm cmd
This commit is contained in:
parent
3c72b5a92f
commit
6202321a42
2 changed files with 15 additions and 11 deletions
|
@ -186,7 +186,7 @@ void (async () => {
|
||||||
)
|
)
|
||||||
spinner.succeed('OK')
|
spinner.succeed('OK')
|
||||||
|
|
||||||
if (!(await isNpx())) {
|
if (!isNpx()) {
|
||||||
const { installed, latest, isLatest } = await getVerInfo()
|
const { installed, latest, isLatest } = await getVerInfo()
|
||||||
if (!isLatest) {
|
if (!isLatest) {
|
||||||
console.log(chalk.yellowBright(`\nYour installed version (${installed}) of the musescore-downloader CLI is not the latest one (${latest})!\nRun npm i -g musescore-downloader to update.`))
|
console.log(chalk.yellowBright(`\nYour installed version (${installed}) of the musescore-downloader CLI is not the latest one (${latest})!\nRun npm i -g musescore-downloader to update.`))
|
||||||
|
|
|
@ -1,22 +1,26 @@
|
||||||
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */
|
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */
|
||||||
|
|
||||||
import { exec as _exec } from 'child_process'
|
import { name as pkgName, version as pkgVer } from '../package.json'
|
||||||
import { promisify } from 'util'
|
import { getFetch } from './utils'
|
||||||
import { version } from '../package.json'
|
|
||||||
|
|
||||||
const exec = promisify(_exec)
|
const IS_NPX_REG = /_npx(\/|\\)\d+\1/
|
||||||
|
const NPM_REGISTRY = 'https://registry.npmjs.org'
|
||||||
|
|
||||||
export async function isNpx (): Promise<boolean> {
|
export function isNpx (): boolean {
|
||||||
const output = await exec('npm list -g musescore-downloader')
|
// file is in a npx cache dir
|
||||||
return output.stdout.includes('(empty)')
|
// TODO: installed locally?
|
||||||
|
return __dirname.match(IS_NPX_REG) !== null
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getInstalledVer (): string {
|
export function getInstalledVer (): string {
|
||||||
return version
|
return pkgVer
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getLatestVer (): Promise<string> {
|
export async function getLatestVer (_fetch = getFetch()): Promise<string> {
|
||||||
return (await exec('npm info musescore-downloader version')).stdout.trim()
|
// fetch pkg info from the npm registry
|
||||||
|
const r = await _fetch(`${NPM_REGISTRY}/${pkgName}`)
|
||||||
|
const json = await r.json()
|
||||||
|
return json['dist-tags'].latest as string
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getVerInfo () {
|
export async function getVerInfo () {
|
||||||
|
|
Loading…
Reference in a new issue