mirror of
https://github.com/arthur-pbty/LazyBot.git
synced 2026-06-03 15:07:29 +02:00
update Oauth discord & add good bye message
This commit is contained in:
+22
@@ -45,6 +45,28 @@ client.on(Events.GuildMemberAdd, member => {
|
||||
});
|
||||
|
||||
|
||||
client.on(Events.GuildMemberRemove, member => {
|
||||
db.get(
|
||||
"SELECT enabled, channel_id, message FROM goodbye_config WHERE guild_id = ?",
|
||||
[member.guild.id],
|
||||
(err, row) => {
|
||||
if (err || !row || !row.enabled) return;
|
||||
|
||||
let msg = row.message;
|
||||
|
||||
msg = msg
|
||||
.replace("{user}", member.user.username)
|
||||
.replace("{server}", member.guild.name);
|
||||
|
||||
const channel = member.guild.channels.cache.get(row.channel_id);
|
||||
if (channel) {
|
||||
channel.send(msg);
|
||||
}
|
||||
}
|
||||
);
|
||||
});
|
||||
|
||||
|
||||
client.login(process.env.BOT_TOKEN);
|
||||
|
||||
module.exports = client;
|
||||
|
||||
@@ -10,13 +10,20 @@ const db = new sqlite3.Database(
|
||||
);
|
||||
|
||||
// Création de la table si elle n'existe pas
|
||||
db.run(`
|
||||
db.exec(`
|
||||
CREATE TABLE IF NOT EXISTS welcome_config (
|
||||
guild_id TEXT PRIMARY KEY,
|
||||
channel_id TEXT,
|
||||
enabled INTEGER NOT NULL,
|
||||
message TEXT NOT NULL
|
||||
)
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS goodbye_config (
|
||||
guild_id TEXT PRIMARY KEY,
|
||||
channel_id TEXT,
|
||||
enabled INTEGER NOT NULL,
|
||||
message TEXT NOT NULL
|
||||
);
|
||||
`);
|
||||
|
||||
module.exports = db;
|
||||
|
||||
@@ -1,9 +1,13 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>Bienvenue</title>
|
||||
<title>Tableau de bord</title>
|
||||
</head>
|
||||
<body>
|
||||
<nav>
|
||||
<a href="/">Accueil</a>
|
||||
</nav>
|
||||
|
||||
<h1 id="greeting">Chargement...</h1>
|
||||
<img id="avatar" src="" alt="Avatar">
|
||||
|
||||
@@ -24,6 +28,7 @@
|
||||
document.getElementById("greeting").textContent = "Utilisateur non connecté.";
|
||||
});
|
||||
|
||||
|
||||
// --- Affichage des guilds de l'utilisateur ---
|
||||
fetch("/api/guilds")
|
||||
.then(res => res.json())
|
||||
@@ -51,6 +56,7 @@
|
||||
document.getElementById("guilds-list").innerHTML = "<li>Impossible de récupérer les guilds.</li>";
|
||||
});
|
||||
|
||||
|
||||
fetch("/invite-bot")
|
||||
.then(res => res.json())
|
||||
.then(data => {
|
||||
+85
-10
@@ -4,16 +4,20 @@
|
||||
<title>Dashboard du serveur</title>
|
||||
</head>
|
||||
<body>
|
||||
<nav>
|
||||
<a href="/">Accueil</a>
|
||||
<a href="/dashboard">Tableau de bord</a>
|
||||
</nav>
|
||||
|
||||
<h1 id="guild-name">Chargement...</h1>
|
||||
|
||||
|
||||
<form id="welcome-form">
|
||||
<label>
|
||||
<input type="checkbox" id="welcome-enabled" />
|
||||
Activer le message de bienvenue
|
||||
</label>
|
||||
|
||||
<br /><br />
|
||||
|
||||
<label>
|
||||
Canal de bienvenue :
|
||||
<br />
|
||||
@@ -21,8 +25,6 @@
|
||||
</select>
|
||||
</label>
|
||||
|
||||
<br /><br />
|
||||
|
||||
<label>
|
||||
Message :
|
||||
<br />
|
||||
@@ -34,8 +36,6 @@
|
||||
></textarea>
|
||||
</label>
|
||||
|
||||
<br /><br />
|
||||
|
||||
<small>
|
||||
Variables disponibles :
|
||||
<ul>
|
||||
@@ -46,9 +46,46 @@
|
||||
</small>
|
||||
|
||||
<button type="submit">Sauvegarder</button>
|
||||
<div id="status-welcome-form"></div>
|
||||
</form>
|
||||
|
||||
|
||||
<form id="goodbye-form">
|
||||
<label>
|
||||
<input type="checkbox" id="goodbye-enabled" />
|
||||
Activer le message d'au revoir
|
||||
</label>
|
||||
|
||||
<label>
|
||||
Canal d'au revoir :
|
||||
<br />
|
||||
<select id="goodbye-channel">
|
||||
</select>
|
||||
</label>
|
||||
|
||||
<label>
|
||||
Message :
|
||||
<br />
|
||||
<textarea
|
||||
id="goodbye-message"
|
||||
rows="4"
|
||||
cols="50"
|
||||
placeholder="Ex : Au revoir {user}, on espère te revoir sur {server} 👋"
|
||||
></textarea>
|
||||
</label>
|
||||
|
||||
<small>
|
||||
Variables disponibles :
|
||||
<ul>
|
||||
<li><code>{user}</code> → nom de l'utilisateur</li>
|
||||
<li><code>{server}</code> → nom du serveur</li>
|
||||
</ul>
|
||||
</small>
|
||||
|
||||
<button type="submit">Sauvegarder</button>
|
||||
<div id="status-goodbye-form"></div>
|
||||
</form>
|
||||
|
||||
<div id="status"></div>
|
||||
|
||||
<script>
|
||||
const guildId = window.location.pathname.split("/")[2]; // récupère l'ID du serveur
|
||||
@@ -88,23 +125,52 @@
|
||||
});
|
||||
|
||||
const data = await res.json();
|
||||
document.getElementById("status").textContent = data.success
|
||||
document.getElementById("status-welcome-form").textContent = data.success
|
||||
? "Config de bienvenue sauvegardée ✅"
|
||||
: "Erreur ❌";
|
||||
});
|
||||
|
||||
|
||||
const goodbyeForm = document.getElementById("goodbye-form");
|
||||
goodbyeForm.addEventListener("submit", async (e) => {
|
||||
e.preventDefault();
|
||||
const enabled = document.getElementById("goodbye-enabled").checked;
|
||||
const channelId = document.getElementById("goodbye-channel").value;
|
||||
const message = document.getElementById("goodbye-message").value;
|
||||
|
||||
const res = await fetch("/api/bot/save-goodbye-config", {
|
||||
method: "POST",
|
||||
headers: { "Content-Type": "application/json" },
|
||||
body: JSON.stringify({
|
||||
guildId,
|
||||
channelId,
|
||||
goodbyeMessage: message,
|
||||
goodbyeEnabled: enabled,
|
||||
}),
|
||||
});
|
||||
|
||||
const data = await res.json();
|
||||
document.getElementById("status-goodbye-form").textContent = data.success
|
||||
? "Config d'au revoir sauvegardée ✅"
|
||||
: "Erreur ❌";
|
||||
});
|
||||
|
||||
|
||||
fetch(`/api/bot/get-text-channels/${guildId}`)
|
||||
.then(res => res.json())
|
||||
.then(channels => {
|
||||
const select = document.getElementById("welcome-channel");
|
||||
const selectWelcome = document.getElementById("welcome-channel");
|
||||
const selectGoodbye = document.getElementById("goodbye-channel");
|
||||
channels.forEach(channel => {
|
||||
const option = document.createElement("option");
|
||||
option.value = channel.id;
|
||||
option.textContent = `#${channel.name}`;
|
||||
select.appendChild(option);
|
||||
selectWelcome.appendChild(option);
|
||||
selectGoodbye.appendChild(option.cloneNode(true));
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
fetch(`/api/bot/get-welcome-config/${guildId}`)
|
||||
.then(res => res.json())
|
||||
.then(cfg => {
|
||||
@@ -112,6 +178,15 @@
|
||||
document.getElementById("welcome-channel").value = cfg.channelId;
|
||||
document.getElementById("welcome-message").value = cfg.message;
|
||||
});
|
||||
|
||||
|
||||
fetch(`/api/bot/get-goodbye-config/${guildId}`)
|
||||
.then(res => res.json())
|
||||
.then(cfg => {
|
||||
document.getElementById("goodbye-enabled").checked = cfg.enabled;
|
||||
document.getElementById("goodbye-channel").value = cfg.channelId;
|
||||
document.getElementById("goodbye-message").value = cfg.message;
|
||||
});
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
|
||||
+18
-5
@@ -1,12 +1,25 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>Connexion Discord</title>
|
||||
<title>LazyBot - Bot Discord</title>
|
||||
</head>
|
||||
<body>
|
||||
<h1>Bienvenue !</h1>
|
||||
<a href="/auth/discord">
|
||||
<button>Se connecter avec Discord</button>
|
||||
</a>
|
||||
<nav>
|
||||
<a href="/">Accueil</a>
|
||||
<a href="/dashboard">Tableau de bord</a>
|
||||
</nav>
|
||||
<h1>LazyBot</h1>
|
||||
<a id="invite-link" href="#">Ajouter à Discord</a>
|
||||
</body>
|
||||
<script>
|
||||
fetch("/invite-bot")
|
||||
.then(res => res.json())
|
||||
.then(data => {
|
||||
const link = document.getElementById("invite-link");
|
||||
link.href = data.url; // met le lien dynamique
|
||||
})
|
||||
.catch(() => {
|
||||
console.log("Impossible de récupérer le lien du bot.");
|
||||
});
|
||||
</script>
|
||||
</html>
|
||||
|
||||
+107
-20
@@ -75,7 +75,7 @@ app.get("/auth/discord/callback", async (req, res) => {
|
||||
req.session.guilds = guilds;
|
||||
|
||||
// Rediriger vers la page HTML
|
||||
res.redirect("/welcome.html");
|
||||
res.redirect("/dashboard");
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
res.send("Erreur lors de la connexion Discord !");
|
||||
@@ -91,6 +91,7 @@ app.get("/api/user", (req, res) => {
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
app.get("/api/guilds", (req, res) => {
|
||||
const userGuilds = req.session.guilds; // toutes les guilds de l'utilisateur
|
||||
if (!userGuilds) return res.status(401).json({ error: "Utilisateur non connecté" });
|
||||
@@ -105,25 +106,40 @@ app.get("/api/guilds", (req, res) => {
|
||||
return hasAdmin && botHere;
|
||||
});
|
||||
|
||||
app.get("/invite-bot", (req, res) => {
|
||||
const clientId = process.env.CLIENT_ID;
|
||||
const redirectUri = encodeURIComponent(process.env.REDIRECT_URI);
|
||||
const permissions = 8; // Permissions administrateur
|
||||
const scope = encodeURIComponent("bot guilds applications.commands");
|
||||
res.json(validGuilds);
|
||||
});
|
||||
|
||||
const url = `https://discord.com/oauth2/authorize?client_id=${clientId}&permissions=${permissions}&scope=${scope}&redirect_uri=${redirectUri}&response_type=code`;
|
||||
|
||||
app.get("/invite-bot", (req, res) => {
|
||||
const permissions = 8; // Permissions administrateur
|
||||
|
||||
const scopes = [
|
||||
"bot",
|
||||
"applications.commands",
|
||||
"identify",
|
||||
"guilds"
|
||||
].join(" ");
|
||||
|
||||
const url =
|
||||
"https://discord.com/oauth2/authorize" +
|
||||
`?client_id=${CLIENT_ID}` +
|
||||
`&redirect_uri=${encodeURIComponent(REDIRECT_URI)}` +
|
||||
"&response_type=code" +
|
||||
`&scope=${encodeURIComponent(scopes)}` +
|
||||
`&permissions=${permissions}`;
|
||||
|
||||
// Tu peux juste renvoyer le lien
|
||||
res.json({ url });
|
||||
});
|
||||
});
|
||||
|
||||
// Servir le dashboard par serveur
|
||||
app.get("/guild/:guildId", (req, res) => {
|
||||
|
||||
// Servir le dashboard par serveur
|
||||
app.get("/guild/:guildId", (req, res) => {
|
||||
const guildId = req.params.guildId;
|
||||
const userGuilds = req.session.guilds;
|
||||
|
||||
// Vérifie que l'utilisateur est connecté et a admin sur ce serveur
|
||||
if (!userGuilds) return res.redirect("/"); // ou une page de connexion
|
||||
if (!userGuilds) return res.redirect("/auth/discord"); // ou une page de connexion
|
||||
const guildValid = userGuilds.find(
|
||||
g => g.id === guildId && (BigInt(g.permissions) & 0x8n) === 0x8n
|
||||
);
|
||||
@@ -131,10 +147,11 @@ app.get("/api/guilds", (req, res) => {
|
||||
|
||||
// Redirige vers la page HTML statique du dashboard
|
||||
res.sendFile(path.join(__dirname, "public", "guild.html"));
|
||||
});
|
||||
});
|
||||
|
||||
// API pour sauvegarder la configuration de bienvenue
|
||||
app.post("/api/bot/save-welcome-config", express.json(), (req, res) => {
|
||||
|
||||
// API pour sauvegarder la configuration de bienvenue
|
||||
app.post("/api/bot/save-welcome-config", express.json(), (req, res) => {
|
||||
const { guildId, channelId, welcomeEnabled, welcomeMessage } = req.body;
|
||||
|
||||
if (!req.session.guilds) {
|
||||
@@ -173,9 +190,10 @@ app.get("/api/guilds", (req, res) => {
|
||||
res.json({ success: true });
|
||||
}
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
app.get("/api/bot/get-welcome-config/:guildId", (req, res) => {
|
||||
|
||||
app.get("/api/bot/get-welcome-config/:guildId", (req, res) => {
|
||||
const { guildId } = req.params;
|
||||
|
||||
db.get(
|
||||
@@ -192,9 +210,72 @@ app.get("/api/guilds", (req, res) => {
|
||||
});
|
||||
}
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
app.get("/api/bot/get-text-channels/:guildId", (req, res) => {
|
||||
|
||||
app.post("/api/bot/save-goodbye-config", express.json(), (req, res) => {
|
||||
const { guildId, channelId, goodbyeEnabled, goodbyeMessage } = req.body;
|
||||
|
||||
if (!req.session.guilds) {
|
||||
return res.status(401).json({ success: false });
|
||||
}
|
||||
|
||||
const isAdmin = req.session.guilds.find(
|
||||
g => g.id === guildId && (BigInt(g.permissions) & 0x8n) === 0x8n
|
||||
);
|
||||
|
||||
if (!isAdmin) {
|
||||
return res.status(403).json({ success: false });
|
||||
}
|
||||
|
||||
db.run(
|
||||
`
|
||||
INSERT INTO goodbye_config (guild_id, channel_id, enabled, message)
|
||||
VALUES (?, ?, ?, ?)
|
||||
ON CONFLICT(guild_id)
|
||||
DO UPDATE SET channel_id = ?, enabled = ?, message = ?
|
||||
`,
|
||||
[
|
||||
guildId,
|
||||
channelId,
|
||||
goodbyeEnabled ? 1 : 0,
|
||||
goodbyeMessage,
|
||||
channelId,
|
||||
goodbyeEnabled ? 1 : 0,
|
||||
goodbyeMessage
|
||||
],
|
||||
err => {
|
||||
if (err) {
|
||||
console.error(err);
|
||||
return res.status(500).json({ success: false });
|
||||
}
|
||||
res.json({ success: true });
|
||||
}
|
||||
);
|
||||
});
|
||||
|
||||
|
||||
app.get("/api/bot/get-goodbye-config/:guildId", (req, res) => {
|
||||
const { guildId } = req.params;
|
||||
|
||||
db.get(
|
||||
"SELECT enabled, channel_id, message FROM goodbye_config WHERE guild_id = ?",
|
||||
[guildId],
|
||||
(err, row) => {
|
||||
if (err || !row) {
|
||||
return res.json({ enabled: false, channelId: null, message: "" });
|
||||
}
|
||||
res.json({
|
||||
enabled: !!row.enabled,
|
||||
channelId: row.channel_id,
|
||||
message: row.message
|
||||
});
|
||||
}
|
||||
);
|
||||
});
|
||||
|
||||
|
||||
app.get("/api/bot/get-text-channels/:guildId", (req, res) => {
|
||||
const { guildId } = req.params;
|
||||
const guild = client.guilds.cache.get(guildId);
|
||||
if (!guild) {
|
||||
@@ -209,9 +290,15 @@ app.get("/api/guilds", (req, res) => {
|
||||
}));
|
||||
|
||||
res.json(channels);
|
||||
});
|
||||
});
|
||||
|
||||
res.json(validGuilds);
|
||||
|
||||
app.get("/dashboard", (req, res) => {
|
||||
if (!req.session.user) {
|
||||
return res.redirect("/auth/discord");
|
||||
}
|
||||
|
||||
res.sendFile(path.join(__dirname, "public", "dashboard.html"));
|
||||
});
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user