+// eslint-disable @typescript-eslint/no-unnecessary-type-assertion
+
+import { registerTSPaths } from '../helpers/register-ts-paths'
+registerTSPaths()
+
import * as program from 'commander'
import * as prompt from 'prompt'
-import { getSettings, writeSettings, getNetrc } from './cli'
-import { isHostValid } from '../helpers/custom-validators/servers'
+import { getNetrc, getSettings, writeSettings } from './cli'
import { isUserUsernameValid } from '../helpers/custom-validators/users'
-
-const Table = require('cli-table')
+import { getAccessToken } from '../../shared/extra-utils'
+import * as CliTable3 from 'cli-table3'
async function delInstance (url: string) {
const [ settings, netrc ] = await Promise.all([ getSettings(), getNetrc() ])
- settings.remotes.splice(settings.remotes.indexOf(url))
+ const index = settings.remotes.indexOf(url)
+ settings.remotes.splice(index)
+
+ if (settings.default === index) settings.default = -1
+
await writeSettings(settings)
delete netrc.machines[url]
await netrc.save()
}
-async function setInstance (url: string, username: string, password: string) {
+async function setInstance (url: string, username: string, password: string, isDefault: boolean) {
const [ settings, netrc ] = await Promise.all([ getSettings(), getNetrc() ])
if (settings.remotes.indexOf(url) === -1) {
settings.remotes.push(url)
}
+
+ if (isDefault || settings.remotes.length === 1) {
+ settings.default = settings.remotes.length - 1
+ }
+
await writeSettings(settings)
netrc.machines[url] = { login: username, password }
}
function isURLaPeerTubeInstance (url: string) {
- return isHostValid(url) || (url.includes('localhost'))
+ return url.startsWith('http://') || url.startsWith('https://')
}
program
url: {
description: 'instance url',
conform: (value) => isURLaPeerTubeInstance(value),
+ message: 'It should be an URL (https://peertube.example.com)',
required: true
},
username: {
}
}
}, async (_, result) => {
- await setInstance(result.url, result.username, result.password)
+ // Check credentials
+ try {
+ await getAccessToken(result.url, result.username, result.password)
+ } catch (err) {
+ console.error(err.message)
+ process.exit(-1)
+ }
+
+ await setInstance(result.url, result.username, result.password, program['default'])
process.exit(0)
})
.action(async () => {
const [ settings, netrc ] = await Promise.all([ getSettings(), getNetrc() ])
- const table = new Table({
- head: ['instance', 'login'],
- colWidths: [30, 30]
- })
+ const table = new CliTable3({
+ head: [ 'instance', 'login' ],
+ colWidths: [ 30, 30 ]
+ }) as any
settings.remotes.forEach(element => {
+ if (!netrc.machines[element]) return
+
table.push([
element,
netrc.machines[element].login
.description('set an existing entry as default')
.action(async url => {
const settings = await getSettings()
- const instanceExists = settings.remotes.indexOf(url) !== -1
+ const instanceExists = settings.remotes.includes(url)
if (instanceExists) {
settings.default = settings.remotes.indexOf(url)
program.on('--help', function () {
console.log(' Examples:')
console.log()
- console.log(' $ peertube add -u peertube.cpy.re -U "PEERTUBE_USER" --password "PEERTUBE_PASSWORD"')
- console.log(' $ peertube add -u peertube.cpy.re -U root')
+ console.log(' $ peertube add -u https://peertube.cpy.re -U "PEERTUBE_USER" --password "PEERTUBE_PASSWORD"')
+ console.log(' $ peertube add -u https://peertube.cpy.re -U root')
console.log(' $ peertube list')
- console.log(' $ peertube del peertube.cpy.re')
+ console.log(' $ peertube del https://peertube.cpy.re')
console.log()
})