Auto add https:// in import script URLs

This commit is contained in:
Chocobozzz 2019-12-30 08:47:58 +01:00
parent 7a3864e818
commit da69b88638
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
1 changed files with 24 additions and 17 deletions

View File

@ -1,4 +1,5 @@
import { registerTSPaths } from '../helpers/register-ts-paths' import { registerTSPaths } from '../helpers/register-ts-paths'
registerTSPaths() registerTSPaths()
// FIXME: https://github.com/nodejs/node/pull/16853 // FIXME: https://github.com/nodejs/node/pull/16853
@ -57,8 +58,8 @@ getServerCredentials(command)
exitError('--tmpdir %s: directory does not exist or is not accessible', program[ 'tmpdir' ]) exitError('--tmpdir %s: directory does not exist or is not accessible', program[ 'tmpdir' ])
} }
url = removeEndSlashes(url) url = normalizeTargetUrl(url)
program[ 'targetUrl' ] = removeEndSlashes(program[ 'targetUrl' ]) program[ 'targetUrl' ] = normalizeTargetUrl(program[ 'targetUrl' ])
const user = { username, password } const user = { username, password }
@ -84,11 +85,11 @@ async function run (url: string, user: UserInfo) {
let infoArray: any[] let infoArray: any[]
// Normalize utf8 fields // Normalize utf8 fields
infoArray = [].concat(info); infoArray = [].concat(info)
if (program[ 'first' ]) { if (program[ 'first' ]) {
infoArray = infoArray.slice(0, program[ 'first' ]) infoArray = infoArray.slice(0, program[ 'first' ])
} else if (program[ 'last' ]) { } else if (program[ 'last' ]) {
infoArray = infoArray.slice(- program[ 'last' ]) infoArray = infoArray.slice(-program[ 'last' ])
} }
infoArray = infoArray.map(i => normalizeObject(i)) infoArray = infoArray.map(i => normalizeObject(i))
@ -125,15 +126,15 @@ function processVideo (parameters: {
if (program[ 'since' ]) { if (program[ 'since' ]) {
if (buildOriginallyPublishedAt(videoInfo).getTime() < program[ 'since' ].getTime()) { if (buildOriginallyPublishedAt(videoInfo).getTime() < program[ 'since' ].getTime()) {
log.info('Video "%s" has been published before "%s", don\'t upload it.\n', log.info('Video "%s" has been published before "%s", don\'t upload it.\n',
videoInfo.title, formatDate(program[ 'since' ])); videoInfo.title, formatDate(program[ 'since' ]))
return res(); return res()
} }
} }
if (program[ 'until' ]) { if (program[ 'until' ]) {
if (buildOriginallyPublishedAt(videoInfo).getTime() > program[ 'until' ].getTime()) { if (buildOriginallyPublishedAt(videoInfo).getTime() > program[ 'until' ].getTime()) {
log.info('Video "%s" has been published after "%s", don\'t upload it.\n', log.info('Video "%s" has been published after "%s", don\'t upload it.\n',
videoInfo.title, formatDate(program[ 'until' ])); videoInfo.title, formatDate(program[ 'until' ]))
return res(); return res()
} }
} }
@ -329,8 +330,14 @@ function isNSFW (info: any) {
return info.age_limit && info.age_limit >= 16 return info.age_limit && info.age_limit >= 16
} }
function removeEndSlashes (url: string) { function normalizeTargetUrl (url: string) {
return url.replace(/\/+$/, '') let normalizedUrl = url.replace(/\/+$/, '')
if (!normalizedUrl.startsWith('http://') || !normalizedUrl.startsWith('https://')) {
normalizedUrl = 'https://' + normalizedUrl
}
return normalizedUrl
} }
async function promptPassword () { async function promptPassword () {
@ -370,21 +377,21 @@ async function getAccessTokenOrDie (url: string, user: UserInfo) {
function parseDate (dateAsStr: string): Date { function parseDate (dateAsStr: string): Date {
if (!/\d{4}-\d{2}-\d{2}/.test(dateAsStr)) { if (!/\d{4}-\d{2}-\d{2}/.test(dateAsStr)) {
exitError(`Invalid date passed: ${dateAsStr}. Expected format: YYYY-MM-DD. See help for usage.`); exitError(`Invalid date passed: ${dateAsStr}. Expected format: YYYY-MM-DD. See help for usage.`)
} }
const date = new Date(dateAsStr); const date = new Date(dateAsStr)
date.setHours(0, 0, 0); date.setHours(0, 0, 0)
if (isNaN(date.getTime())) { if (isNaN(date.getTime())) {
exitError(`Invalid date passed: ${dateAsStr}. See help for usage.`); exitError(`Invalid date passed: ${dateAsStr}. See help for usage.`)
} }
return date; return date
} }
function formatDate (date: Date): string { function formatDate (date: Date): string {
return date.toISOString().split('T')[0]; return date.toISOString().split('T')[ 0 ]
} }
function exitError (message:string, ...meta: any[]) { function exitError (message: string, ...meta: any[]) {
// use console.error instead of log.error here // use console.error instead of log.error here
console.error(message, ...meta) console.error(message, ...meta)
process.exit(-1) process.exit(-1)