Browse Source

Initial Commit

master
Levi Olson 9 years ago
commit
14c77090ad
6 changed files with 146 additions and 0 deletions
  1. +8
    -0
      .env.json.example
  2. +3
    -0
      .gitignore
  3. +64
    -0
      app.js
  4. +41
    -0
      database.js
  5. +1
    -0
      index.php
  6. +29
    -0
      package.json

+ 8
- 0
.env.json.example View File

@ -0,0 +1,8 @@
{
"PORT":"1337",
"DB_SOCKET":"/var/run/mysqld/mysqld.sock",
"DB_USER":"username",
"DB_PASSWORD":"password",
"DB_DATABASE":"database"
}

+ 3
- 0
.gitignore View File

@ -0,0 +1,3 @@
node_modules
*.swp
.env.json

+ 64
- 0
app.js View File

@ -0,0 +1,64 @@
var bodyParser = require('body-parser');
var express = require('express');
var passport = require('passport');
var Strategy = require('passport-custom').Strategy;
var request = require('request');
var dotEnv = require('dot-env');
var db = require('./database.js');
var app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended:false}));
app.use(passport.initialize());
// Custom Strategy
passport.use(new Strategy(db.verify));
// Use Custom Strategy
app.use('*', passport.authenticate('custom', { session: false }));
// Main Route /
app.all('*', function(req, res, next) {
// TODO: lookup base url based on client_id in request body
var baseUrl = clientLookup(req.body.client_id);
// 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),
}
res.json(request);
} else {
console.log('Error code : ' + response.statusCode);
console.log('Error message : ' + error);
}
});
});
var port = process.env.PORT;
app.listen(port, '127.0.0.1', function () {
console.log('Example app listening at http://%s:%s', '127.0.0.1', port);
});

+ 41
- 0
database.js View File

@ -0,0 +1,41 @@
var bcrypt = require('bcrypt');
var mysql = require('mysql');
var dotEnv = require('dot-env');
module.exports = {
verify: function(req, done) {
var connection = mysql.createConnection({
socket : process.env.DB_SOCKET,
user : process.env.DB_USER,
password : process.env.DB_PASSWORD,
database : process.env.DB_DATABASE
});
connection.connect(function(err) {
if (err) done(err);
});
connection.query('SELECT password FROM users WHERE email = \''+req.body.email+'\'', function(err, result, fields) {
if (err) done(err);
if (!result || !result[0] || !result[0].password) return done(null, false);
var password = result[0].password.replace('$2y$', '$2a$');
var salt = password.slice(0,29);
bcrypt.hash(req.body.password, salt, function(err, enc) {
if (err) {
console.log(err);
return done(err, null);
} else if (enc == password) {
// console.log('Authorized');
return done(null, true);
} else {
// console.log('Not Authorized');
return done(null, null);
}
});
});
connection.end();
},
clientLookup(client_id): function(client_id) {
return 'http://xkcd.leviolson.com';
}
};

+ 1
- 0
index.php View File

@ -0,0 +1 @@
<?php phpinfo();

+ 29
- 0
package.json View File

@ -0,0 +1,29 @@
{
"name": "Guardian",
"version": "0.0.1",
"description": "Proof-of-concept for the guardian service.",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"repository": {
"type": "git",
"url": "git+ssh://git@bitbucket.org/leothelocust/guardian-proof-of-concept.git"
},
"author": "Levi Olson <olson.levi@gmail.com>",
"license": "UNLICENSED",
"homepage": "https://bitbucket.org/leothelocust/guardian-proof-of-concept#readme",
"dependencies": {
"bcrypt": "^0.8.5",
"body-parser": "^1.14.2",
"dot-env": "0.0.1",
"express": "^4.13.3",
"mysql": "^2.10.0",
"passport": "^0.3.2",
"passport-custom": "^1.0.5",
"passport-http": "^0.3.0",
"passport-local": "^1.0.0",
"querystring": "^0.2.0",
"request": "^2.67.0"
}
}

Loading…
Cancel
Save