Clean up peertube auth

This commit is contained in:
Chocobozzz 2018-11-14 15:45:50 +01:00
parent 5c6d985fae
commit e5cb43e071
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
3 changed files with 55 additions and 58 deletions

View File

@ -44,6 +44,8 @@ describe('Test CLI wrapper', function () {
}) })
after(async function () { after(async function () {
this.timeout(10000)
await execCLI(cmd + ` auth del ${server.url}`) await execCLI(cmd + ` auth del ${server.url}`)
killallServers([ server ]) killallServers([ server ])

View File

@ -5,34 +5,25 @@ import { getSettings, writeSettings, netrc } from './cli'
import { isHostValid } from '../helpers/custom-validators/servers' import { isHostValid } from '../helpers/custom-validators/servers'
import { isUserUsernameValid } from '../helpers/custom-validators/users' import { isUserUsernameValid } from '../helpers/custom-validators/users'
function delInstance (url: string) { async function delInstance (url: string) {
return new Promise((res, rej): void => { const settings = await getSettings()
getSettings()
.then(async (settings) => { settings.remotes.splice(settings.remotes.indexOf(url))
settings.remotes.splice(settings.remotes.indexOf(url)) await writeSettings(settings)
await writeSettings(settings)
delete netrc.machines[url] delete netrc.machines[url]
netrc.save() await netrc.save()
res()
})
.catch(err => rej(err))
})
} }
async function setInstance (url: string, username: string, password: string) { async function setInstance (url: string, username: string, password: string) {
return new Promise((res, rej): void => { const settings = await getSettings()
getSettings() if (settings.remotes.indexOf(url) === -1) {
.then(async settings => { settings.remotes.push(url)
if (settings.remotes.indexOf(url) === -1) { }
settings.remotes.push(url) await writeSettings(settings)
}
await writeSettings(settings) netrc.machines[url] = { login: username, password }
netrc.machines[url] = { login: username, password } await netrc.save()
netrc.save()
res()
})
.catch(err => rej(err))
})
} }
function isURLaPeerTubeInstance (url: string) { function isURLaPeerTubeInstance (url: string) {
@ -71,56 +62,60 @@ program
required: true required: true
} }
} }
}, (_, result) => { }, async (_, result) => {
setInstance(result.url, result.username, result.password) await setInstance(result.url, result.username, result.password)
process.exit(0)
}) })
}) })
program program
.command('del <url>') .command('del <url>')
.description('unregisters a remote instance') .description('unregisters a remote instance')
.action((url) => { .action(async url => {
delInstance(url) await delInstance(url)
process.exit(0)
}) })
program program
.command('list') .command('list')
.description('lists registered remote instances') .description('lists registered remote instances')
.action(() => { .action(async () => {
getSettings() const settings = await getSettings()
.then(settings => { const table = new Table({
const table = new Table({ head: ['instance', 'login'],
head: ['instance', 'login'], colWidths: [30, 30]
colWidths: [30, 30] })
}) netrc.loadSync()
netrc.loadSync() settings.remotes.forEach(element => {
settings.remotes.forEach(element => { table.push([
table.push([ element,
element, netrc.machines[element].login
netrc.machines[element].login ])
]) })
})
console.log(table.toString()) console.log(table.toString())
})
process.exit(0)
}) })
program program
.command('set-default <url>') .command('set-default <url>')
.description('set an existing entry as default') .description('set an existing entry as default')
.action((url) => { .action(async url => {
getSettings() const settings = await getSettings()
.then(settings => { const instanceExists = settings.remotes.indexOf(url) !== -1
const instanceExists = settings.remotes.indexOf(url) !== -1
if (instanceExists) { if (instanceExists) {
settings.default = settings.remotes.indexOf(url) settings.default = settings.remotes.indexOf(url)
writeSettings(settings) await writeSettings(settings)
} else {
console.log('<url> is not a registered instance.') process.exit(0)
process.exit(-1) } else {
} console.log('<url> is not a registered instance.')
}) process.exit(-1)
}
}) })
program.on('--help', function () { program.on('--help', function () {

View File

@ -58,7 +58,7 @@ if (!process.argv.slice(2).length) {
,"\\/ ,"\\/
_,.__/"\\/_ (the CLI for red chocobos) _,.__/"\\/_ (the CLI for red chocobos)
/ \\) "./, ". / \\) "./, ".
--/---"---" "-) )---- by Chocobozzz et al.`) --/---"---" "-) )---- by Chocobozzz et al.\n`)
} }
getSettings() getSettings()