1
0
mirror of https://github.com/stolksdorf/homebrewery.git synced 2025-12-23 09:31:31 +00:00

moved welcome message and adding in egads errors

This commit is contained in:
Scott Tolksdorf
2017-01-01 10:38:36 -08:00
parent 1173af5803
commit 95c09ba7ad
8 changed files with 82 additions and 142 deletions

View File

@@ -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
View File

@@ -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('<', '&lt;').replaceAll('>', '&gt;');
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;

View File

@@ -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);

View File

@@ -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);
@@ -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
View 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;

View File

@@ -2,14 +2,23 @@ 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,
@@ -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;

View File

@@ -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