X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=skyquake%2Fframework%2Fcore%2Fmodules%2Froutes%2Fnavigation.js;h=3f460e6eef5293b94534daa81bad76990ec08b7f;hb=407555cd9dac9e0dd9889da18082ae275a0a44fd;hp=9b8fbf7ecadb3a625469ec03ef6574654aa744d9;hpb=3d39b18290b9cb3e10c1a80d91ac4819e7c58474;p=osm%2FUI.git diff --git a/skyquake/framework/core/modules/routes/navigation.js b/skyquake/framework/core/modules/routes/navigation.js index 9b8fbf7ec..3f460e6ee 100644 --- a/skyquake/framework/core/modules/routes/navigation.js +++ b/skyquake/framework/core/modules/routes/navigation.js @@ -1,6 +1,6 @@ /* - * + * * Copyright 2016 RIFT.IO Inc * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -42,14 +42,36 @@ Router.get('/login.html', cors(), function(req, res) { res.end(); }); -Router.get('/', cors(), function(req, res) { +Router.use(/^\/(?!session).*/, function(req, res, next) { var api_server = req.query['api_server'] || (req.protocol + '://' + configurationAPI.globalConfiguration.get().api_server); - if (req.session.loggedIn) { - console.log('Logged in. Redirect to launchpad') - res.redirect('/launchpad/?api_server=' + api_server + '&upload_server=' + req.protocol + '://' + (configurationAPI.globalConfiguration.get().upload_server || req.hostname)); + if (req.session && req.session.loggedIn) { + next(); } else { console.log('Redirect to login.html'); - res.redirect('login.html?api_server=' + api_server); + res.redirect('/login.html?api_server=' + api_server + '&upload_server=' + req.protocol + '://' + (configurationAPI.globalConfiguration.get().upload_server || req.hostname) + '&referer=' + encodeURIComponent(req.headers.referer)); + } +}); + +Router.use(function(req, res, next) { + var api_server = req.query['api_server'] || (req.protocol + '://' + configurationAPI.globalConfiguration.get().api_server); + if (req.session.redirect) { + req.session.redirect = false; + req.session.save(function(err) { + if (err) { + console.log('Error saving session to store', err); + } + }); + if(req.query.referer && (req.query.referer != "undefined")) { + res.redirect(decodeURIComponent(req.query.referer)); + } else { + if(req.session.isLCM) { + res.redirect('/launchpad/?api_server=' + api_server + '&upload_server=' + req.protocol + '://' + (configurationAPI.globalConfiguration.get().upload_server || req.hostname)); + } else { + res.redirect('/user_management/?api_server=' + api_server + '&upload_server=' + req.protocol + '://' + (configurationAPI.globalConfiguration.get().upload_server || req.hostname) + '#/user-profile'); + } + } + } else { + next(); } });