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 * Node sessions routes module.
22 * Provides a RESTful API to manage sessions.
23 * @module framework/core/modules/routes/sessions
24 * @author Kiran Kashalkar <kiran.kashalkar@riftio.com>
27 var cors
= require('cors');
28 var bodyParser
= require('body-parser');
29 var sessionsAPI
= require('../api/sessions');
30 var Router
= require('express').Router();
31 var utils
= require('../../api_utils/utils');
32 var CONSTANTS
= require('../../api_utils/constants.js');
33 var request
= require('request');
34 var _
= require('lodash');
36 Router
.use(bodyParser
.json());
38 Router
.use(bodyParser
.urlencoded({
42 Router
.post('/session', cors(), function(req
, res
) {
43 sessionsAPI
.create(req
, res
).then(function(data
) {
44 utils
.sendSuccessResponse(data
, res
);
48 // For project switcher UI
49 Router
.put('/session/:projectId', cors(), function(req
, res
) {
50 sessionsAPI
.addProjectToSession(req
, res
).then(function(data
) {
51 utils
.sendSuccessResponse(data
, res
);
53 utils
.sendErrorResponse(error
, res
);
57 Router
.delete('/session', cors(), function(req
, res
) {
58 sessionsAPI
.delete(req
, res
);
62 module
.exports
= Router
;