]> git.immae.eu Git - perso/Immae/Projets/Nodejs/Surfer.git/commitdiff
Add optional --username and --password arguments for easier scripting
authorJohannes Zellner <johannes@cloudron.io>
Thu, 9 Feb 2017 14:47:40 +0000 (15:47 +0100)
committerJohannes Zellner <johannes@cloudron.io>
Thu, 9 Feb 2017 14:47:40 +0000 (15:47 +0100)
cli/actions.js
cli/surfer.js

index 996ef7fdc7e6fefd741e99835c6fb9de2e9ec344..e9bbd9d8ce5f72a2514c3a925693e9bab875d7be 100644 (file)
@@ -55,7 +55,7 @@ function collectFiles(filesOrFolders, options) {
     return tmp;
 }
 
-function login(uri) {
+function login(uri, options) {
     var tmp = url.parse(uri);
     if (!tmp.slashes) tmp = url.parse('https://' + uri);
 
@@ -63,8 +63,8 @@ function login(uri) {
 
     console.log('Using server', server.cyan);
 
-    var username = readlineSync.question('Username: ');
-    var password = readlineSync.question('Password: ', { hideEchoBack: true, mask: '' });
+    var username = options.username || readlineSync.question('Username: ');
+    var password = options.password || readlineSync.question('Password: ', { hideEchoBack: true, mask: '' });
 
     superagent.post(server + '/api/login').send({ username: username, password: password }).end(function (error, result) {
         if (error && error.code === 'ENOTFOUND') {
@@ -77,7 +77,11 @@ function login(uri) {
         }
         if (result.status !== 201) {
             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
index ef3ed9119eaef8b74d2c3b747b31bd58c8ced4cc..366d3c54075eb99fde97786962b863e2058d2b6e 100755 (executable)
@@ -9,6 +9,8 @@ program.version(require('../package.json').version);
 
 program.command('login <url>')
     .description('Login to server')
+    .option('--username [username]', 'Username (optional)')
+    .option('--password [password]', 'Password (optional)')
     .action(actions.login);
 
 program.command('logout')