X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Flib%2Fplugins%2Fyarn.ts;h=3f45681d3f90ca839d575616681a4680b164ca23;hb=302eba0d898e38dca14739486441c27c0be6c62f;hp=35fe1625f4808001f628456759f05d6c8225d751;hpb=f023a19c3eeeea2b014b47fae522a62eab320048;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/lib/plugins/yarn.ts b/server/lib/plugins/yarn.ts index 35fe1625f..3f45681d3 100644 --- a/server/lib/plugins/yarn.ts +++ b/server/lib/plugins/yarn.ts @@ -1,17 +1,24 @@ +import { outputJSON, pathExists } from 'fs-extra' +import { join } from 'path' import { execShell } from '../../helpers/core-utils' -import { logger } from '../../helpers/logger' import { isNpmPluginNameValid, isPluginVersionValid } from '../../helpers/custom-validators/plugins' +import { logger } from '../../helpers/logger' import { CONFIG } from '../../initializers/config' -import { outputJSON, pathExists } from 'fs-extra' -import { join } from 'path' +import { getLatestPluginVersion } from './plugin-index' -async function installNpmPlugin (name: string, version: string) { +async function installNpmPlugin (npmName: string, versionArg?: string) { // Security check - checkNpmPluginNameOrThrow(name) - checkPluginVersionOrThrow(version) + checkNpmPluginNameOrThrow(npmName) + if (versionArg) checkPluginVersionOrThrow(versionArg) + + const version = versionArg || await getLatestPluginVersion(npmName) + + let toInstall = npmName + if (version) toInstall += `@${version}` + + const { stdout } = await execYarn('add ' + toInstall) - const toInstall = `${name}@${version}` - await execYarn('add ' + toInstall) + logger.debug('Added a yarn package.', { yarnStdout: stdout }) } async function installNpmPluginFromDisk (path: string) { @@ -44,7 +51,7 @@ async function execYarn (command: string) { await outputJSON(pluginPackageJSON, {}) } - await execShell(`yarn ${command}`, { cwd: pluginDirectory }) + return execShell(`yarn ${command}`, { cwd: pluginDirectory }) } catch (result) { logger.error('Cannot exec yarn.', { command, err: result.err, stderr: result.stderr })