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
| require("dotenv").config();
const session = require("express-session");
const mysqlStore = require("express-mysql-session")(session);
const mysql = require("mysql2/promise");
class Session {
#dbCo;
#sessionStore;
constructor() {
(async () => {
try {
this.#sessionStore = await this.#startStore();
console.log("Session store prêt");
} catch (err) {
console.error("Echec creation du session store:", err);
}
})();
return session({
resave: false,
saveUninitialized: false,
secret: process.env.SESSION_SECRET,
cookie: {
maxAge: 365 * 24 * 60 * 60 * 1000,
sameSite: "strict",
secure: true,
httpOnly: true,
},
store: this.#sessionStore
});
}
async #startStore() {
try {
this.#dbCo = {
host: process.env.DB_HOST,
user: process.env.DB_USERNAME,
password: process.env.DB_PASSWORD,
database: process.env.DB_NAME,
};
const connexion = await mysql.createPool(this.#dbCo);
const sessionStore = new mysqlStore(
{
expiration: 365 * 24 * 60 * 60 * 1000,
createDatabaseTable: true,
schema: {
tableName: "Session"
}
},
connexion
);
await sessionStore.onReady();
//console.log("Session data:", sessionStore);
return sessionStore;
} catch (err) {
console.error(err);
}
}
}
module.exports = Session; |
Partager