Update backend, DB, Commands, Live Reloading
This commit is contained in:
43
discord-bot/commands/add-kickuser.js
Normal file
43
discord-bot/commands/add-kickuser.js
Normal file
@@ -0,0 +1,43 @@
|
||||
const { SlashCommandBuilder, PermissionsBitField } = require('discord.js');
|
||||
const fetch = require('node-fetch');
|
||||
|
||||
module.exports = {
|
||||
name: 'add-kickuser',
|
||||
description: 'Admin: add a Kick username to watch for this server (DISABLED)',
|
||||
enabled: false,
|
||||
dev: true,
|
||||
builder: new SlashCommandBuilder()
|
||||
.setName('add-kickuser')
|
||||
.setDescription('Add a Kick username to watch for live notifications')
|
||||
.addStringOption(opt => opt.setName('username').setDescription('Kick username').setRequired(true)),
|
||||
async execute(interaction) {
|
||||
if (!interaction.member.permissions.has(PermissionsBitField.Flags.Administrator)) {
|
||||
await interaction.reply({ content: 'You must be an administrator to use this command.', flags: 64 });
|
||||
return;
|
||||
}
|
||||
const username = interaction.options.getString('username').toLowerCase().trim();
|
||||
try {
|
||||
const backendBase = process.env.BACKEND_BASE || `http://${process.env.HOST || '127.0.0.1'}:${process.env.PORT || 3002}`;
|
||||
const resp = await fetch(`${backendBase}/api/servers/${interaction.guildId}/kick-users`, {
|
||||
method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ username })
|
||||
});
|
||||
if (resp.ok) {
|
||||
await interaction.reply({ content: `Added ${username} to Kick watch list.`, flags: 64 });
|
||||
// Refresh cached settings from backend so watcher sees new user immediately
|
||||
try {
|
||||
const settingsResp = await fetch(`${backendBase}/api/servers/${interaction.guildId}/settings`);
|
||||
if (settingsResp.ok) {
|
||||
const json = await settingsResp.json();
|
||||
const bot = require('..');
|
||||
if (bot && bot.setGuildSettings) bot.setGuildSettings(interaction.guildId, json);
|
||||
}
|
||||
} catch (_) {}
|
||||
} else {
|
||||
await interaction.reply({ content: 'Failed to add user via backend.', flags: 64 });
|
||||
}
|
||||
} catch (e) {
|
||||
console.error('Error adding kick user:', e);
|
||||
await interaction.reply({ content: 'Internal error adding kick user.', flags: 64 });
|
||||
}
|
||||
}
|
||||
};
|
||||
@@ -22,6 +22,15 @@ module.exports = {
|
||||
});
|
||||
if (resp.ok) {
|
||||
await interaction.reply({ content: `Added ${username} to watch list.`, flags: 64 });
|
||||
// Refresh cached settings from backend so watcher sees new user immediately
|
||||
try {
|
||||
const settingsResp = await fetch(`${backendBase}/api/servers/${interaction.guildId}/settings`);
|
||||
if (settingsResp.ok) {
|
||||
const json = await settingsResp.json();
|
||||
const bot = require('..');
|
||||
if (bot && bot.setGuildSettings) bot.setGuildSettings(interaction.guildId, json);
|
||||
}
|
||||
} catch (_) {}
|
||||
} else {
|
||||
await interaction.reply({ content: 'Failed to add user via backend.', flags: 64 });
|
||||
}
|
||||
|
||||
24
discord-bot/commands/list-kickusers.js
Normal file
24
discord-bot/commands/list-kickusers.js
Normal file
@@ -0,0 +1,24 @@
|
||||
const { SlashCommandBuilder } = require('discord.js');
|
||||
const api = require('../api');
|
||||
|
||||
module.exports = {
|
||||
name: 'list-kickusers',
|
||||
description: 'List watched Kick usernames for this server (DISABLED).',
|
||||
enabled: false,
|
||||
dev: true,
|
||||
builder: new SlashCommandBuilder().setName('list-kickusers').setDescription('List watched Kick usernames for this server'),
|
||||
async execute(interaction) {
|
||||
try {
|
||||
const users = await api.getKickUsers(interaction.guildId) || [];
|
||||
if (!users || users.length === 0) {
|
||||
await interaction.reply({ content: 'No Kick users are being watched for this server.', ephemeral: true });
|
||||
return;
|
||||
}
|
||||
const list = users.map(u => `• ${u}`).join('\n');
|
||||
await interaction.reply({ content: `Watched Kick users:\n${list}`, ephemeral: true });
|
||||
} catch (e) {
|
||||
console.error('Error listing kick users:', e);
|
||||
await interaction.reply({ content: 'Failed to retrieve watched users.', ephemeral: true });
|
||||
}
|
||||
},
|
||||
};
|
||||
@@ -20,7 +20,7 @@ module.exports = {
|
||||
let toggles = existingSettings.commandToggles;
|
||||
// Include all loaded commands so simple command modules (no SlashCommandBuilder) like
|
||||
// `ping` are also listed. Filter for objects with a name for safety.
|
||||
const commands = Array.from(interaction.client.commands.values()).filter(cmd => cmd && cmd.name);
|
||||
const commands = Array.from(interaction.client.commands.values()).filter(cmd => cmd && cmd.name && !cmd.dev);
|
||||
|
||||
// Build button components (max 5 rows, 5 buttons per row)
|
||||
const actionRows = [];
|
||||
|
||||
41
discord-bot/commands/remove-kickuser.js
Normal file
41
discord-bot/commands/remove-kickuser.js
Normal file
@@ -0,0 +1,41 @@
|
||||
const { SlashCommandBuilder, PermissionsBitField } = require('discord.js');
|
||||
const fetch = require('node-fetch');
|
||||
|
||||
module.exports = {
|
||||
name: 'remove-kickuser',
|
||||
description: 'Admin: remove a Kick username from this server watch list',
|
||||
enabled: false,
|
||||
dev: true,
|
||||
builder: new SlashCommandBuilder()
|
||||
.setName('remove-kickuser')
|
||||
.setDescription('Remove a Kick username from the watch list')
|
||||
.addStringOption(opt => opt.setName('username').setDescription('Kick username to remove').setRequired(true)),
|
||||
async execute(interaction) {
|
||||
if (!interaction.member.permissions.has(PermissionsBitField.Flags.Administrator)) {
|
||||
await interaction.reply({ content: 'You must be an administrator to use this command.', flags: 64 });
|
||||
return;
|
||||
}
|
||||
const username = interaction.options.getString('username').toLowerCase().trim();
|
||||
try {
|
||||
const backendBase = process.env.BACKEND_BASE || `http://${process.env.HOST || '127.0.0.1'}:${process.env.PORT || 3002}`;
|
||||
const resp = await fetch(`${backendBase}/api/servers/${interaction.guildId}/kick-users/${encodeURIComponent(username)}`, { method: 'DELETE' });
|
||||
if (resp.ok) {
|
||||
await interaction.reply({ content: `Removed ${username} from Kick watch list.`, flags: 64 });
|
||||
// Refresh cached settings from backend
|
||||
try {
|
||||
const settingsResp = await fetch(`${backendBase}/api/servers/${interaction.guildId}/settings`);
|
||||
if (settingsResp.ok) {
|
||||
const json = await settingsResp.json();
|
||||
const bot = require('..');
|
||||
if (bot && bot.setGuildSettings) bot.setGuildSettings(interaction.guildId, json);
|
||||
}
|
||||
} catch (_) {}
|
||||
} else {
|
||||
await interaction.reply({ content: 'Failed to remove user via backend.', flags: 64 });
|
||||
}
|
||||
} catch (e) {
|
||||
console.error('Error removing kick user:', e);
|
||||
await interaction.reply({ content: 'Internal error removing kick user.', flags: 64 });
|
||||
}
|
||||
}
|
||||
};
|
||||
@@ -20,6 +20,15 @@ module.exports = {
|
||||
const resp = await fetch(`${backendBase}/api/servers/${interaction.guildId}/twitch-users/${encodeURIComponent(username)}`, { method: 'DELETE' });
|
||||
if (resp.ok) {
|
||||
await interaction.reply({ content: `Removed ${username} from watch list.`, flags: 64 });
|
||||
// Refresh cached settings from backend
|
||||
try {
|
||||
const settingsResp = await fetch(`${backendBase}/api/servers/${interaction.guildId}/settings`);
|
||||
if (settingsResp.ok) {
|
||||
const json = await settingsResp.json();
|
||||
const bot = require('..');
|
||||
if (bot && bot.setGuildSettings) bot.setGuildSettings(interaction.guildId, json);
|
||||
}
|
||||
} catch (_) {}
|
||||
} else {
|
||||
await interaction.reply({ content: 'Failed to remove user via backend.', flags: 64 });
|
||||
}
|
||||
|
||||
@@ -1,17 +1,13 @@
|
||||
const { SlashCommandBuilder, PermissionsBitField } = require('discord.js');
|
||||
const fetch = require('node-fetch');
|
||||
const api = require('../api');
|
||||
const { readDb, writeDb } = require('../../backend/db');
|
||||
|
||||
module.exports = {
|
||||
name: 'setup-live',
|
||||
description: 'Admin: configure Twitch live notifications for this server',
|
||||
description: 'Admin: enable or disable Twitch live notifications for this server',
|
||||
enabled: true,
|
||||
builder: new SlashCommandBuilder()
|
||||
.setName('setup-live')
|
||||
.setDescription('Configure Twitch live notifications for this server')
|
||||
.addStringOption(opt => opt.setName('twitch_user').setDescription('Twitch username to watch').setRequired(true))
|
||||
.addChannelOption(opt => opt.setName('channel').setDescription('Channel to send notifications').setRequired(true))
|
||||
.setDescription('Enable or disable Twitch live notifications for this server')
|
||||
.addBooleanOption(opt => opt.setName('enabled').setDescription('Enable/disable notifications').setRequired(true)),
|
||||
|
||||
async execute(interaction) {
|
||||
@@ -20,24 +16,18 @@ module.exports = {
|
||||
return;
|
||||
}
|
||||
|
||||
const twitchUser = interaction.options.getString('twitch_user');
|
||||
const channel = interaction.options.getChannel('channel');
|
||||
const enabled = interaction.options.getBoolean('enabled');
|
||||
|
||||
try {
|
||||
const api = require('../api');
|
||||
const existing = (await api.getServerSettings(interaction.guildId)) || {};
|
||||
existing.liveNotifications = { enabled: !!enabled, twitchUser, channelId: channel.id };
|
||||
const currentLn = existing.liveNotifications || {};
|
||||
existing.liveNotifications = { ...currentLn, enabled: !!enabled };
|
||||
await api.upsertServerSettings(interaction.guildId, existing);
|
||||
await interaction.reply({ content: `Live notifications ${enabled ? 'enabled' : 'disabled'} for ${twitchUser} -> ${channel.name}`, flags: 64 });
|
||||
await interaction.reply({ content: `Live notifications ${enabled ? 'enabled' : 'disabled'} for this server.`, flags: 64 });
|
||||
} catch (e) {
|
||||
console.error('Error saving live notifications to backend, falling back to local:', e);
|
||||
// fallback to local db
|
||||
const db = readDb();
|
||||
if (!db[interaction.guildId]) db[interaction.guildId] = {};
|
||||
db[interaction.guildId].liveNotifications = { enabled, twitchUser, channelId: channel.id };
|
||||
writeDb(db);
|
||||
await interaction.reply({ content: `Saved locally: Live notifications ${enabled ? 'enabled' : 'disabled'} for ${twitchUser} -> ${channel.name}`, flags: 64 });
|
||||
console.error('Error saving live notifications to backend:', e);
|
||||
await interaction.reply({ content: 'Failed to update live notifications.', flags: 64 });
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user