old-automod/bot/src/index.ts

64 lines
2.1 KiB
TypeScript
Raw Normal View History

2022-01-04 23:05:52 +00:00
import { config } from 'dotenv';
config();
2021-10-08 21:36:46 +00:00
import logger from './bot/logger';
import AutomodClient, { login } from './struct/AutomodClient';
import MongoDB from './bot/db';
2022-04-09 11:03:12 +00:00
import DbUser from './struct/DbUser';
import ServerConfig from './struct/ServerConfig';
import Infraction from './struct/antispam/Infraction';
import PendingLogin from './struct/PendingLogin';
import TempBan from './struct/TempBan';
import { VoteEntry } from './bot/commands/votekick';
import ScannedUser from './struct/ScannedUser';
2022-04-24 11:48:42 +00:00
import BridgeRequest from './struct/BridgeRequest';
import BridgeConfig from './struct/BridgeConfig';
2022-04-30 21:14:48 +00:00
import BridgedMessage from './struct/BridgedMessage';
2021-10-08 21:36:46 +00:00
logger.info('Initializing client');
let db = MongoDB();
let client = new AutomodClient({
2022-04-09 15:25:27 +00:00
// pongTimeout: 10,
// onPongTimeout: 'RECONNECT',
fixReplyCrash: true,
2022-04-30 09:25:24 +00:00
messageTimeoutFix: true,
apiURL: process.env.API_URL,
2022-05-03 05:53:42 +00:00
messageRateLimiter: true,
}, db);
2021-10-08 21:36:46 +00:00
login(client);
2022-04-09 11:03:12 +00:00
const dbs = {
SERVERS: db.get<ServerConfig>('servers'),
USERS: db.get<DbUser>('users'),
INFRACTIONS: db.get<Infraction>('infractions'),
PENDING_LOGINS: db.get<PendingLogin>('pending_logins'),
SESSIONS: db.get('sessions'),
TEMPBANS: db.get<TempBan>('tempbans'),
VOTEKICKS: db.get<VoteEntry>('votekicks'),
SCANNED_USERS: db.get<ScannedUser>('scanned_users'),
2022-04-24 11:48:42 +00:00
BRIDGE_CONFIG: db.get<BridgeConfig>('bridge_config'),
2022-04-30 21:14:48 +00:00
BRIDGED_MESSAGES: db.get<BridgedMessage>('bridged_messages'),
2022-04-24 11:48:42 +00:00
BRIDGE_REQUESTS: db.get<BridgeRequest>('bridge_requests'),
2022-04-09 11:03:12 +00:00
}
export { client, dbs }
2021-10-08 21:36:46 +00:00
(async () => {
// Wait for a database query to succeed before loading the rest
logger.info('Connecting to database...');
await db.get('servers').findOne({});
logger.done('DB ready!');
// Load modules
import('./bot/modules/command_handler');
import('./bot/modules/mod_logs');
import('./bot/modules/event_handler');
import('./bot/modules/tempbans');
2021-12-09 21:04:33 +00:00
import('./bot/modules/user_scan');
2022-01-22 21:37:59 +00:00
import('./bot/modules/api_communication');
2022-02-12 14:25:24 +00:00
import('./bot/modules/metrics');
import('./bot/modules/bot_status');
import('./bot/modules/fetch_all');
})();