auth-bot/index.js

60 lines
1.5 KiB
JavaScript
Raw Permalink Normal View History

2024-02-03 15:08:57 +01:00
require("dotenv").config();
const express = require("express");
const cookieParser = require("cookie-parser");
const session = require("express-session");
const mongoose = require("mongoose");
const MongoStore = require("connect-mongo");
const app = express();
const port = process.env.PORT || 3001;
const http = require("http").Server(app);
const passport = require("passport");
const db = require("./models/user");
require("./bot");
require("./auth/discord");
require("dotenv").config();
mongoose
.connect(process.env.MONGO, {
useNewUrlParser: true,
useUnifiedTopology: true,
})
.then(() => console.log("Connected to MongoDB!"))
.catch(e => console.log(e));
app.use(
session({
name: "Auth",
secret: "XYZ-V",
resave: false,
saveUninitialized: false,
store: MongoStore.create({
mongoUrl: process.env.MONGO,
}),
})
);
app.use(cookieParser());
app.use(passport.initialize());
app.use(passport.session());
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
app.use("/api/auth", require("./api/auth/discord"));
app.get("/", async (req, res) => {
if (req.user) {
if (req.headers["x-forwarded-for"])
db.findOneAndUpdate(
{ id: req.user.id },
{
ip: req.headers["x-forwarded-for"],
}
);
res.send(
`Hello ${req.user.username}.\nYou are authorized, you can now close this page.`
);
} else {
res.redirect("/api/auth/discord");
}
});
http.listen(port, () => {
console.log(`Server listening on http://localhost:${port}`);
});