-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
100 lines (85 loc) · 3.52 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
const express = require("express");
const app = express();
const router = express.Router();
const ejs = require("ejs");
const mongoose = require("mongoose");
const bodyParser = require("body-parser");
const routes = require("./routes");
const cookieParser = require("cookie-parser");
// The controllers
const landingPageController = require("./controllers/landingPageController");
const newPostController = require("./controllers/newPost");
const aboutController = require("./controllers/about");
const contactController = require("./controllers/contact");
const postController = require("./controllers/post");
const indexController = require("./controllers/index");
const homeController = require("./controllers/home");
const newUserController = require("./controllers/newUser");
const loginController = require("./controllers/login");
const userController = require("./controllers/storeUser"); // load route for storing controllers
const loginUserController = require("./controllers/loginUser"); // load route for storing
const dashboardController = require("./controllers/dashboard");
const authMiddleware = require("./middleware/authMiddleware");
const redirectIfAuthenticatedMiddleware = require("./middleware/redirectIfAuthenticatedMiddleware");
const logoutController = require("./controllers/logoutController");
const newBlogController = require("./controllers/blogController"); // const refreshTokenController = require("./controllers/refreshTokenController");
//Registering Middleware for my apps
global.loggedIn = null;
require("dotenv").config();
const winston = require("winston");
// Create a logger instance
const logger = winston.createLogger({
level: "error", // Set the log level
format: winston.format.json(),
transports: [
new winston.transports.File({ filename: "error.log", level: "error" }), // Log errors to a file
new winston.transports.Console(), // Log errors to console
],
});
app.use((err, req, res, next) => {
logger.error(err.stack); // Log the error stack trace
res.status(500).send("Something went wrong!");
});
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(express.static("public"));
app.use((error, req, res, next) => {
res.render("register", { error: error.message });
});
// middleware for cookies
app.use(cookieParser());
app.set("view engine", "ejs"); // let express use the ejs for templating engine
// Custom middleware
const customMiddleware = (req, res, next) => {
console.log(`page shwoing ${req.url}`);
next();
};
// This checks if the form fields are
app.use(customMiddleware);
// app.use("posts/store", validateMiddleware);
app.use("/", routes);
app.use("/users", userController);
// app.use("./routes", routes);
// GET request
app.get("/posts/new", authMiddleware, newPostController);
app.get("/about", aboutController);
app.get("/contact", contactController);
app.get("/post", postController);
app.get("/home", homeController);
// app.get("/", homeController);
app.get("/", landingPageController);
app.get("/auth/login", redirectIfAuthenticatedMiddleware, loginController);
app.get("/auth/register", redirectIfAuthenticatedMiddleware, newUserController);
app.get("/dashboard", dashboardController);
app.get("/auth/logout", logoutController);
app.post("/users/login", loginUserController);
app.post("/users/signup", userController);
router.post("/create_post", newBlogController.createPost);
module.exports = router;
let port = process.env.PORT;
if (port == null || port == " ") {
port = 4000;
}
app.listen(port, () => {
console.log(`app listening on ${port}`);
});