-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
107 lines (87 loc) · 2.95 KB
/
index.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
import 'dotenv/config';
import express from 'express';
import cors from 'cors';
import path from 'path';
import helmet from 'helmet';
import morgan from 'morgan';
import multer from 'multer';
import config from './config.js';
import { fileURLToPath } from 'url';
import authRouter from './routes/auth.js';
import userRouter from './routes/users.js';
import postRouter from './routes/posts.js';
const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
const app = express();
const router = express.Router();
app.use(express.json());
app.use(cors());
app.use(helmet());
app.use(morgan('common'));
app.use(
helmet.contentSecurityPolicy({
useDefaults: true,
directives: {
"img-src": ["'self'", "https: data:", "data: blob:"]
}
})
);
//TODO: verify user before upload
//TODO: put file upload in separate module
const storage = multer.diskStorage({
destination: (req, file, cb) => {
cb(null, './public/uploads')
},
filename: (req, file, cb) => {
const fileName = Date.now() + file.originalname;
req.newFilename = fileName;
cb(null, fileName);
},
});
const upload = multer({storage});
router.post('/api/upload', upload.single("file"), (req, res) => {
try {
return res.status(200).json({ fileName: req.newFilename });
}
catch (err) {
console.log(err);
}
});
/* ---------------------------------------- */
/* Public directory */
/* ---------------------------------------- */
//TODO: builddir/subdir
app.use(`${config.subdir}/images`, express.static(
path.join(__dirname, 'public/uploads')));
router.use(express.static(
path.resolve(path.join(__dirname, `/${config.builddir}`)))
);
/* ---------------------------------------- */
/* Pass router to subdir */
/* ---------------------------------------- */
app.use(`${config.subdir}/api`, authRouter);
app.use(`${config.subdir}/api/users`, userRouter);
app.use(`${config.subdir}/api/posts`, postRouter);
app.use(config.subdir, router);
/* ---------------------------------------- */
/* Error handler middleware */
/* ---------------------------------------- */
app.use((err, _req, res, _next) => {
const statusCode = err.statusCode || 500;
console.error(err.message, err.stack);
res.status(statusCode).json({ message: err.message });
});
/* -------------------------------------------------- */
/* Catch-all route to index.html */
/* -------------------------------------------------- */
router.get('/*', (_req, res) => {
res.sendFile(path.resolve(__dirname + `/${config.builddir}/index.html`));
});
/* ---------------------------------------- */
/* Listen */
/* ---------------------------------------- */
console.log('builddir: ' + path.join(__dirname, `/${config.builddir}`));
console.log(`subdir: ${config.subdir}`);
app.listen(config.port, () => {
console.log(`Server listening on port ${config.port}`);
});