-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbanners.js
More file actions
108 lines (96 loc) · 2.54 KB
/
banners.js
File metadata and controls
108 lines (96 loc) · 2.54 KB
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
const router = require("express").Router();
const adminTokenValidation = require("./tokenValidations/adminTokenValidation");
const db = require("./db");
const multer = require("multer");
const path = require("path");
const fs = require("fs");
const imgUpload = require('./uploadImages');
let storage = multer.diskStorage({
destination: (req, file, cb) => {
// let dir = "./public/banners";
let dir = "./public/temp";
if (!fs.existsSync(dir)) {
fs.mkdirSync(dir, { recursive: true });
cb(null, dir);
} else {
cb(null, dir);
}
},
filename: (req, file, cb) => {
let paths = path.parse(file.originalname);
if (paths.ext.trim().length > 0) {
cb(null, Date.now() + file.originalname);
} else {
let ext = getFileType(file.mimetype);
if (ext) {
cb(null, Date.now() + file.originalname + ext);
} else {
// NO EXTENSION
console.error("No extension found");
}
}
},
});
let upload = multer({
storage: storage,
}).array("banners");
// =========>
getFileType = (type) => {
switch (type) {
case "image/jpeg":
return ".jpeg";
case "image/png":
return ".png";
case "image/jpg":
return ".jpg";
default:
return null;
}
};
// GETTING ALL BANNERS
router.get("/", (req, res) => {
let qry = "SELECT * FROM banners";
db.query(qry, (err, rows) => {
if (err) return res.status(500).send("Internal Error");
return res.send(rows);
});
});
getBanners = (qry2, values) => {
return new Promise((resolve, reject) => {
db.query(qry2, [values], (err) => {
if (err) return reject(err);
resolve(true);
});
});
};
router.post("/", adminTokenValidation, (req, res) => {
let qry1 = "DELETE FROM banners";
db.query(qry1, (err) => {
if (err) return res.status(500).send("Internal Error");
// let dir = "/public/banners";
// if (fs.existsSync(dir)) {
// fsExtra.emptyDirSync(dir);
// }
upload(req, res, async (err) => {
if (err) {
console.log(err);
return res.status(500).send(err.message);
}
let files = req.files;
let qry2 = "INSERT INTO banners(bannerImgUrl) VALUES ?";
let values = [];
try {
for (let file of files) {
let path = await imgUpload(file.path);
values.push([path]);
}
await getBanners(qry2, values);
return res.send("Success");
} catch (error) {
console.log(error);
return res.status(500).send("Internal Error");
}
});
});
});
module.exports = router;