102 lines
2.0 KiB
JavaScript
102 lines
2.0 KiB
JavaScript
'use strict';
|
|
|
|
const mw = require('../middleware.js'),
|
|
router = require('express').Router(),
|
|
slug = require('slug'),
|
|
xss = require('xss'),
|
|
User = require('../models.js').user;
|
|
|
|
module.exports = router
|
|
|
|
// Index
|
|
.get('/', (req,res,next)=>{
|
|
res.render('index');
|
|
})
|
|
|
|
// Help
|
|
.get('/help', (req,res)=>{
|
|
res.render('help');
|
|
})
|
|
|
|
// Terms of Service and Privacy Policy
|
|
.get('/terms', (req,res)=>{
|
|
res.render('terms');
|
|
})
|
|
.get('/privacy', (req,res)=>{
|
|
res.render('privacy');
|
|
})
|
|
|
|
// robots.txt
|
|
.get('/robots.txt', (req,res)=>{
|
|
res.type('text/plain');
|
|
res.send("User-agent: *\n"+
|
|
"Disallow: /map/*\n"
|
|
);
|
|
})
|
|
|
|
// favicon.ico
|
|
.get('/favicon.ico', (req,res)=>{
|
|
res.redirect('/static/img/icon/by/16-32-48.ico');
|
|
})
|
|
|
|
// Endpoint to validate forms
|
|
.get('/validate', (req,res,next)=>{
|
|
|
|
// 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);
|
|
});
|
|
}
|
|
|
|
// 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);
|
|
});
|
|
}
|
|
|
|
// Create slug
|
|
else if (req.query.slugify) {
|
|
res.send(slug(xss(req.query.slugify)));
|
|
}
|
|
|
|
// Sanitize for XSS
|
|
else if (req.query.xss) {
|
|
res.send(xss(req.query.xss));
|
|
}
|
|
|
|
// 404
|
|
else { next(); }
|
|
|
|
})
|
|
|
|
// 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');
|
|
})
|
|
|
|
;
|