added private public view to profile -- todo : add same for article view

This commit is contained in:
2013-01-17 17:30:16 -05:00
parent 89308a0c3e
commit 7b6a0df4a5
13 changed files with 42 additions and 31 deletions

View File

@@ -2,8 +2,7 @@ var Schema = require('mongoose').Schema;
var ArticleSchema = new Schema({
title: {
type: String,
unique: true
type: String
},
body: String,
author: {

View File

@@ -1,9 +1,9 @@
var mongoose = require('mongoose');
var UserSchema = new mongoose.Schema({
username: {type: String, unique: true},
username: {type: String, unique: true, required: true},
name: String,
password: String,
password: String
});
UserSchema.methods.recentArticles = function(callback) {

View File

@@ -13,7 +13,7 @@ var maxArticlesPerPage = 5;
module.exports = function(app) {
app.get('/articles', function(req, res, next){
app.get('/articles', loggedIn, function(req, res, next){
var page = req.query.page && parseInt(req.query.page, 10) || 0;
async.parallel([
@@ -57,7 +57,7 @@ module.exports = function(app) {
res.render('articles/new', {title: "New Article"});
});
app.get('/articles/:title', loadArticle, function(req, res, next){
app.get('/articles/:_id', loadArticle, function(req, res, next){
res.render('articles/article', {title: req.article.title,
article: req.article});
});

View File

@@ -3,9 +3,11 @@
* GET home page.
*/
var loggedIn = require('./middleware/logged_in');
module.exports = function(app) {
app.get('/', function(req, res){
res.render('index', { title: 'Express' })
app.get('/', loggedIn, function(req, res){
res.render('index', { title: 'Express' });
});
};

View File

@@ -1,6 +1,7 @@
function loggedIn(req, res, next) {
if (! req.session.user) {
res.send('Forbidden. Please log in first.', 403);
//res.send('Forbidden. Please log in first.', 403);
res.redirect('/session/new');
} else {
next();
}

View File

@@ -1,6 +1,6 @@
function notLoggedIn(req, res, next) {
if (req.session.user) {
res.send('Unauthorized', 401);
res.redirect('/users/' + req.session.user.username);
} else {
next();
}

View File

@@ -17,6 +17,7 @@ module.exports = function(app) {
}
if (user) {
req.session.user = user;
console.log("req.session.user= " + JSON.stringify(req.session.user));
res.redirect('/users');
} else {
res.redirect('/session/new');
@@ -26,6 +27,6 @@ module.exports = function(app) {
app.del('/session', function(req, res, next) {
req.session.destroy();
res.redirect('/users');
res.redirect('/session/new');
});
};

View File

@@ -4,13 +4,14 @@
var User = require('../data/models/user');
var notLoggedIn = require('./middleware/not_logged_in');
var loggedIn = require('./middleware/logged_in');
var loadUser = require('./middleware/load_user');
var restrictUserToSelf = require('./middleware/restrict_user_to_self');
var maxUsersPerPage = 5;
module.exports = function(app) {
app.get('/users', function(req, res, next){
app.get('/users', loggedIn, function(req, res, next){
var page = req.query.page && parseInt(req.query.page, 10) || 0;
User.count(function(err, count) {

View File

@@ -9,7 +9,7 @@ block content
p
span Author:
 
a(href="/users/" + encodeURIComponent(article.author.username))= article.author.full_name
a(href="/users/" + encodeURIComponent(article.author.name))= article.author.name
p
a(href="/articles") Back to all articles

View File

@@ -1,8 +1,5 @@
extends ../layout
block content
ul
- articles.forEach(function(article) {
li
a(href="/articles/" + encodeURIComponent(article.title))= article.title
- });
ul
- articles.forEach(function(article) {
li
a(href="/articles/" + encodeURIComponent(article._id))= article.title
- });

View File

@@ -11,4 +11,7 @@ block content
label(for="password") Password:<br />
input#password(type="password", name="password")
p
input(type="submit", value="Log in");
input(type="submit", value="Log in");
p
a(href="/users/new") Register New User

View File

@@ -1,14 +1,12 @@
- if (session.user)
p
span Hello&nbsp;
span
b UserName&nbsp;
span= session.user.name
span !
span
b &nbspUserID&nbsp;
span= session.user._id
p
form(method="POST", action="/session")
input(type="hidden", name="_method", value="DELETE")
input(type="submit", value="Log out")
- else
p
a(href="/session/new") Login
span &nbsp;or&nbsp;
a(href="/users/new") Register
input(type="submit", value="Log out")

View File

@@ -2,8 +2,17 @@ extends ../layout
block content
h1= user.name
- if (session.user)
h1 Private View
- else
h1 Public View
h2 Recent Articles:
p!= partial('articles/list', {articles: recentArticles })
ul
- recentArticles.forEach(function(article) {
li
a(href="/articles/" + encodeURIComponent(article._id))= article.title
- });
form(action="/users/" + encodeURIComponent(user.username), method="POST")