Fix config endpoint

This commit is contained in:
Chocobozzz 2018-10-03 14:35:35 +02:00
parent 6a6951ec10
commit 499d901595
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
5 changed files with 28 additions and 14 deletions

View File

@ -43,7 +43,7 @@ let serverCommit: string
async function getConfig (req: express.Request, res: express.Response, next: express.NextFunction) { async function getConfig (req: express.Request, res: express.Response, next: express.NextFunction) {
const allowed = await isSignupAllowed() const allowed = await isSignupAllowed()
const allowedForCurrentIP = isSignupAllowedForCurrentIP(req.ip) const allowedForCurrentIP = isSignupAllowedForCurrentIP(req.ip)
serverCommit = (serverCommit) ? serverCommit : getVersion() serverCommit = (serverCommit) ? serverCommit : await getVersion()
if (serverCommit === packageJSON.version) serverCommit = '' if (serverCommit === packageJSON.version) serverCommit = ''
const enabledResolutions = Object.keys(CONFIG.TRANSCODING.RESOLUTIONS) const enabledResolutions = Object.keys(CONFIG.TRANSCODING.RESOLUTIONS)

View File

@ -8,9 +8,9 @@ import * as createTorrent from 'create-torrent'
import { createHash, pseudoRandomBytes } from 'crypto' import { createHash, pseudoRandomBytes } from 'crypto'
import { isAbsolute, join } from 'path' import { isAbsolute, join } from 'path'
import * as pem from 'pem' import * as pem from 'pem'
import * as rimraf from 'rimraf'
import { URL } from 'url' import { URL } from 'url'
import { truncate } from 'lodash' import { truncate } from 'lodash'
import { exec } from 'child_process'
const timeTable = { const timeTable = {
ms: 1, ms: 1,
@ -178,6 +178,8 @@ const bcryptComparePromise = promisify2<any, string, boolean>(bcrypt.compare)
const bcryptGenSaltPromise = promisify1<number, string>(bcrypt.genSalt) const bcryptGenSaltPromise = promisify1<number, string>(bcrypt.genSalt)
const bcryptHashPromise = promisify2<any, string | number, string>(bcrypt.hash) const bcryptHashPromise = promisify2<any, string | number, string>(bcrypt.hash)
const createTorrentPromise = promisify2<string, any, any>(createTorrent) const createTorrentPromise = promisify2<string, any, any>(createTorrent)
const execPromise2 = promisify2<string, any, string>(exec)
const execPromise = promisify1<string, string>(exec)
// --------------------------------------------------------------------------- // ---------------------------------------------------------------------------
@ -203,5 +205,7 @@ export {
bcryptComparePromise, bcryptComparePromise,
bcryptGenSaltPromise, bcryptGenSaltPromise,
bcryptHashPromise, bcryptHashPromise,
createTorrentPromise createTorrentPromise,
execPromise2,
execPromise
} }

View File

@ -1,7 +1,7 @@
import { ResultList } from '../../shared' import { ResultList } from '../../shared'
import { CONFIG } from '../initializers' import { CONFIG } from '../initializers'
import { ApplicationModel } from '../models/application/application' import { ApplicationModel } from '../models/application/application'
import { pseudoRandomBytesPromise, sha256 } from './core-utils' import { execPromise, execPromise2, pseudoRandomBytesPromise, sha256 } from './core-utils'
import { logger } from './logger' import { logger } from './logger'
import { join } from 'path' import { join } from 'path'
import { Instance as ParseTorrent } from 'parse-torrent' import { Instance as ParseTorrent } from 'parse-torrent'
@ -54,14 +54,25 @@ function getSecureTorrentName (originalName: string) {
return sha256(originalName) + '.torrent' return sha256(originalName) + '.torrent'
} }
function getVersion () { async function getVersion () {
const tag = require('child_process') try {
.execSync('[[ ! -d .git ]] || git name-rev --name-only --tags --no-undefined HEAD 2>/dev/null || true', { stdio: [0,1,2] }) const tag = await execPromise2(
if (tag) return tag.replace(/^v/, '') '[ ! -d .git ] || git name-rev --name-only --tags --no-undefined HEAD 2>/dev/null || true',
{ stdio: [ 0, 1, 2 ] }
)
const version = require('child_process') if (tag) return tag.replace(/^v/, '')
.execSync('[[ ! -d .git ]] || git rev-parse --short HEAD').toString().trim() } catch (err) {
if (version) return version logger.debug('Cannot get version from git tags.', { err })
}
try {
const version = await execPromise('[ ! -d .git ] || git rev-parse --short HEAD')
if (version) return version.toString().trim()
} catch (err) {
logger.debug('Cannot get version from git HEAD.', { err })
}
return require('../../../package.json').version return require('../../../package.json').version
} }

View File

@ -1,8 +1,7 @@
const config = require('application-config')('PeerTube/CLI') const config = require('application-config')('PeerTube/CLI')
const netrc = require('netrc-parser').default const netrc = require('netrc-parser').default
import { getVersion } from '../helpers/utils'
const version = getVersion const version = require('../../../package.json').version
let settings = { let settings = {
remotes: [], remotes: [],

View File

@ -7,7 +7,7 @@ import {
} from './cli' } from './cli'
program program
.version(version(), '-v, --version') .version(version, '-v, --version')
.usage('[command] [options]') .usage('[command] [options]')
/* Subcommands automatically loaded in the directory and beginning by peertube-* */ /* Subcommands automatically loaded in the directory and beginning by peertube-* */