homeController.js 3.9 KB
/* 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);
};