|
@ -4,7 +4,7 @@ var passport = require('passport'); |
|
|
var Strategy = require('passport-custom').Strategy; |
|
|
var Strategy = require('passport-custom').Strategy; |
|
|
var request = require('request'); |
|
|
var request = require('request'); |
|
|
var dotEnv = require('dot-env'); |
|
|
var dotEnv = require('dot-env'); |
|
|
var db = require('./database.js'); |
|
|
|
|
|
|
|
|
var DB = require('./database.js'); |
|
|
|
|
|
|
|
|
var app = express(); |
|
|
var app = express(); |
|
|
|
|
|
|
|
@ -14,47 +14,58 @@ app.use(bodyParser.urlencoded({extended:false})); |
|
|
app.use(passport.initialize()); |
|
|
app.use(passport.initialize()); |
|
|
|
|
|
|
|
|
// Custom Strategy
|
|
|
// Custom Strategy
|
|
|
passport.use(new Strategy(db.verify)); |
|
|
|
|
|
|
|
|
|
|
|
// Use Custom Strategy
|
|
|
|
|
|
|
|
|
passport.use(new Strategy(DB.DatabaseLookup)); |
|
|
app.use('*', passport.authenticate('custom', { session: false })); |
|
|
app.use('*', passport.authenticate('custom', { session: false })); |
|
|
|
|
|
|
|
|
// Main Route /
|
|
|
// Main Route /
|
|
|
app.all('*', function(req, res, next) { |
|
|
app.all('*', function(req, res, next) { |
|
|
// TODO: lookup base url based on client_id in request body
|
|
|
|
|
|
var baseUrl = clientLookup(req.body.client_id); |
|
|
|
|
|
|
|
|
// Lookup client
|
|
|
|
|
|
var baseUrl = DB.ClientLookup(req.body.client_id, function(err, url) { |
|
|
|
|
|
if (err) { |
|
|
|
|
|
console.log(err); |
|
|
|
|
|
return res.sendStatus(404); |
|
|
|
|
|
} |
|
|
|
|
|
if (!url) { |
|
|
|
|
|
console.log('No Results'); |
|
|
|
|
|
return res.sendStatus(400); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
// Perform the actual request to the requested API
|
|
|
|
|
|
request( |
|
|
|
|
|
{ |
|
|
|
|
|
method : req.body._method || req.method, |
|
|
|
|
|
uri : baseUrl + req.path, |
|
|
|
|
|
multipart : [{ |
|
|
|
|
|
'content-type' : 'application/json', |
|
|
|
|
|
'body' : JSON.stringify(req.body.params) || '' |
|
|
|
|
|
}] |
|
|
|
|
|
}, |
|
|
|
|
|
function(error, response, body) { |
|
|
|
|
|
if (!error && response.statusCode == 200) { |
|
|
|
|
|
var request = { |
|
|
|
|
|
"baseUrl" : baseUrl, |
|
|
|
|
|
"body" : req.body, |
|
|
|
|
|
"method" : req.method, |
|
|
|
|
|
"requestParams" : req.body.params, |
|
|
|
|
|
"originalUrl" : req.originalUrl, |
|
|
|
|
|
"path" : req.path, |
|
|
|
|
|
"protocol" : req.protocol, |
|
|
|
|
|
"query" : req.query, |
|
|
|
|
|
"secure" : req.secure, |
|
|
|
|
|
"signedCookies" : req.signedCookies, |
|
|
|
|
|
"response" : JSON.parse(body), |
|
|
|
|
|
|
|
|
// Perform request on API
|
|
|
|
|
|
console.log(req.body._method); |
|
|
|
|
|
console.log(url); |
|
|
|
|
|
console.log(req.path); |
|
|
|
|
|
request( |
|
|
|
|
|
{ |
|
|
|
|
|
method : req.body._method || req.method, |
|
|
|
|
|
uri : url + req.path, |
|
|
|
|
|
multipart : [{ |
|
|
|
|
|
'content-type' : 'application/json', |
|
|
|
|
|
'body' : JSON.stringify(req.body.params) || '' |
|
|
|
|
|
}] |
|
|
|
|
|
}, |
|
|
|
|
|
function(error, response, body) { |
|
|
|
|
|
if (!error && response.statusCode == 200) { |
|
|
|
|
|
var request = { |
|
|
|
|
|
"baseUrl" : url, |
|
|
|
|
|
"body" : req.body, |
|
|
|
|
|
"method" : req.method, |
|
|
|
|
|
"requestParams" : req.body.params, |
|
|
|
|
|
"originalUrl" : req.originalUrl, |
|
|
|
|
|
"path" : req.path, |
|
|
|
|
|
"protocol" : req.protocol, |
|
|
|
|
|
"query" : req.query, |
|
|
|
|
|
"secure" : req.secure, |
|
|
|
|
|
"signedCookies" : req.signedCookies, |
|
|
|
|
|
"response" : JSON.parse(body), |
|
|
|
|
|
} |
|
|
|
|
|
res.json(request); |
|
|
|
|
|
} else { |
|
|
|
|
|
//console.log('Error code : ' + response.statusCode);
|
|
|
|
|
|
console.log('Error message : ' + error); |
|
|
} |
|
|
} |
|
|
res.json(request); |
|
|
|
|
|
} else { |
|
|
|
|
|
console.log('Error code : ' + response.statusCode); |
|
|
|
|
|
console.log('Error message : ' + error); |
|
|
|
|
|
} |
|
|
} |
|
|
}); |
|
|
|
|
|
|
|
|
); |
|
|
|
|
|
}); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
var port = process.env.PORT; |
|
|
var port = process.env.PORT; |
|
|