mirror of
https://github.com/stolksdorf/homebrewery.git
synced 2025-12-23 08:11:29 +00:00
moved welcome message and adding in egads errors
This commit is contained in:
@@ -19,6 +19,7 @@
|
|||||||
"classnames": "^2.2.0",
|
"classnames": "^2.2.0",
|
||||||
"codemirror": "^5.22.0",
|
"codemirror": "^5.22.0",
|
||||||
"cookie-parser": "^1.4.3",
|
"cookie-parser": "^1.4.3",
|
||||||
|
"egads": "^1.0.1",
|
||||||
"express": "^4.13.3",
|
"express": "^4.13.3",
|
||||||
"jwt-simple": "^0.5.1",
|
"jwt-simple": "^0.5.1",
|
||||||
"lodash": "^4.17.3",
|
"lodash": "^4.17.3",
|
||||||
|
|||||||
103
server.js
103
server.js
@@ -29,110 +29,11 @@ app.use(mw.admin);
|
|||||||
|
|
||||||
|
|
||||||
//Routes
|
//Routes
|
||||||
|
app.use(require('./server/brew.api.js'));
|
||||||
|
|
||||||
app.use(require('./server/interface.routes.js'));
|
app.use(require('./server/interface.routes.js'));
|
||||||
app.use(require('./server/homebrew.api.js'));
|
|
||||||
app.use(require('./server/admin.api.js'));
|
|
||||||
|
|
||||||
|
|
||||||
const HomebrewModel = require('./server/homebrew.model.js').model;
|
//app.use(require('./server/admin.api.js'));
|
||||||
const welcomeText = require('fs').readFileSync('./client/homebrew/pages/homePage/welcome_msg.md', 'utf8');
|
|
||||||
const changelogText = require('fs').readFileSync('./changelog.md', 'utf8');
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//Source page
|
|
||||||
String.prototype.replaceAll = function(s,r){return this.split(s).join(r)}
|
|
||||||
app.get('/source/:id', (req, res)=>{
|
|
||||||
HomebrewModel.get({shareId : req.params.id})
|
|
||||||
.then((brew)=>{
|
|
||||||
const text = brew.text.replaceAll('<', '<').replaceAll('>', '>');
|
|
||||||
return res.send(`<code><pre>${text}</pre></code>`);
|
|
||||||
})
|
|
||||||
.catch((err)=>{
|
|
||||||
console.log(err);
|
|
||||||
return res.status(404).send('Could not find Homebrew with that id');
|
|
||||||
})
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
app.get('/user/:username', (req, res, next) => {
|
|
||||||
const fullAccess = req.account && (req.account.username == req.params.username);
|
|
||||||
HomebrewModel.getByUser(req.params.username, fullAccess)
|
|
||||||
.then((brews) => {
|
|
||||||
req.brews = brews;
|
|
||||||
return next();
|
|
||||||
})
|
|
||||||
.catch((err) => {
|
|
||||||
console.log(err);
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
app.get('/edit/:id', (req, res, next)=>{
|
|
||||||
HomebrewModel.get({editId : req.params.id})
|
|
||||||
.then((brew)=>{
|
|
||||||
req.brew = brew.sanatize();
|
|
||||||
return next();
|
|
||||||
})
|
|
||||||
.catch((err)=>{
|
|
||||||
console.log(err);
|
|
||||||
return res.status(400).send(`Can't get that`);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
//Share Page
|
|
||||||
app.get('/share/:id', (req, res, next)=>{
|
|
||||||
HomebrewModel.get({shareId : req.params.id})
|
|
||||||
.then((brew)=>{
|
|
||||||
return brew.increaseView();
|
|
||||||
})
|
|
||||||
.then((brew)=>{
|
|
||||||
req.brew = brew.sanatize(true);
|
|
||||||
return next();
|
|
||||||
})
|
|
||||||
.catch((err)=>{
|
|
||||||
console.log(err);
|
|
||||||
return res.status(400).send(`Can't get that`);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
//Print Page
|
|
||||||
app.get('/print/:id', (req, res, next)=>{
|
|
||||||
HomebrewModel.get({shareId : req.params.id})
|
|
||||||
.then((brew)=>{
|
|
||||||
req.brew = brew.sanatize(true);
|
|
||||||
return next();
|
|
||||||
})
|
|
||||||
.catch((err)=>{
|
|
||||||
console.log(err);
|
|
||||||
return res.status(400).send(`Can't get that`);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
//Render Page
|
|
||||||
const render = require('vitreum/steps/render');
|
|
||||||
const templateFn = require('./client/template.js');
|
|
||||||
app.use((req, res) => {
|
|
||||||
render('homebrew', templateFn, {
|
|
||||||
version : require('./package.json').version,
|
|
||||||
url: req.originalUrl,
|
|
||||||
welcomeText : welcomeText,
|
|
||||||
changelog : changelogText,
|
|
||||||
brew : req.brew,
|
|
||||||
brews : req.brews,
|
|
||||||
account : req.account
|
|
||||||
})
|
|
||||||
.then((page) => {
|
|
||||||
return res.send(page)
|
|
||||||
})
|
|
||||||
.catch((err) => {
|
|
||||||
console.log(err);
|
|
||||||
return res.sendStatus(500);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
const PORT = process.env.PORT || 8000;
|
const PORT = process.env.PORT || 8000;
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ router.post('/api/brew', (req, res, next)=>{
|
|||||||
});
|
});
|
||||||
|
|
||||||
//Update
|
//Update
|
||||||
router.put('/api/brew/:editId', mw.loadBrew, mw.Validate, (req, res, next)=>{
|
router.put('/api/brew/:editId', mw.loadBrew, (req, res, next)=>{
|
||||||
if(req.account){
|
if(req.account){
|
||||||
req.brew.authors = _.uniq(_.concat(req.brew.authors, req.account.username));
|
req.brew.authors = _.uniq(_.concat(req.brew.authors, req.account.username));
|
||||||
}
|
}
|
||||||
@@ -40,7 +40,7 @@ router.put('/api/brew/:editId', mw.loadBrew, mw.Validate, (req, res, next)=>{
|
|||||||
});
|
});
|
||||||
|
|
||||||
//Delete
|
//Delete
|
||||||
router.delete('/api/brew/:editId', mw.loadBrew, mw.Validate, (req, res, next) => {
|
router.delete('/api/brew/:editId', mw.loadBrew, (req, res, next) => {
|
||||||
BrewData.remove(req.brew.editId)
|
BrewData.remove(req.brew.editId)
|
||||||
.then(()=>{
|
.then(()=>{
|
||||||
return res.sendStatus(200);
|
return res.sendStatus(200);
|
||||||
|
|||||||
@@ -7,21 +7,21 @@ const utils = require('./utils.js');
|
|||||||
|
|
||||||
const BrewSchema = mongoose.Schema({
|
const BrewSchema = mongoose.Schema({
|
||||||
shareId : {type : String, default: shortid.generate, index: { unique: true }},
|
shareId : {type : String, default: shortid.generate, index: { unique: true }},
|
||||||
editId : {type : String, default: shortid.generate, index: { unique: true }},
|
editId : {type : String, default: shortid.generate, index: { unique: true }},
|
||||||
|
|
||||||
text : {type : String, default : ""},
|
text : {type : String, default : ""},
|
||||||
|
|
||||||
title : {type : String, default : ""},
|
title : {type : String, default : ""},
|
||||||
description : {type : String, default : ""},
|
description : {type : String, default : ""},
|
||||||
tags : {type : String, default : ""},
|
tags : {type : String, default : ""},
|
||||||
systems : [String],
|
systems : [String],
|
||||||
authors : [String],
|
authors : [String],
|
||||||
published : {type : Boolean, default : false},
|
published : {type : Boolean, default : false},
|
||||||
|
|
||||||
createdAt : { type: Date, default: Date.now },
|
createdAt : { type: Date, default: Date.now },
|
||||||
updatedAt : { type: Date, default: Date.now},
|
updatedAt : { type: Date, default: Date.now},
|
||||||
lastViewed : { type: Date, default: Date.now},
|
lastViewed : { type: Date, default: Date.now},
|
||||||
views : {type:Number, default:0}
|
views : {type:Number, default:0}
|
||||||
}, { versionKey: false });
|
}, { versionKey: false });
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -35,7 +35,7 @@ BrewSchema.methods.sanatize = function(userName, isAdmin, getText = true){
|
|||||||
return brew;
|
return brew;
|
||||||
};
|
};
|
||||||
*/
|
*/
|
||||||
|
/*
|
||||||
BrewSchema.methods.sanatize = function(req, getText = true){
|
BrewSchema.methods.sanatize = function(req, getText = true){
|
||||||
const brew = this.toJSON();
|
const brew = this.toJSON();
|
||||||
delete brew._id;
|
delete brew._id;
|
||||||
@@ -56,6 +56,12 @@ BrewSchema.methods.increaseView = function(){
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
*/
|
||||||
|
|
||||||
|
BrewSchema.methods.increaseView = function(){
|
||||||
|
this.views = this.views + 1;
|
||||||
|
return this.save();
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
const Brew = mongoose.model('Brew', BrewSchema);
|
const Brew = mongoose.model('Brew', BrewSchema);
|
||||||
@@ -64,7 +70,7 @@ const Brew = mongoose.model('Brew', BrewSchema);
|
|||||||
|
|
||||||
const BrewData = {
|
const BrewData = {
|
||||||
schema : BrewSchema,
|
schema : BrewSchema,
|
||||||
model : Brew,
|
model : Brew,
|
||||||
|
|
||||||
get : (query) => {
|
get : (query) => {
|
||||||
//returns a single brew with the given query
|
//returns a single brew with the given query
|
||||||
@@ -95,8 +101,13 @@ const BrewData = {
|
|||||||
|
|
||||||
|
|
||||||
getByShare : (shareId) => {
|
getByShare : (shareId) => {
|
||||||
//auto sanatize
|
return BrewData.get({ shareId : shareId})
|
||||||
//increase view count
|
.then((brew) => {
|
||||||
|
brew.increaseView();
|
||||||
|
const brewJSON = brew.toJSON();
|
||||||
|
delete brewJSON.editId;
|
||||||
|
return brewJSON;
|
||||||
|
});
|
||||||
},
|
},
|
||||||
getByEdit : (editId) => {
|
getByEdit : (editId) => {
|
||||||
return Brew.get({ editId });
|
return Brew.get({ editId });
|
||||||
|
|||||||
14
server/errors.js
Normal file
14
server/errors.js
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
const egads = require('egads');
|
||||||
|
|
||||||
|
|
||||||
|
const Error = egads.extend('Server Error', 500, 'Generic Server Error');
|
||||||
|
|
||||||
|
Error.noBrew = Error.extend('Can not find a brew with that id', 404);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = Error;
|
||||||
@@ -2,16 +2,25 @@ const _ = require('lodash');
|
|||||||
const utils = require('./utils.js');
|
const utils = require('./utils.js');
|
||||||
const BrewData = require('./brew.data.js');
|
const BrewData = require('./brew.data.js');
|
||||||
const router = require('express').Router();
|
const router = require('express').Router();
|
||||||
|
const mw = require('./middleware.js');
|
||||||
|
|
||||||
|
|
||||||
|
const docs = {
|
||||||
|
welcomeBrew : require('fs').readFileSync('./welcome.brew.md', 'utf8'),
|
||||||
|
changelog : require('fs').readFileSync('./changelog.md', 'utf8'),
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
const vitreumRender = require('vitreum/steps/render');
|
const vitreumRender = require('vitreum/steps/render');
|
||||||
const templateFn = require('./client/template.js');
|
const templateFn = require('./client/template.js');
|
||||||
|
//TODO: Catch errors here?
|
||||||
const renderPage = (req, res, next) => {
|
const renderPage = (req, res, next) => {
|
||||||
return vitreumRender('homebrew', templateFn, {
|
return vitreumRender('homebrew', templateFn, {
|
||||||
url : req.originalUrl,
|
url : req.originalUrl,
|
||||||
version : require('./package.json').version,
|
version : require('./package.json').version,
|
||||||
|
//TODO: add in login path?
|
||||||
|
|
||||||
user : req.account && req.account.username,
|
user : req.account && req.account.username,
|
||||||
brews : req.brews,
|
brews : req.brews,
|
||||||
brew : req.brew
|
brew : req.brew
|
||||||
})
|
})
|
||||||
@@ -24,10 +33,10 @@ const renderPage = (req, res, next) => {
|
|||||||
router.get('/share/:shareId', mw.viewBrew, renderPage);
|
router.get('/share/:shareId', mw.viewBrew, renderPage);
|
||||||
|
|
||||||
//Edit Page
|
//Edit Page
|
||||||
app.get('/edit/:editId', mw.loadBrew, mw.validate, renderPage);
|
router.get('/edit/:editId', mw.loadBrew, renderPage);
|
||||||
|
|
||||||
//Print Page
|
//Print Page
|
||||||
app.get('/print/:shareId', mw.viewBrew, renderPage);
|
router.get('/print/:shareId', mw.viewBrew, renderPage);
|
||||||
|
|
||||||
//Source page
|
//Source page
|
||||||
router.get('/source/:sharedId', mw.viewBrew, (req, res, next)=>{
|
router.get('/source/:sharedId', mw.viewBrew, (req, res, next)=>{
|
||||||
@@ -35,20 +44,36 @@ router.get('/source/:sharedId', mw.viewBrew, (req, res, next)=>{
|
|||||||
return res.send(`<code><pre>${text}</pre></code>`);
|
return res.send(`<code><pre>${text}</pre></code>`);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
//User Page
|
||||||
|
|
||||||
//user Page
|
|
||||||
router.get('/user/:username', (req, res, next) => {
|
router.get('/user/:username', (req, res, next) => {
|
||||||
BrewData.search({ user : req.params.username }, req)
|
BrewData.search({ user : req.params.username })
|
||||||
.then((brews) => {
|
.then((brews) => {
|
||||||
return render(req, { brews : brews });
|
req.brews = brews;
|
||||||
|
return next();
|
||||||
})
|
})
|
||||||
.then(res.send)
|
|
||||||
.catch(next);
|
.catch(next);
|
||||||
});
|
}, renderPage);
|
||||||
|
|
||||||
|
//Search Page
|
||||||
|
router.get('/search', (req, res, next) => {
|
||||||
|
BrewData.search()
|
||||||
|
.then((brews) => {
|
||||||
|
req.brews = brews;
|
||||||
|
return next();
|
||||||
|
})
|
||||||
|
.catch(next);
|
||||||
|
}, renderPage);
|
||||||
|
|
||||||
//Catch all page?
|
//Changelog Page
|
||||||
router.get('*', renderPage);
|
router.get('/changelog', (req, res, next) => {
|
||||||
|
req.brew = { text : docs.changelog };
|
||||||
|
return next();
|
||||||
|
}, renderPage);
|
||||||
|
|
||||||
|
//Home Page
|
||||||
|
router.get('/', (req, res, next) => {
|
||||||
|
req.brew = { text : docs.welcomeBrew };
|
||||||
|
return next();
|
||||||
|
}, renderPage);
|
||||||
|
|
||||||
module.exports = router;
|
module.exports = router;
|
||||||
@@ -32,25 +32,13 @@ const Middleware = {
|
|||||||
if(req.isAdmin) return next();
|
if(req.isAdmin) return next();
|
||||||
return res.sendStatus(401);
|
return res.sendStatus(401);
|
||||||
},
|
},
|
||||||
validate : (req, res, next) => {
|
|
||||||
//Only allow admin or brew authors pass.
|
|
||||||
|
|
||||||
return next();
|
|
||||||
},
|
|
||||||
|
|
||||||
|
|
||||||
//Loaders
|
//Loaders
|
||||||
loadBrew : (req, res, next) => {
|
loadBrew : (req, res, next) => {
|
||||||
//Loads a brew by edit id
|
//Loads a brew by edit id
|
||||||
if(req.params.shareId){
|
|
||||||
BrewData.get({ shareId : req.params.shareId})
|
|
||||||
.then((brew))
|
|
||||||
}else if(req.params.editId){
|
|
||||||
|
|
||||||
|
//TODO: move validate into hurrr
|
||||||
}else{
|
|
||||||
return next();
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
viewBrew : (req, res, next) => {
|
viewBrew : (req, res, next) => {
|
||||||
//load by share
|
//load by share
|
||||||
|
|||||||
Reference in New Issue
Block a user