Commit ff4aca50 by Johannes Zellner

Add optional --username and --password arguments for easier scripting

1 parent ba93623c
Showing with 10 additions and 4 deletions
...@@ -55,7 +55,7 @@ function collectFiles(filesOrFolders, options) { ...@@ -55,7 +55,7 @@ function collectFiles(filesOrFolders, options) {
return tmp; return tmp;
} }
function login(uri) { function login(uri, options) {
var tmp = url.parse(uri); var tmp = url.parse(uri);
if (!tmp.slashes) tmp = url.parse('https://' + uri); if (!tmp.slashes) tmp = url.parse('https://' + uri);
...@@ -63,8 +63,8 @@ function login(uri) { ...@@ -63,8 +63,8 @@ function login(uri) {
console.log('Using server', server.cyan); console.log('Using server', server.cyan);
var username = readlineSync.question('Username: '); var username = options.username || readlineSync.question('Username: ');
var password = readlineSync.question('Password: ', { hideEchoBack: true, mask: '' }); var password = options.password || readlineSync.question('Password: ', { hideEchoBack: true, mask: '' });
superagent.post(server + '/api/login').send({ username: username, password: password }).end(function (error, result) { superagent.post(server + '/api/login').send({ username: username, password: password }).end(function (error, result) {
if (error && error.code === 'ENOTFOUND') { if (error && error.code === 'ENOTFOUND') {
...@@ -77,7 +77,11 @@ function login(uri) { ...@@ -77,7 +77,11 @@ function login(uri) {
} }
if (result.status !== 201) { if (result.status !== 201) {
console.log('Login failed.\n'.red); console.log('Login failed.\n'.red);
return login(uri);
// remove the password to avoid a login loop
delete options.password;
return login(uri, options);
} }
// TODO remove at some point, this is just to clear the previous old version values // TODO remove at some point, this is just to clear the previous old version values
......
...@@ -9,6 +9,8 @@ program.version(require('../package.json').version); ...@@ -9,6 +9,8 @@ program.version(require('../package.json').version);
program.command('login <url>') program.command('login <url>')
.description('Login to server') .description('Login to server')
.option('--username [username]', 'Username (optional)')
.option('--password [password]', 'Password (optional)')
.action(actions.login); .action(actions.login);
program.command('logout') program.command('logout')
......
Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!