server.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. require('./configToEnv');
  2. require('dotenv').config();
  3. const nextApp = require('next');
  4. const express = require('express');
  5. const helmet = require('helmet');
  6. const morgan = require('morgan');
  7. const Raven = require('raven');
  8. const cookieParser = require('cookie-parser');
  9. const bodyParser = require('body-parser');
  10. const passport = require('passport');
  11. const cors = require('cors');
  12. const {
  13. validateBody,
  14. validationCriterias,
  15. validateUrl,
  16. ipCooldownCheck,
  17. } = require('./controllers/validateBodyController');
  18. const auth = require('./controllers/authController');
  19. const url = require('./controllers/urlController');
  20. require('./cron');
  21. require('./passport');
  22. if (process.env.RAVEN_DSN) {
  23. Raven.config(process.env.RAVEN_DSN).install();
  24. }
  25. const catchErrors = fn => (req, res, next) =>
  26. fn(req, res, next).catch(err => {
  27. res.status(500).json({ error: 'Sorry an error ocurred. Please try again later.' });
  28. if (process.env.RAVEN_DSN) {
  29. Raven.captureException(err, {
  30. user: { email: req.user && req.user.email },
  31. });
  32. } else {
  33. throw new Error(err);
  34. }
  35. });
  36. const port = Number(process.env.PORT) || 3000;
  37. const dev = process.env.NODE_ENV !== 'production';
  38. const app = nextApp({ dir: './client', dev });
  39. const handle = app.getRequestHandler();
  40. app.prepare().then(() => {
  41. const server = express();
  42. server.set('trust proxy', true);
  43. server.use(helmet());
  44. if (process.env.NODE_ENV !== 'production') {
  45. server.use(morgan('dev'));
  46. }
  47. server.use(cookieParser());
  48. server.use(bodyParser.json());
  49. server.use(bodyParser.urlencoded({ extended: true }));
  50. server.use(passport.initialize());
  51. server.use(express.static('static'));
  52. server.use((req, res, next) => {
  53. req.realIp = req.headers['x-real-ip'] || req.connection.remoteAddress || '';
  54. return next();
  55. });
  56. server.use(url.customDomainRedirection);
  57. /* View routes */
  58. server.get('/', (req, res) => app.render(req, res, '/'));
  59. server.get('/login', (req, res) => app.render(req, res, '/login'));
  60. server.get('/logout', (req, res) => app.render(req, res, '/logout'));
  61. server.get('/settings', (req, res) => app.render(req, res, '/settings'));
  62. server.get('/stats', (req, res) => app.render(req, res, '/stats', req.query));
  63. server.get('/terms', (req, res) => app.render(req, res, '/terms'));
  64. server.get('/report', (req, res) => app.render(req, res, '/report'));
  65. server.get('/banned', (req, res) => app.render(req, res, '/banned'));
  66. server.get('/offline', (req, res) => app.render(req, res, '/offline'));
  67. server.get('/reset-password/:resetPasswordToken?', catchErrors(auth.resetPassword), (req, res) =>
  68. app.render(req, res, '/reset-password', req.user)
  69. );
  70. server.get('/verify/:verificationToken?', catchErrors(auth.verify), (req, res) =>
  71. app.render(req, res, '/verify', req.user)
  72. );
  73. // Disabled service worker because of multiple requests
  74. // Resulting in duplicated visist count
  75. server.get('/sw.js', (_req, res) => {
  76. res.sendFile(`${__dirname}/offline/sw.js`);
  77. });
  78. /* User and authentication */
  79. server.post('/api/auth/signup', validationCriterias, validateBody, catchErrors(auth.signup));
  80. server.post('/api/auth/login', validationCriterias, validateBody, auth.authLocal, auth.login);
  81. server.post('/api/auth/renew', auth.authJwt, auth.renew);
  82. server.post('/api/auth/changepassword', auth.authJwt, catchErrors(auth.changePassword));
  83. server.post('/api/auth/generateapikey', auth.authJwt, catchErrors(auth.generateApiKey));
  84. server.post('/api/auth/resetpassword', catchErrors(auth.requestPasswordReset));
  85. server.get('/api/auth/usersettings', auth.authJwt, auth.userSettings);
  86. /* URL shortener */
  87. server.post(
  88. '/api/url/submit',
  89. cors(),
  90. auth.authApikey,
  91. auth.authJwtLoose,
  92. catchErrors(auth.recaptcha),
  93. catchErrors(validateUrl),
  94. catchErrors(ipCooldownCheck),
  95. catchErrors(url.urlShortener)
  96. );
  97. server.post('/api/url/deleteurl', auth.authApikey, auth.authJwt, catchErrors(url.deleteUrl));
  98. server.get('/api/url/geturls', auth.authApikey, auth.authJwt, catchErrors(url.getUrls));
  99. server.post('/api/url/customdomain', auth.authJwt, catchErrors(url.setCustomDomain));
  100. server.delete('/api/url/customdomain', auth.authJwt, catchErrors(url.deleteCustomDomain));
  101. server.get('/api/url/stats', auth.authApikey, auth.authJwt, catchErrors(url.getStats));
  102. server.post('/api/url/requesturl', catchErrors(url.goToUrl));
  103. server.post('/api/url/report', catchErrors(url.reportUrl));
  104. server.post(
  105. '/api/url/admin/ban',
  106. auth.authApikey,
  107. auth.authJwt,
  108. auth.authAdmin,
  109. catchErrors(url.ban)
  110. );
  111. server.get('/:id', catchErrors(url.goToUrl), (req, res) => {
  112. switch (req.pageType) {
  113. case 'password':
  114. return app.render(req, res, '/url-password', req.protectedUrl);
  115. case 'info':
  116. default:
  117. return app.render(req, res, '/url-info', req.urlTarget);
  118. }
  119. });
  120. server.get('*', (req, res) => handle(req, res));
  121. server.listen(port, err => {
  122. if (err) throw err;
  123. console.log(`> Ready on http://localhost:${port}`); // eslint-disable-line no-console
  124. });
  125. });