+import { Command } from 'commander'
import { Netrc } from 'netrc-parser'
-import { getAppNumber, isTestInstance } from '../helpers/core-utils'
import { join } from 'path'
-import { root } from '../../shared/extra-utils/miscs/miscs'
-import { getVideoChannel } from '../../shared/extra-utils/videos/video-channels'
-import { CommanderStatic } from 'commander'
-import { VideoChannel, VideoPrivacy } from '../../shared/models/videos'
import { createLogger, format, transports } from 'winston'
-import { getMyUserInformation } from '@shared/extra-utils/users/users'
-import { User, UserRole } from '@shared/models'
-import { getAccessToken } from '@shared/extra-utils/users/login'
+import { loadLanguages } from '@server/initializers/constants'
+import { root } from '@shared/core-utils'
+import { UserRole } from '@shared/models'
+import { PeerTubeServer } from '@shared/server-commands'
+import { VideoPrivacy } from '../../shared/models/videos'
+import { getAppNumber, isTestInstance } from '../helpers/core-utils'
let configName = 'PeerTube/CLI'
if (isTestInstance()) configName += `-${getAppNumber()}`
const config = require('application-config')(configName)
-const version = require('../../../package.json').version
+const version = require(join(root(), 'package.json')).version
-async function getAdminTokenOrDie (url: string, username: string, password: string) {
- const accessToken = await getAccessToken(url, username, password)
- const resMe = await getMyUserInformation(url, accessToken)
- const me: User = resMe.body
+async function getAdminTokenOrDie (server: PeerTubeServer, username: string, password: string) {
+ const token = await server.login.getAccessToken(username, password)
+ const me = await server.users.getMyInfo({ token })
if (me.role !== UserRole.ADMINISTRATOR) {
console.error('You must be an administrator.')
process.exit(-1)
}
- return accessToken
+ return token
}
interface Settings {
}
function getRemoteObjectOrDie (
- program: CommanderStatic,
+ program: Command,
settings: Settings,
netrc: Netrc
): { url: string, username: string, password: string } {
const options = program.opts()
- if (!options.url || !options.username || !options.password) {
- // No remote and we don't have program parameters: quit
- if (settings.remotes.length === 0 || Object.keys(netrc.machines).length === 0) {
- if (!options.url) console.error('--url field is required.')
- if (!options.username) console.error('--username field is required.')
- if (!options.password) console.error('--password field is required.')
+ function exitIfNoOptions (optionNames: string[], errorPrefix: string = '') {
+ let exit = false
- return process.exit(-1)
- }
+ for (const key of optionNames) {
+ if (!options[key]) {
+ if (exit === false && errorPrefix) console.error(errorPrefix)
- let url: string = options.url
- let username: string = options.username
- let password: string = options.password
+ console.error(`--${key} field is required`)
+ exit = true
+ }
+ }
- if (!url && settings.default !== -1) url = settings.remotes[settings.default]
+ if (exit) process.exit(-1)
+ }
- const machine = netrc.machines[url]
+ // If username or password are specified, both are mandatory
+ if (options.username || options.password) {
+ exitIfNoOptions([ 'username', 'password' ])
+ }
- if (!username && machine) username = machine.login
- if (!password && machine) password = machine.password
+ // If no available machines, url, username and password args are mandatory
+ if (Object.keys(netrc.machines).length === 0) {
+ exitIfNoOptions([ 'url', 'username', 'password' ], 'No account found in netrc')
+ }
- return { url, username, password }
+ if (settings.remotes.length === 0 || settings.default === -1) {
+ exitIfNoOptions([ 'url' ], 'No default instance found')
}
- return {
- url: options.url,
- username: options.username,
- password: options.password
+ let url: string = options.url
+ let username: string = options.username
+ let password: string = options.password
+
+ if (!url && settings.default !== -1) url = settings.remotes[settings.default]
+
+ const machine = netrc.machines[url]
+ if ((!username || !password) && !machine) {
+ console.error('Cannot find existing configuration for %s.', url)
+ process.exit(-1)
}
+
+ if (!username && machine) username = machine.login
+ if (!password && machine) password = machine.password
+
+ return { url, username, password }
}
-function buildCommonVideoOptions (command: CommanderStatic) {
+function buildCommonVideoOptions (command: Command) {
function list (val) {
return val.split(',')
}
.option('-v, --verbose <verbose>', 'Verbosity, from 0/\'error\' to 4/\'debug\'', 'info')
}
-async function buildVideoAttributesFromCommander (url: string, command: CommanderStatic, defaultAttributes: any = {}) {
+async function buildVideoAttributesFromCommander (server: PeerTubeServer, command: Command, defaultAttributes: any = {}) {
const options = command.opts()
const defaultBooleanAttributes = {
Object.assign(videoAttributes, booleanAttributes)
if (options.channelName) {
- const res = await getVideoChannel(url, options.channelName)
- const videoChannel: VideoChannel = res.body
+ const videoChannel = await server.channels.get({ channelName: options.channelName })
Object.assign(videoAttributes, { channelId: videoChannel.id })
return videoAttributes
}
-function getServerCredentials (program: CommanderStatic) {
+function getServerCredentials (program: Command) {
return Promise.all([ getSettings(), getNetrc() ])
.then(([ settings, netrc ]) => {
return getRemoteObjectOrDie(program, settings, netrc)
})
}
+function buildServer (url: string) {
+ loadLanguages()
+ return new PeerTubeServer({ url })
+}
+
+async function assignToken (server: PeerTubeServer, username: string, password: string) {
+ const bodyClient = await server.login.getClient()
+ const client = { id: bodyClient.client_id, secret: bodyClient.client_secret }
+
+ const body = await server.login.login({ client, user: { username, password } })
+
+ server.accessToken = body.access_token
+}
+
function getLogger (logLevel = 'info') {
const logLevels = {
0: 0,
buildCommonVideoOptions,
buildVideoAttributesFromCommander,
- getAdminTokenOrDie
+ getAdminTokenOrDie,
+ buildServer,
+ assignToken
}