Commit a90a633f by Johannes Zellner

Add auth to client

1 parent b72caa69
Showing with 64 additions and 16 deletions
...@@ -6,7 +6,8 @@ exports.get = get; ...@@ -6,7 +6,8 @@ exports.get = get;
exports.del = del; exports.del = del;
var superagent = require('superagent'), var superagent = require('superagent'),
config = require('./config'), config = require('./config.js'),
readlineSync = require('readline-sync'),
async = require('async'), async = require('async'),
fs = require('fs'), fs = require('fs'),
path = require('path'); path = require('path');
...@@ -15,12 +16,16 @@ require('colors'); ...@@ -15,12 +16,16 @@ require('colors');
var API = '/api/files/'; var API = '/api/files/';
var gQuery = {};
function checkConfig() { function checkConfig() {
if (!config.server()) { if (!config.server() || !config.username() || !config.password()) {
console.log('You have run "login" first'); console.log('You have run "login" first');
process.exit(1); process.exit(1);
} }
gQuery = { username: config.username(), password: config.password() };
console.log('Using server %s', config.server().yellow); console.log('Using server %s', config.server().yellow);
} }
...@@ -43,11 +48,40 @@ function collectFiles(filesOrFolders) { ...@@ -43,11 +48,40 @@ function collectFiles(filesOrFolders) {
return tmp; return tmp;
} }
function checkResponse(error, result) {
if (error && error.status === 401) {
console.log('Login failed');
process.exit(1);
} else if (error) {
console.log('Error', result ? result.text : error);
process.exit(1);
}
}
function login(server) { function login(server) {
if (server[server.length-1] === '/') server = server.slice(0, -1); if (server[server.length-1] === '/') server = server.slice(0, -1);
console.log('Using server', server); console.log('Using server', server);
config.set('server', server);
var username = readlineSync.question('Username: ', { hideEchoBack: false });
var password = readlineSync.question('Password: ', { hideEchoBack: true });
superagent.get(server + API + '/').query({ username: username, password: password }).end(function (error, result) {
console.log(result.status);
if (result.status === 401) {
console.log('Login failed.');
process.exit(1);
}
config.set('server', server);
config.set('username', username);
// TODO this is clearly bad and needs fixing
config.set('password', password);
gQuery = { username: username, password: password };
});
} }
function put(filePath, otherFilePaths, options) { function put(filePath, otherFilePaths, options) {
...@@ -60,7 +94,7 @@ function put(filePath, otherFilePaths, options) { ...@@ -60,7 +94,7 @@ function put(filePath, otherFilePaths, options) {
console.log('Uploading file %s -> %s', relativeFilePath.cyan, ((options.destination ? options.destination : '') + '/' + relativeFilePath).cyan); console.log('Uploading file %s -> %s', relativeFilePath.cyan, ((options.destination ? options.destination : '') + '/' + relativeFilePath).cyan);
superagent.put(config.server() + API + relativeFilePath).attach('file', file).end(callback); superagent.put(config.server() + API + relativeFilePath).query(gQuery).attach('file', file).end(callback);
}, function (error) { }, function (error) {
if (error) { if (error) {
console.log('Failed to put file.', error); console.log('Failed to put file.', error);
...@@ -74,8 +108,9 @@ function put(filePath, otherFilePaths, options) { ...@@ -74,8 +108,9 @@ function put(filePath, otherFilePaths, options) {
function get(filePath) { function get(filePath) {
checkConfig(); checkConfig();
var relativeFilePath = path.resolve(filePath).slice(process.cwd().length + 1); superagent.get(config.server() + API + filePath).query(gQuery).end(function (error, result) {
superagent.get(config.server() + API + relativeFilePath).end(function (error, result) { if (error && error.status === 401) return console.log('Login failed');
if (error && error.status === 404) return console.log('No such file or directory');
if (error) return console.log('Failed', result ? result.body : error); if (error) return console.log('Failed', result ? result.body : error);
if (result.body && result.body.entries) { if (result.body && result.body.entries) {
...@@ -93,8 +128,9 @@ function del(filePath) { ...@@ -93,8 +128,9 @@ function del(filePath) {
checkConfig(); checkConfig();
var relativeFilePath = path.resolve(filePath).slice(process.cwd().length + 1); var relativeFilePath = path.resolve(filePath).slice(process.cwd().length + 1);
superagent.del(config.server() + API + relativeFilePath).end(function (error, result) { superagent.del(config.server() + API + relativeFilePath).query(gQuery).end(function (error, result) {
if (error.status === 404) return console.log('No such file or directory'); if (error && error.status === 401) return console.log('Login failed');
if (error && error.status === 404) return console.log('No such file or directory');
if (error) return console.log('Failed', result ? result.body : error); if (error) return console.log('Failed', result ? result.body : error);
console.log('Success', result.body); console.log('Success', result.body);
}); });
......
...@@ -15,7 +15,9 @@ exports = module.exports = { ...@@ -15,7 +15,9 @@ exports = module.exports = {
has: has, has: has,
// convenience // convenience
server: function () { return get('server'); } server: function () { return get('server'); },
username: function () { return get('username'); },
password: function () { return get('password'); }
}; };
var HOME = process.env.HOME || process.env.HOMEPATH || process.env.USERPROFILE; var HOME = process.env.HOME || process.env.HOMEPATH || process.env.USERPROFILE;
......
...@@ -3,20 +3,30 @@ ...@@ -3,20 +3,30 @@
var passport = require('passport'), var passport = require('passport'),
LdapStrategy = require('passport-ldapjs').Strategy; LdapStrategy = require('passport-ldapjs').Strategy;
passport.serializeUser(function (user, done) {
console.log('serializeUser', user);
done(null, user.id);
});
passport.deserializeUser(function (id, done) {
console.log('deserializeUser', id);
done(null, { id: id });
});
var LDAP_URL = process.env.LDAP_URL; var LDAP_URL = process.env.LDAP_URL;
var LDAP_USERS_BASE_DN = process.env.LDAP_USERS_BASE_DN; var LDAP_USERS_BASE_DN = process.env.LDAP_USERS_BASE_DN;
if (LDAP_URL && LDAP_USERS_BASE_DN) { if (LDAP_URL && LDAP_USERS_BASE_DN) {
console.log('Enable ldap auth'); console.log('Enable ldap auth');
exports.ldap = passport.authenticate('ldap', { exports.ldap = passport.authenticate('ldap');
successReturnToOrRedirect: '/',
failureRedirect: '/login',
failureFlash: true
});
} else { } else {
exports.ldap = function (req, res, next) { exports.ldap = function (req, res, next) {
console.log('ldap auth disabled'); console.log('Disable ldap auth, use developer credentials!');
if (req.query.username !== 'username') return res.send(401);
if (req.query.password !== 'password') return res.send(401);
next(); next();
}; };
} }
...@@ -31,7 +41,7 @@ var opts = { ...@@ -31,7 +41,7 @@ var opts = {
attributes: ['displayname', 'username', 'mail', 'uid'], attributes: ['displayname', 'username', 'mail', 'uid'],
scope: 'sub' scope: 'sub'
}, },
uidTag: 'uid', uidTag: 'cn',
usernameField: 'username', usernameField: 'username',
passwordField: 'password', passwordField: 'password',
}; };
......
Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!