4 * Copyright 2016 RIFT.IO Inc
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
21 * navigation routes module. Provides a RESTful API for this
22 * skyquake instance's navigation state.
23 * @module framework/core/modules/routes/navigation
24 * @author Kiran Kashalkar <kiran.kashalkar@riftio.com>
27 var cors
= require('cors');
28 var bodyParser
= require('body-parser');
29 var navAPI
= require('../api/navigation');
30 var Router
= require('express').Router();
31 var utils
= require('../../api_utils/utils');
32 var configurationAPI
= require('../api/configuration');
34 Router
.use(bodyParser
.json());
36 Router
.use(bodyParser
.urlencoded({
40 Router
.get('/login.html', cors(), function(req
, res
) {
41 res
.render('login.html');
44 //Should have a way of adding excluded routes to this via plugin registry, instead of hard coding
45 Router
.use(/^(?!.*(session|composer\/upload|composer\/update)).*/, function(req
, res
, next
) {
46 var api_server
= req
.query
['api_server'] || (req
.protocol
+ '://' + configurationAPI
.globalConfiguration
.get().api_server
);
47 if (req
.session
&& req
.session
.loggedIn
) {
50 console
.log('Redirect to login.html');
51 res
.redirect('/login.html?api_server=' + api_server
+ '&upload_server=' + req
.protocol
+ '://' + (configurationAPI
.globalConfiguration
.get().upload_server
|| req
.hostname
) + '&referer=' + encodeURIComponent(req
.headers
.referer
));
55 Router
.use(function(req
, res
, next
) {
56 var api_server
= req
.query
['api_server'] || (req
.protocol
+ '://' + configurationAPI
.globalConfiguration
.get().api_server
);
57 if (req
.session
.redirect
) {
58 req
.session
.redirect
= false;
59 req
.session
.save(function(err
) {
61 console
.log('Error saving session to store', err
);
64 if(req
.query
.referer
&& (req
.query
.referer
!= "undefined")) {
65 res
.redirect(decodeURIComponent(req
.query
.referer
));
67 if(req
.session
.isLCM
) {
68 res
.redirect('/launchpad/?api_server=' + api_server
+ '&upload_server=' + req
.protocol
+ '://' + (configurationAPI
.globalConfiguration
.get().upload_server
|| req
.hostname
));
70 res
.redirect('/user_management/?api_server=' + api_server
+ '&upload_server=' + req
.protocol
+ '://' + (configurationAPI
.globalConfiguration
.get().upload_server
|| req
.hostname
) + '#/user-profile');
78 Router
.get('/nav', cors(), function(req
, res
) {
79 navAPI
.get(req
).then(function(data
) {
80 utils
.sendSuccessResponse(data
, res
);
82 utils
.sendErrorResponse(error
, res
);
86 Router
.get('/nav/:plugin_id', cors(), function(req
, res
) {
87 navAPI
.get(req
).then(function(data
) {
88 utils
.sendSuccessResponse(data
, res
);
90 utils
.sendErrorResponse(error
, res
);
94 Router
.post('/nav/:plugin_id', cors(), function(req
, res
) {
95 navAPI
.create(req
).then(function(data
) {
96 utils
.sendSuccessResponse(data
, res
);
98 utils
.sendErrorResponse(error
, res
);
102 Router
.put('/nav/:plugin_id/:route_id', cors(), function(req
, res
) {
103 navAPI
.update(req
).then(function(data
) {
104 utils
.sendSuccessResponse(data
, res
);
106 utils
.sendErrorResponse(error
, res
);
110 Router
.delete('/nav/:plugin_id/:route_id', cors(), function(req
, res
) {
111 navAPI
.delete(req
).then(function(data
) {
112 utils
.sendSuccessResponse(data
, res
);
114 utils
.sendErrorResponse(error
, res
);
119 module
.exports
= Router
;