tracman-server/config/routes/index.js

107 lines
2.1 KiB
JavaScript
Raw Normal View History

'use strict';
2017-07-04 10:01:11 -06:00
const router = require('express').Router(),
2017-04-10 01:00:56 -06:00
slug = require('slug'),
xss = require('xss'),
2017-05-08 17:01:35 -06:00
User = require('../models.js').user;
2017-03-14 22:05:03 -06:00
2017-04-25 15:22:23 -06:00
module.exports = router
// Index
.get('/', (req,res,next)=>{
2017-05-22 20:32:51 -06:00
res.render('index', {active:'home'});
2017-04-25 15:22:23 -06:00
})
2017-08-20 14:26:47 -06:00
// Demo redirect
.get('/demo', (req,res,next)=>{
res.redirect('/map/demo');
})
2017-04-25 15:22:23 -06:00
// Help
2017-04-28 01:21:16 -06:00
.get('/help', (req,res)=>{
2017-05-22 20:32:51 -06:00
res.render('help', {active:'help'});
2017-04-25 15:22:23 -06:00
})
2017-04-25 15:22:23 -06:00
// Terms of Service and Privacy Policy
.get('/terms', (req,res)=>{
2017-05-22 20:32:51 -06:00
res.render('terms', {active:'terms'});
2017-04-25 15:22:23 -06:00
})
.get('/privacy', (req,res)=>{
2017-05-22 20:32:51 -06:00
res.render('privacy', {active:'privacy'});
2017-04-25 15:22:23 -06:00
})
2017-04-25 15:22:23 -06:00
// robots.txt
.get('/robots.txt', (req,res)=>{
res.type('text/plain');
res.send("User-agent: *\n"+
"Disallow: /map/*\n"
);
})
2017-04-25 15:22:23 -06:00
// favicon.ico
2017-05-22 20:32:51 -06:00
//TODO: Just serve it
2017-04-25 15:22:23 -06:00
.get('/favicon.ico', (req,res)=>{
res.redirect('/static/img/icon/by/16-32-48.ico');
})
2017-04-25 15:22:23 -06:00
// Endpoint to validate forms
.get('/validate', (req,res,next)=>{
2017-04-25 15:22:23 -06:00
// Validate unique slug
if (req.query.slug) {
User.findOne({ slug: slug(req.query.slug) })
.then( (existingUser)=>{
if (existingUser && existingUser.id!==req.user.id) {
res.sendStatus(400);
}
else { res.sendStatus(200); }
})
.catch( (err)=>{
console.error(err);
res.sendStatus(500);
});
2017-04-25 15:22:23 -06:00
}
// Validate unique email
else if (req.query.email) {
User.findOne({ email: req.query.email })
.then( (existingUser)=>{
if (existingUser && existingUser.id!==req.user.id) {
res.sendStatus(400);
}
else { res.sendStatus(200); }
})
.catch( (err)=>{
console.error(err);
res.sendStatus(500);
});
2017-04-25 15:22:23 -06:00
}
// Create slug
else if (req.query.slugify) {
res.send(slug(xss(req.query.slugify)));
}
// Sanitize for XSS
2017-04-25 15:22:23 -06:00
else if (req.query.xss) {
res.send(xss(req.query.xss));
}
// 404
else { next(); }
2017-04-25 15:22:23 -06:00
})
2017-04-25 15:22:23 -06:00
// Link to androidapp in play store
.get('/android', (req,res)=>{
res.redirect('https://play.google.com/store/apps/details?id=us.keithirwin.tracman');
})
// Link to iphone app in the apple store
// ... maybe someday
.get('/ios', (req,res)=>{
res.redirect('/help#why-is-there-no-ios-app');
})
2017-04-10 01:00:56 -06:00
2017-04-25 15:22:23 -06:00
;