aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/config
diff options
context:
space:
mode:
authorDennis Eriksen <dennis.se@gmail.com>2013-04-29 09:16:00 +0200
committerDennis Eriksen <dennis.se@gmail.com>2013-04-29 09:16:00 +0200
commitdd061b09ae345a272810984335cc84281b0c87ce (patch)
treeb7c6d40673d3452a4a1456ba9370eca1cec986f1 /config
parentWrong location for img (diff)
parentcleaning (diff)
downloadDivid-dd061b09ae345a272810984335cc84281b0c87ce.tar.gz
Merge branch 'dev'
Conflicts: app.js router.js
Diffstat (limited to 'config')
-rw-r--r--config/config.js25
-rw-r--r--config/email-settings.js13
-rw-r--r--config/express.js60
-rw-r--r--config/middlewares/authorization.js13
-rw-r--r--config/passport.js109
5 files changed, 207 insertions, 13 deletions
diff --git a/config/config.js b/config/config.js
new file mode 100644
index 0000000..50dea23
--- /dev/null
+++ b/config/config.js
@@ -0,0 +1,25 @@
+var path = require('path')
+ , rootPath = path.normalize(__dirname + '/..');
+
+
+module.exports = {
+ development: {
+ db: 'mongodb://localhost/test',
+ root: rootPath,
+ app: {
+ name: 'Divid'
+ },
+ facebook: {
+ clientID: "504825706245603",
+ clientSecret: "e5ea0faed85d8749cafd38732530ef35",
+ callbackURL: "https://divid.no/auth/facebook/callback"
+ },
+ twitter: {
+ clientID: "tpCfKBUyAfogTpFxnb9w",
+ clientSecret: "abzInK4Nu0IFUhyXl73O2XjlFLFlzmBtLmbXk6v8",
+ callbackURL: "https://divid.no/auth/twitter/callback"
+ }
+ }
+}
+
+
diff --git a/config/email-settings.js b/config/email-settings.js
deleted file mode 100644
index 8bc9983..0000000
--- a/config/email-settings.js
+++ /dev/null
@@ -1,13 +0,0 @@
-/**
- * Email settings
- */
-
-module.exports = {
-
- host: 'localhost',
- user: 'divid',
- password: '',
- sender: 'Divid <divid@divid.no>'
-
-}
-
diff --git a/config/express.js b/config/express.js
new file mode 100644
index 0000000..eb10b20
--- /dev/null
+++ b/config/express.js
@@ -0,0 +1,60 @@
+
+/**
+ * Module dependencies
+ */
+
+var express = require('express');
+
+
+/**
+ * Module
+ */
+
+module.exports = function (app, config, passport) {
+
+ //sets view engine and path
+ app.set('views', config.root + '/views');
+ app.set('view engine', 'ejs');
+
+ app.use(express.static(config.root + '/public'));
+
+ // don't use logger for test enc
+ if (process.env.NODE_ENV !== 'test') app.use(express.logger('dev'));
+
+
+ app.configure(function () {
+
+ app.use(express.cookieParser()); //must be above sessions
+
+ app.use(express.bodyParser()); //must be above methodOverride
+
+ app.use(express.methodOverride());
+
+ app.use(express.session({ secret: 'lsdrghoi4hgqio42nqf2uqi32f3bilu23fl23b' }));
+
+ // use passport session
+ app.use(passport.initialize());
+ app.use(passport.session());
+
+ app.use(express.favicon(__dirname + '/public/faviconb.ico'));
+
+ // use LESS for CSS
+ app.use(require('less-middleware')({ src: config.root + '/public' }));
+
+ app.use(app.router);
+
+ app.use(function(err, req, res, next) {
+ if (~err.message.indexOf('not fount')) return next(); // treat like 404
+
+ console.error(err.stack);
+
+ res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); // render page
+ });
+
+ app.use(function(req, res, next) {
+ res.status(404).render('error', { title: '404', text: 'Fant ikke siden du så etter' }); // render page
+ });
+ });
+}
+
+
diff --git a/config/middlewares/authorization.js b/config/middlewares/authorization.js
new file mode 100644
index 0000000..440f085
--- /dev/null
+++ b/config/middlewares/authorization.js
@@ -0,0 +1,13 @@
+
+
+/*
+ * Generic require login routing
+ */
+
+exports.requiresLogin = function(req, res, next) {
+ if (!req.isAuthenticated()) return res.redirect('/login');
+ next();
+}
+
+
+
diff --git a/config/passport.js b/config/passport.js
new file mode 100644
index 0000000..9518409
--- /dev/null
+++ b/config/passport.js
@@ -0,0 +1,109 @@
+// dependencies
+var mongoose = require('mongoose')
+ , LocalStrategy = require('passport-local').Strategy
+ , FacebookStrategy = require('passport-facebook').Strategy
+ , TwitterStrategy = require('passport-twitter').Strategy
+ , User = mongoose.model('User');
+
+/**
+ * This is where the magic happends
+ */
+
+module.exports = function (passport, config) {
+
+ // serialize sessions
+ passport.serializeUser( function(user, done) {
+ done(null, user.id);
+ });
+ passport.deserializeUser( function(id, done) {
+ User.findOne({ _id: id }, function(err, user) {
+ done(err, user);
+ });
+ });
+
+
+ /**
+ * Local strategy
+ */
+ passport.use(new LocalStrategy({
+ usernameField: 'email',
+ passwordField: 'password'
+ }, function(email, password, done) {
+
+ // looks up the user in the database, and check if password matches
+ User.findOne({ email: email }, function(err, user) {
+ if (err) return done(err);
+ if (!user) return done(null, false, { message: 'Unknown user' });
+ if (!user.authenticate(password)) return done(null, false, { message: 'Invalid password' });
+ return done(null, user);
+ });
+ }));
+
+
+ /**
+ * Facebook strategy
+ */
+ passport.use(new FacebookStrategy({
+ clientID: config.facebook.clientID
+ , clientSecret: config.facebook.clientSecret
+ , callbackURL: config.facebook.callbackURL
+ }, function(accessToken, refreshToken, profile, done) {
+
+ // looks up the user in the database. Will create the user if it does not exist
+ User.findOne({ 'facebook.id': profile.id }, function(err, user) {
+ if(err) return done(err);
+ if (!user) {
+ user = new User({
+ name: profile.displayName
+ , email: profile.emails[0].value
+ , username: profile.username
+ , provider: 'facebook'
+ , facebook: profile._json
+ });
+ user.save(function(err) {
+ if (err) console.log(err);
+ return done(err, user);
+ });
+ } else {
+ return done(err, user);
+ }
+ });
+ }));
+
+
+ /**
+ * Twitter strategy
+ */
+ passport.use(new TwitterStrategy({
+ consumerKey: config.twitter.clientID
+ , consumerSecret: config.twitter.clientSecret
+ , callbackURL: config.twitter.callbackURL
+ }, function(token, tokenSecret, profile, done) {
+
+ // looks up the user in the database. Will create the user if it does not exist
+ User.findOne({ 'twitter.id': profile.id }, function(err, user) {
+ if (err) return done(err);
+ if (!user) {
+ user = new User({
+ name: profile.displayName
+ , username: profile.username
+ , provider: 'twitter'
+ , twitter: profile._json
+ });
+ user.save(function(err) {
+ if (err) console.log(err);
+ return done(err, user);
+ });
+ } else {
+ return done(err, user);
+ }
+ });
+ }));
+
+
+
+
+
+
+}
+