var parseCookie = connect.utils.parseCookie;
var Backchannel = require('./bc/backchannel');
-// ********************************
-// For facebook oauth and connect
-// ********************************
-var everyauth = require('everyauth');
-var FacebookClient = require('facebook-client').FacebookClient;
-var facebook = new FacebookClient();
-
-everyauth.debug = true;
-
-// configure facebook authentication
-everyauth.facebook
- .appId('118001624986867')
- .appSecret('c74910f00dea3d083a00572a445af3ae')
- .scope('user_likes,user_photos,user_photo_video_tags,email')
- .entryPath('/fbauth')
- .redirectPath('/profile')
- .findOrCreateUser(function(req) {
- log3(req.user)
- console.log(req.user);
- User.findOne( { }, function( err, user ) {
- log3(err)
- log3(user)
- // if a user exists with that email, call them logged in
- // FIXME: change this to different query on 'fbid'
- if(user) {
- // save the fact that this cookie/session-id is right for this user
- var sid = req.sessionID;
- user.session = sid;
- user.save( function() {
- //req.session.email = 'fuckles';
- sendJson(res, {status: 'ok', message:'Successfully logged in via Fb'});
- });
- }
- });
- });
- //.callbackPath('/fbsucc')
-
-
-
// Depracated
// Used for initial testing
// requests that otherwise aren't handled by default.
app.use( express.methodOverride() );
// Static files are loaded when no dynamic views match.
- app.use( express.static( __dirname + '/public' ) );
-
- // EveryAuth fb connect
- app.use( everyauth.middleware() );
+ app.use( express.static( __dirname + '/public', {maxAge: 900000} ) );
// Sets the routers middleware to load after everything set
// before it, but before static files.
//sys.puts(school);
if( school ) {
req.school = school;
- //req.school.authorized = authorized;
// If a school is found, the user is checked to see if they are
// authorized to see or interact with anything related to that
// school.
- //school.authorize( user, function( authorized ){
- //});
+ school.authorize( user, function( authorized ){
+ req.school.authorized = authorized;
+ });
next();
} else {
// If no school is found, display an appropriate error.
});
}
-function loadSchoolSlug( req, res, next ) {
- var user = req.user;
- var schoolSlug = req.params.slug;
-
- console.log("loading a school by slug");
- //console.log(schoolSlug);
-
- School.findOne({ 'slug': schoolSlug }, function( err, school ) {
- console.log( school );
- if( school ) {
- req.school = school;
-
- // If a school is found, the user is checked to see if they are
- // authorized to see or interact with anything related to that
- // school.
- next()
- //school.authorize( user, function( authorized ){
- //req.school.authorized = authorized;
- //next();
- //});
- } else {
- // If no school is found, display an appropriate error.
- sendJson(res, {status: 'not_found', message: 'Invalid school specified!'} );
- }
- });
-}
-
// loadSchool is used to load a course by it's id
function loadCourse( req, res, next ) {
var user = req.user;
if ( req.xhr ) {
next();
} else {
- res.sendfile( 'public/index.html' );
+ res.sendfile( 'public/index.html', function(err){
+ if(err){
+ console.log(err);
+ }
+ });
}
}
res.json(obj);
}
-// Routes
-// The following are the main CRUD routes that are used
-// to make up this web app.
-
-// Homepage
-// Public
-/*
-app.get( '/', loadUser, function( req, res ) {
- log3("get / page");
-
- res.render( 'index' );
-});
-*/
// Schools list
-// Used to display all available schools and any courses
-// in those schools.
+// Used to display all available schools
// Public with some private information
app.get( '/schools', checkAjax, loadUser, function( req, res ) {
var user = req.user;
description: s.description,
url: s.url,
slug: s.slug,
- courses: s.courses_length
+ courses: s.courses_length,
+ courseNum: s.courseNum
};
return school;
})
app.get( '/school/:name', checkAjax, loadUser, loadSchool, function( req, res ) {
var school = req.school;
var user = req.user;
- var courses;
- console.log( 'loading a school by school/:id now name' );
-
- //school.authorize( user, function( authorized ) {
- // This is used to display interface elements for those users
- // that are are allowed to see th)m, for instance a 'New Course' button.
- //var sanitizedSchool = school.sanitized;
- var sanitizedSchool = {
- _id: school.id,
- name: school.name,
- description: school.description,
- url: school.url
- };
- //sanitizedSchool.authorized = authorized;
- // Find all courses for school by it's id and sort by name
- Course.find( { 'school' : school._id } ).sort( 'name', '1' ).run( function( err, courses ) {
- // If any courses are found, set them to the appropriate school, otherwise
- // leave empty.
- sys.puts(courses);
- if( courses.length > 0 ) {
- courses = courses.filter(function(course) {
- if (!course.deleted) return course;
- }).map(function(course) {
- return course.sanitized;
- });
- } else {
- school.courses = [];
- }
- sanitizedSchool.courses = courses;
- sys.puts(courses);
-
- // This tells async (the module) that each iteration of forEach is
- // done and will continue to call the rest until they have all been
- // completed, at which time the last function below will be called.
- sendJson(res, { 'school': sanitizedSchool, 'user': user.sanitized })
- });
- //});
-});
-
-// FIXME: version of the same using school slugs instead of ids
-// TODO: merge this with the :id funciton or depricate it
-app.get( '/schoolslug/:slug', checkAjax, loadUser, loadSchoolSlug, function( req, res ) {
- var school = req.school;
- var user = req.user;
- console.log( 'loading a schoolslug/:slug' );
+ console.log("Loading a school");
school.authorize( user, function( authorized ) {
// This is used to display interface elements for those users
// that are are allowed to see th)m, for instance a 'New Course' button.
var sanitizedSchool = school.sanitized;
+ //var sanitizedSchool = {
+ // _id: school.id,
+ // name: school.name,
+ // description: school.description,
+ // url: school.url
+ //};
sanitizedSchool.authorized = authorized;
// Find all courses for school by it's id and sort by name
Course.find( { 'school' : school._id } ).sort( 'name', '1' ).run( function( err, courses ) {
// If any courses are found, set them to the appropriate school, otherwise
// leave empty.
+
if( courses.length > 0 ) {
sanitizedSchool.courses = courses.filter(function(course) {
if (!course.deleted) return course;
return course.sanitized;
});
} else {
- sanitizedSchool.courses = [];
+ school.courses = [];
}
+
// This tells async (the module) that each iteration of forEach is
// done and will continue to call the rest until they have all been
// completed, at which time the last function below will be called.
// Logut user
app.get( '/logout', checkAjax, function( req, res ) {
+ sys.puts("logging out");
var sid = req.sessionID;
// Find user by session id
});
var backchannel = new Backchannel(app, io.of('/backchannel'), {
+ // TODO: if lecture belongs to course (find pinker's courseId) pass a 'no-answers' true/false
subscribe: function(lecture, send) {
Post.find({'lecture': lecture}, function(err, posts) {
send(posts);
var mailer = new Mailer( app.set('awsAccessKey'), app.set('awsSecretKey') );
-everyauth.helpExpress(app);
-
app.listen( serverPort, function() {
console.log( "Express server listening on port %d in %s mode", app.address().port, app.settings.env );