nurl/app.js
Martin Donnelly eb0b076fed gulp stuff
2017-08-07 22:21:36 +01:00

127 lines
3.2 KiB
JavaScript

const express = require('express');
const app = express();
const path = require('path');
const bodyParser = require('body-parser');
const mongoose = require('mongoose');
const config = require('./config');
const base58 = require('./base58.js');
const log4js = require('log4js');
const logger = log4js.getLogger();
const compression = require('compression');
const favicon = require('express-favicon');
logger.level = 'debug';
// grab the url model
const Url = require('./models/url');
let isProduction = false;
let sitePath = 'public';
let indexView = 'views/index.html';
let listView = 'views/list.html';
process.env.NODE_ENV = process.env.NODE_ENV || 'dev';
if (process.env.NODE_ENV === 'prod') {
isProduction = true;
sitePath = 'live';
indexView = 'dist/index.html'
}
logger.warn(`isProduction:${isProduction}`);
mongoose.connect('mongodb://' + config.db.host + '/' + config.db.name);
app.use(compression());
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(express.static(path.join(__dirname, sitePath)));
app.use(favicon(__dirname + '/live/favicon-16x16.png'));
app.all('/*', function(req, res, next) {
// CORS headers
res.header("Access-Control-Allow-Origin", "*"); // restrict it to the required domain
res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');
// Set custom headers for CORS
res.header('Access-Control-Allow-Headers', 'Content-type,Accept,X-Access-Token,X-Key');
if (req.method == 'OPTIONS') {
res.status(200).end();
} else {
next();
}
});
app.get('/', function(req, res){
res.sendFile(path.join(__dirname, indexView));
});
app.get('/admin/list', function(req, res){
res.sendFile(path.join(__dirname, listView));
});
app.post('/api/v1/shorten', function(req, res){
const longUrl = req.body.url;
let shortUrl = '';
// check if url already exists in database
Url.findOne({long_url: longUrl}, function (err, doc){
if (doc){
shortUrl = config.webhost + base58.encode(doc._id);
// the document exists, so we return it without creating a new entry
res.send({'shortUrl': shortUrl});
} else {
// since it doesn't exist, let's go ahead and create it:
const newUrl = Url({
long_url: longUrl
});
// save the new link
newUrl.save(function(err) {
if (err){
logger.error(err);
}
shortUrl = config.webhost + base58.encode(newUrl._id);
res.send({'shortUrl': shortUrl});
});
}
});
});
app.get('/api/v1/list', function(req, res){
Url.find({}, function(err, doc) {
if (doc) {
logger.debug(doc);
}
})
});
app.get('/:encoded_id', function(req, res){
const base58Id = req.params.encoded_id;
const id = base58.decode(base58Id);
// check if url already exists in database
Url.findOneAndUpdate({_id: id}, {$inc:{visits:1}}, function (err, doc){
if (doc) {
logger.debug(`Redirect: ${doc.long_url}`);
res.redirect(doc.long_url);
} else {
res.redirect(config.webhost);
}
});
});
const server = app.listen(config.port, function () {
logger.info(`Server listening on port ${config.port}`);
});