-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
56 lines (48 loc) · 1.57 KB
/
app.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
require("dotenv").config();
const express = require("express");
const axios = require("axios");
const cron = require("node-cron");
const app = express();
const { sequelize } = require("./config/db");
const cors = require("cors");
// Middleware
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
app.use(cors());
app.use((req, res, next) => {
console.log(`Request Method: ${req.method}`);
console.log(`Request URL: ${req.url}`);
console.log(`Request body: ${JSON.stringify(req.body)}`);
next();
});
// Routes
app.use("/auth", require("./routes/userRoutes"));
app.use("/api", require("./routes/orgRoute"));
console.log(process.env);
if (process.env.NODE_ENV !== "test") {
sequelize
.sync({ alter: true })
.then(() => {
const port = process.env.PORT || 3000;
app.listen(port, () => {
console.log("Server running on port 3000");
});
})
.catch((err) => console.error("Database connection failed: ", err));
// Cron job to trigger redeployment
const deployHookUrl =
"https://api.render.com/deploy/srv-cu8mj2lds78s73bjcar0?key=KWA0m4_WTGk";
cron.schedule("*/14 * * * *", async () => {
try {
const response = await axios.post(deployHookUrl);
console.log("Deployment triggered", response.data);
} catch (error) {
console.error("Error triggering deployment", error);
}
});
// Handle unhandled rejection
process.on("unhandledRejection", (err) => {
console.log(`An error occurred: ${err.message}`);
});
}
module.exports = { app };