This repository has been archived by the owner on Feb 3, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 201
/
Copy pathapp.js
120 lines (108 loc) · 3.9 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
'use strict';
// Environment
require('dotenv').config();
process.env.TZ = 'UTC';
// Globals
global.__basedir = __dirname;
global.__version = require('./package.json').version;
// Node modules
const Adaro = require('adaro');
const BodyParser = require('body-parser');
const Chalk = require('chalk');
const CookieParser = require('cookie-parser');
const Compression = require('compression');
const Express = require('express');
const Fs = require('fs');
const Path = require('path');
const Promise = require('bluebird');
const Slashes = require('connect-slashes');
// Express app
const app = Express();
const AdminRouter = require(Path.join(__basedir, 'source/routers/admin_router.js'));
const ApiRouter = require(Path.join(__basedir, 'source/routers/api_router.js'));
const ThemeRouter = require(Path.join(__basedir, 'source/routers/theme_router.js'));
const AuthMiddleware = require(Path.join(__basedir, 'source/middleware/auth_middleware'));
const ViewMiddleware = require(Path.join(__basedir, 'source/middleware/view_middleware.js'));
const ErrorController = require(Path.join(__basedir, 'source/controllers/error_controller.js'));
const DynamicImages = require(Path.join(__basedir, 'source/modules/dynamic_images.js'));
// Database
const Database = require(Path.join(__basedir, 'source/modules/database.js'));
app.locals.Database = Database;
Promise.resolve()
// Make sure .env exists
.then(() => {
if(!Fs.existsSync(Path.join(__basedir, '.env'))) {
throw new Error('Required config file .env is missing.');
}
})
// Initialize the database
.then(() => Database.init())
.then(() => {
let models = Database.sequelize.models;
// Generate search indexes on startup
return Promise.all([
models.post.buildSearchIndex(),
models.user.buildSearchIndex(),
models.tag.buildSearchIndex()
]);
})
// Load settings into app.locals.Settings
.then(() => Database.loadSettings())
.then((settings) => app.locals.Settings = settings)
// Load navigation into app.locals.Navigation
.then(() => Database.sequelize.models.navigation.getArray())
.then((navigation) => app.locals.Navigation = navigation)
// Load i18n into app.locals.I18n
.then(() => {
app.locals.I18n = require(Path.join(__basedir, 'source/modules/i18n.js'));
return app.locals.I18n.load(app.locals.Settings.language);
})
// Start the app
.then(() => {
// App config
app.enable('strict routing');
app.disable('x-powered-by');
// App-level middleware
app
.use(Slashes(false))
.use(CookieParser())
.use(Compression())
.use(DynamicImages.processImages)
.use('/assets', Express.static(Path.join(__basedir, 'assets')))
.use('/themes', Express.static(Path.join(__basedir, 'themes')))
.use('/uploads', Express.static(Path.join(__basedir, 'uploads')))
.use(BodyParser.urlencoded({ extended: true, limit: '10mb' }))
.use(AuthMiddleware.attachUser)
.use(ViewMiddleware.attachViewData)
.use(ViewMiddleware.enableDynamicViews);
// View engine
app.engine('dust', Adaro.dust({
cache: process.env.NODE_ENV === 'production',
whitespace: true,
helpers: [
'dustjs-helpers',
'source/modules/helpers/html_helpers.js',
'source/modules/helpers/utility_helpers.js',
'source/modules/helpers/theme_helpers.js'
]
}));
app.set('views', Path.join(__basedir, 'source/views'));
app.set('view engine', 'dust');
// App routers
ApiRouter(app);
AdminRouter(app);
ThemeRouter(app);
// Error pages
app.use(ErrorController.notFound);
app.use(ErrorController.applicationError);
// Start sailing! ⚓️
app.listen(process.env.APP_PORT, () => {
console.info('Postleaf publishing on port %d! 🌱', process.env.APP_PORT);
});
})
.catch((err) => {
console.error(
Chalk.red('Error: ') + 'Postleaf failed to start! 🐛\n\n' +
Chalk.red(err.stack)
);
});