homeController.js
3.9 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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/* eslint-disable no-console */
import routes from "../routes";
import File from "../models/File";
const createCsvWriter = require('csv-writer').createObjectCsvWriter;
const csvInsertWriter = createCsvWriter({
path: 'insertOutput.csv',
header: [
{id: 'ms', title: 'time'}
]
});
const csvSelectWriter = createCsvWriter({
path: 'selectOutput.csv',
header: [
{id: 'ms', title: 'time'}
]
});
export const home = async (req, res) => {
try {
const files = await File.find({}).sort({ _id: -1 }); // 모든 파일을 가져온다.
res.render("home", { pageTitle: "Home", files }); // render DB에 저장된 file의 내용을 보여준다
} catch (error) {
console.log(error);
res.render("home", { pageTitle: "Home", files: [] });
}
};
// const searchTime = new Array();
export const search = async (req, res) => {
console.log(req);
// const startTime = new Date().getTime();
const {
query: { term: searchingBy },
} = req; // == const searchingBy = req.query.term;
let files = [];
try {
files = await File.find({
title: { $regex: searchingBy, $options: "i" }, // i를 옵션으로 추가하면 insensitive.. 대소문자 구분 안함.
});
/*
const endTime = new Date().getTime(); // SELECT의 경우 파일 시간 측정
searchTime.push({ms: endTime - startTime});
if (searchTime.length === 50){
csvSelectWriter
.writeRecords(searchTime)
.then(() => console.log("The CSV file was written successfully~"));
}
for (var i = 0; i < searchTime.length; i++){
console.log(i+1 + "번째 속도: " + Object.values(searchTime[i]) + "ms");
}
*/
} catch (error) {
console.log(error);
}
res.render("search", { pageTitle: "Search", searchingBy, files });
};
// upload 또한 upload를 준비하기 위한 get 페이지와 실제 데이터를 보내는 post 페이지가 필요하다.
export const getUpload = (req, res) =>
res.render("upload", { pageTitle: "Upload" });
const insertTime = new Array();
export const postUpload = async (req, res) => {
// const startTime = new Date().getTime();
// multer를 해야 파일이 넘어가는 것이 나타난다.
const {
body: { title },
file: { path },
} = req;
const newFile = await File.create({
fileUrl: path,
title,
// 여기있는 fileUrl, title은 fileDB의 속성이다.
});
// console.log(newFile);
/*
const endTime = new Date().getTime(); // INSERT의 경우 파일 시간 측정
insertTime.push({ms: endTime - startTime});
if (insertTime.length === 50){
csvInsertWriter
.writeRecords(insertTime)
.then(() => console.log("The CSV file was written successfully~"));
}
for (var i = 0; i < insertTime.length; i++){
console.log(i+1 + "번째 속도: " + Object.values(insertTime[i]) + "ms");
}
*/
res.redirect(routes.home);
};
export const fileDetail = async (req, res) => {
// console.log(req.params); params에 id가 있다는걸 알게 됨
const {
params: { id },
} = req;
try {
const file = await File.findById(id);
res.render("fileDetail", { pageTitle: file.title, file });
} catch (error) {
res.redirect(routes.home);
}
};
export const deleteFile = async (req, res) => {
const {
params: { id },
} = req;
try {
const file = await File.findById(id);
// file을 받아서 render로 통해 템플릿으로 던져준다,
if (String(file.creator) !== req.user.id) {
throw Error();
} else {
await File.findOneAndRemove({ _id: id });
}
} catch (error) {
console.log(error);
}
// 삭제를 실패하던 성공하던 home으로 redirect한다.
res.redirect(routes.home);
};