X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftools%2Fpeertube-upload.ts;h=c94b0585729b8a643a6c8cc718984d0f024c0d85;hb=d0a0fa429d4651710ed951a3c11af0219e408964;hp=cc7bd9b4c7453706d4beabc4fa9dd6ea5eba0b2f;hpb=73471b1a52f242e86364ffb077ea6cadb3b07ae2;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/tools/peertube-upload.ts b/server/tools/peertube-upload.ts index cc7bd9b4c..c94b05857 100644 --- a/server/tools/peertube-upload.ts +++ b/server/tools/peertube-upload.ts @@ -1,137 +1,73 @@ -import * as program from 'commander' +import { registerTSPaths } from '../helpers/register-ts-paths' +registerTSPaths() + +import { program } from 'commander' import { access, constants } from 'fs-extra' import { isAbsolute } from 'path' -import { getClient, login } from '../../shared/utils' -import { uploadVideo } from '../../shared/utils/' -import { VideoPrivacy } from '../../shared/models/videos' -import { netrc, getSettings } from './cli' +import { uploadVideo } from '../../shared/extra-utils/' +import { assignToken, buildCommonVideoOptions, buildServer, buildVideoAttributesFromCommander, getServerCredentials } from './cli' -program +let command = program .name('upload') + +command = buildCommonVideoOptions(command) + +command .option('-u, --url ', 'Server url') .option('-U, --username ', 'Username') .option('-p, --password ', 'Password') - .option('-n, --video-name ', 'Video name') - .option('-P, --privacy ', 'Privacy') - .option('-N, --nsfw', 'Video is Not Safe For Work') - .option('-c, --category ', 'Category number') - .option('-C, --channel-id ', 'Channel ID') - .option('-m, --comments-enabled', 'Enable comments') - .option('-l, --licence ', 'Licence number') - .option('-L, --language ', 'Language ISO 639 code (fr or en...)') - .option('-d, --video-description ', 'Video description') - .option('-t, --tags ', 'Video tags', list) .option('-b, --thumbnail ', 'Thumbnail path') .option('-v, --preview ', 'Preview path') .option('-f, --file ', 'Video absolute file path') .parse(process.argv) -if (!program['tags']) program['tags'] = [] -if (!program['nsfw']) program['nsfw'] = false -if (!program['privacy']) program['privacy'] = VideoPrivacy.PUBLIC -if (!program['commentsEnabled']) program['commentsEnabled'] = false - -getSettings() - .then(settings => { - if ( - (!program['url'] || - !program['username'] || - !program['password']) && - (settings.remotes.length === 0) - ) { - if (!program['url']) console.error('--url field is required.') - if (!program['username']) console.error('--username field is required.') - if (!program['password']) console.error('--password field is required.') - if (!program['videoName']) console.error('--video-name field is required.') - if (!program['file']) console.error('--file field is required.') - process.exit(-1) - } +const options = command.opts() - if ( - (!program['url'] || - !program['username'] || - !program['password']) && - (settings.remotes.length > 0) - ) { - if (!program['url']) { - program['url'] = (settings.default !== -1) ? - settings.remotes[settings.default] : - settings.remotes[0] - } - if (!program['username']) program['username'] = netrc.machines[program['url']].login - if (!program['password']) program['password'] = netrc.machines[program['url']].password - } +getServerCredentials(command) + .then(({ url, username, password }) => { + if (!options.videoName || !options.file) { + if (!options.videoName) console.error('--video-name is required.') + if (!options.file) console.error('--file is required.') - if ( - !program['videoName'] || - !program['file'] - ) { - if (!program['videoName']) console.error('--video-name field is required.') - if (!program['file']) console.error('--file field is required.') process.exit(-1) } - if (isAbsolute(program['file']) === false) { + if (isAbsolute(options.file) === false) { console.error('File path should be absolute.') process.exit(-1) } - run().catch(err => { + run(url, username, password).catch(err => { console.error(err) process.exit(-1) }) }) + .catch(err => console.error(err)) -async function run () { - const res = await getClient(program[ 'url' ]) - const client = { - id: res.body.client_id, - secret: res.body.client_secret - } +async function run (url: string, username: string, password: string) { + const server = buildServer(url) + await assignToken(server, username, password) - const user = { - username: program[ 'username' ], - password: program[ 'password' ] - } + await access(options.file, constants.F_OK) - let accessToken: string - try { - const res2 = await login(program[ 'url' ], client, user) - accessToken = res2.body.access_token - } catch (err) { - throw new Error('Cannot authenticate. Please check your username/password.') - } + console.log('Uploading %s video...', options.videoName) - await access(program[ 'file' ], constants.F_OK) - - console.log('Uploading %s video...', program[ 'videoName' ]) - - const videoAttributes = { - name: program['videoName'], - category: program['category'], - channelId: program['channelId'], - licence: program['licence'], - language: program['language'], - nsfw: program['nsfw'], - description: program['videoDescription'], - tags: program['tags'], - commentsEnabled: program['commentsEnabled'], - fixture: program['file'], - thumbnailfile: program['thumbnail'], - previewfile: program['preview'], - waitTranscoding: true, - privacy: program['privacy'], - support: undefined - } + const videoAttributes = await buildVideoAttributesFromCommander(server, program) - await uploadVideo(program[ 'url' ], accessToken, videoAttributes) + Object.assign(videoAttributes, { + fixture: options.file, + thumbnailfile: options.thumbnail, + previewfile: options.preview + }) - console.log(`Video ${program['videoName']} uploaded.`) - process.exit(0) + try { + await uploadVideo(url, server.accessToken, videoAttributes) + console.log(`Video ${options.videoName} uploaded.`) + process.exit(0) + } catch (err) { + console.error(require('util').inspect(err)) + process.exit(-1) + } } // ---------------------------------------------------------------------------- - -function list (val) { - return val.split(',') -}