Add auto kick functionality #502

Merged
Vylpes merged 10 commits from feature/485-auto-kick into hotfix/3.2.4 2025-01-03 17:47:16 +00:00
3 changed files with 32 additions and 8 deletions
Showing only changes of commit afafe246a8 - Show all commits

View file

@ -7,7 +7,7 @@
# any secret values.
BOT_TOKEN=
BOT_VER=3.2.3
BOT_VER=3.2.4
BOT_AUTHOR=Vylpes
BOT_OWNERID=147392775707426816
BOT_CLIENTID=682942374040961060
@ -23,4 +23,6 @@ DB_NAME=vylbot
DB_AUTH_USER=dev
DB_AUTH_PASS=dev
DB_SYNC=true
DB_LOGGING=true
DB_LOGGING=true
DB_DATA_LOCATION=./.temp/database
DB_ROOT_HOST=0.0.0.0

View file

@ -20,7 +20,6 @@ export class CoreClient extends Client {
private static _buttonEvents: ButtonEventItem[];
private static _baseClient: Client;
private _events: Events;
private _util: Util;
private _timerHelper: TimerHelper;
@ -60,11 +59,15 @@ export class CoreClient extends Client {
return;
}
CoreClient._baseClient = this;
await AppDataSource.initialize()
.then(() => {
console.log("Data Source Initialized");
this._timerHelper.AddTimer("*/5 * * * *", "Europe/London", AutoKick, true);
this._timerHelper.StartAllTimers();
})
.catch((err) => console.error("Error Initialising Data Source", err));
@ -79,8 +82,6 @@ export class CoreClient extends Client {
this._util.loadEvents(this, CoreClient._eventItems);
this._util.loadSlashCommands(this);
CoreClient._baseClient = this;
}
public static RegisterCommand(name: string, command: Command, serverId?: string) {

View file

@ -6,12 +6,33 @@ export default async function AutoKick() {
const autoKickConfigs = await AutoKickConfig.FetchAll(AutoKickConfig);
for (let config of autoKickConfigs) {
const guild = client.guilds.cache.find(x => x.id == config.ServerId) || client.guilds.fetch(config.ServerId);
const guild = client.guilds.cache.find(x => x.id == config.ServerId) || await client.guilds.fetch(config.ServerId);
if (!guild) {
continue;
}
console.log(typeof guild);
await guild.members.fetch();
const role = guild.roles.cache.find(x => x.id == config.RoleId);
if (!role) {
continue;
}
for (let memberEntity of role.members) {
const member = memberEntity[1];
if (!member.kickable) {
continue;
}
const whenToKick = new Date(member.joinedTimestamp! + config.KickTime);
const now = new Date();
if (whenToKick < now) {
await member.kick("Auto Kicked");
}
}
}
}