2021-06-25 11:48:27 -04:00
|
|
|
import { program } from 'commander'
|
2018-08-27 07:28:49 -04:00
|
|
|
import { access, constants } from 'fs-extra'
|
2017-09-07 11:58:09 -04:00
|
|
|
import { isAbsolute } from 'path'
|
2023-02-15 10:30:33 -05:00
|
|
|
import { assignToken, buildCommonVideoOptions, buildServer, buildVideoAttributesFromCommander, getServerCredentials } from './shared'
|
2017-09-07 11:58:09 -04:00
|
|
|
|
2019-06-13 07:53:28 -04:00
|
|
|
let command = program
|
2018-09-13 08:27:44 -04:00
|
|
|
.name('upload')
|
2019-06-13 07:53:28 -04:00
|
|
|
|
|
|
|
command = buildCommonVideoOptions(command)
|
|
|
|
|
|
|
|
command
|
2017-09-07 11:58:09 -04:00
|
|
|
.option('-u, --url <url>', 'Server url')
|
2018-02-12 06:48:58 -05:00
|
|
|
.option('-U, --username <username>', 'Username')
|
|
|
|
.option('-p, --password <token>', 'Password')
|
2018-02-15 08:46:26 -05:00
|
|
|
.option('-b, --thumbnail <thumbnailPath>', 'Thumbnail path')
|
2018-02-15 12:40:24 -05:00
|
|
|
.option('-v, --preview <previewPath>', 'Preview path')
|
2017-09-07 11:58:09 -04:00
|
|
|
.option('-f, --file <file>', 'Video absolute file path')
|
|
|
|
.parse(process.argv)
|
|
|
|
|
2021-02-03 03:33:05 -05:00
|
|
|
const options = command.opts()
|
|
|
|
|
2019-07-11 11:23:24 -04:00
|
|
|
getServerCredentials(command)
|
|
|
|
.then(({ url, username, password }) => {
|
2021-02-03 03:33:05 -05:00
|
|
|
if (!options.videoName || !options.file) {
|
|
|
|
if (!options.videoName) console.error('--video-name is required.')
|
|
|
|
if (!options.file) console.error('--file is required.')
|
2018-09-13 08:27:44 -04:00
|
|
|
|
2019-07-11 11:23:24 -04:00
|
|
|
process.exit(-1)
|
|
|
|
}
|
2018-09-13 08:27:44 -04:00
|
|
|
|
2021-02-03 03:33:05 -05:00
|
|
|
if (isAbsolute(options.file) === false) {
|
2019-07-11 11:23:24 -04:00
|
|
|
console.error('File path should be absolute.')
|
|
|
|
process.exit(-1)
|
|
|
|
}
|
2018-09-13 08:27:44 -04:00
|
|
|
|
2019-07-11 11:23:24 -04:00
|
|
|
run(url, username, password).catch(err => {
|
|
|
|
console.error(err)
|
|
|
|
process.exit(-1)
|
|
|
|
})
|
|
|
|
})
|
2020-01-31 10:56:52 -05:00
|
|
|
.catch(err => console.error(err))
|
2017-09-07 11:58:09 -04:00
|
|
|
|
2019-04-25 07:55:28 -04:00
|
|
|
async function run (url: string, username: string, password: string) {
|
2021-07-13 05:44:16 -04:00
|
|
|
const server = buildServer(url)
|
|
|
|
await assignToken(server, username, password)
|
2017-09-07 11:58:09 -04:00
|
|
|
|
2021-02-03 03:33:05 -05:00
|
|
|
await access(options.file, constants.F_OK)
|
2018-02-12 06:48:58 -05:00
|
|
|
|
2021-02-03 03:33:05 -05:00
|
|
|
console.log('Uploading %s video...', options.videoName)
|
2017-09-07 11:58:09 -04:00
|
|
|
|
2021-07-15 04:02:54 -04:00
|
|
|
const baseAttributes = await buildVideoAttributesFromCommander(server, program)
|
|
|
|
|
|
|
|
const attributes = {
|
|
|
|
...baseAttributes,
|
2019-06-13 07:53:28 -04:00
|
|
|
|
2021-02-03 03:33:05 -05:00
|
|
|
fixture: options.file,
|
|
|
|
thumbnailfile: options.thumbnail,
|
|
|
|
previewfile: options.preview
|
2021-07-15 04:02:54 -04:00
|
|
|
}
|
2018-02-12 06:48:58 -05:00
|
|
|
|
2019-04-25 07:55:28 -04:00
|
|
|
try {
|
2021-07-16 03:04:35 -04:00
|
|
|
await server.videos.upload({ attributes })
|
2021-02-03 03:33:05 -05:00
|
|
|
console.log(`Video ${options.videoName} uploaded.`)
|
2019-04-25 07:55:28 -04:00
|
|
|
process.exit(0)
|
|
|
|
} catch (err) {
|
2022-01-18 03:19:59 -05:00
|
|
|
const message = err.message || ''
|
|
|
|
if (message.includes('413')) {
|
2022-01-19 04:50:34 -05:00
|
|
|
console.error('Aborted: user quota is exceeded or video file is too big for this PeerTube instance.')
|
2022-01-18 03:19:59 -05:00
|
|
|
} else {
|
|
|
|
console.error(require('util').inspect(err))
|
|
|
|
}
|
|
|
|
|
2019-04-25 07:55:28 -04:00
|
|
|
process.exit(-1)
|
|
|
|
}
|
2018-02-12 06:48:58 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|