DenisSlider2000/index.js
2022-04-13 21:52:53 +02:00

105 lines
2.6 KiB
JavaScript

const fs = require("fs");
const https = require("https");
const express = require("express");
const socketio = require("socket.io");
const app = express();
const https_options = {
key: fs.readFileSync("./privkey.pem"),
cert: fs.readFileSync("./fullchain.pem"),
requestCert: false,
rejectUnauthorized: false
}
const socketHTTPSServer = https.createServer(https_options, app);
const webHTTPSServer = https.createServer(https_options, app);
const io = socketio(socketHTTPSServer, {
cors: {
origin: "https://danby.aniere.fr",
},
secure: true
});
function getCurrentTime() {
function addZero(i) {
if (i < 10) {
i = "0" + i;
}
return i;
}
var d = new Date();
var day = addZero(d.getUTCDate());
var month = addZero(d.getUTCMonth() + 1);
var year = d.getFullYear();
var h = addZero(d.getHours());
var m = addZero(d.getMinutes());
var s = addZero(d.getSeconds());
return "[" + day + "-"+ month + "-" + year + " " + h + ":" + m + ":" + s + "]";
}
function log(message) {
console.log(getCurrentTime() + " " + message);
}
usersConnected = 0;
lastUsername = 0;
messagesHistory = []
io.on("connection", (client) => {
usersConnected++;
io.sockets.emit("update-count", {value: usersConnected});
client.on("disconnect", () => {
usersConnected--;
io.sockets.emit("update-count", {value: usersConnected});
log(`${client.usernameDenis} has disconnected`);
});
client.on("message", (data) => {
if(data.message.toLowerCase().includes("denis")) {
io.sockets.emit("new-message", {author: client.usernameDenis, message: data.message});
log(`${client.usernameDenis} : ${data.message}`);
messagesHistory.push([client.usernameDenis, data.message]);
if(messagesHistory.length > 20) {
messagesHistory.shift();
}
} else {
client.emit("warning");
log(`${client.usernameDenis} : ${data.message} (INVALID)`);
}
});
lastUsername++;
client.usernameDenis = "DenisFan" + lastUsername;
client.emit("username", {username: "DenisFan" + lastUsername});
log(`${client.usernameDenis} is now connected`);
client.emit("previous-messages", {messages: messagesHistory});
});
app.use(express.static("src"));
app.listen(80, () => {
log("Web server started on port 80")
});
webHTTPSServer.listen(443, () => {
log("Web HTTPS server started on port 443");
});
socketHTTPSServer.listen(3000, () => {
log("Socket HTTPS server started on port 3000");
});