-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathBlacklisted.js
399 lines (382 loc) · 20.9 KB
/
Blacklisted.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
'use strict';
const moment=require('moment');
const tz=require('moment-timezone');
const Discord=require('discord.js');
const CONFIG=require('./files/blacklist_config.json');
const EXECUTIONER=new Discord.Client({disabledEvents:[
'CHANNEL_PINS_UPDATE', 'MESSAGE_REACTION_REMOVE_ALL', 'PRESENCE_UPDATE', 'VOICE_STATE_UPDATE',
'TYPING_START', 'VOICE_SERVER_UPDATE', 'RELATIONSHIP_ADD', 'RELATIONSHIP_REMOVE'
]});
const USERBOT=new Discord.Client({disabledEvents: [
'GUILD_CREATE', 'GUILD_DELETE', 'GUILD_UPDATE', 'GUILD_MEMBER_UPDATE', 'GUILD_MEMBERS_CHUNK', 'GUILD_ROLE_CREATE',
'GUILD_ROLE_DELETE', 'GUILD_ROLE_UPDATE', 'GUILD_BAN_ADD', 'GUILD_BAN_REMOVE', 'CHANNEL_CREATE', 'CHANNEL_DELETE',
'CHANNEL_UPDATE', 'CHANNEL_PINS_UPDATE', 'MESSAGE_DELETE', 'MESSAGE_UPDATE', 'MESSAGE_DELETE_BULK', 'MESSAGE_REACTION_ADD',
'MESSAGE_REACTION_REMOVE', 'MESSAGE_REACTION_REMOVE_ALL', 'USER_UPDATE', 'USER_NOTE_UPDATE', 'USER_SETTINGS_UPDATE',
'PRESENCE_UPDATE', 'VOICE_STATE_UPDATE', 'TYPING_START', 'VOICE_SERVER_UPDATE', 'RELATIONSHIP_ADD', 'RELATIONSHIP_REMOVE'
]});
USERBOT.Snipe_IMG='https://i.imgur.com/dzvklbi.png';
USERBOT.Left_IMG='https://i.imgur.com/HVRacGU.jpg';
USERBOT.Approved_IMG='https://i.imgur.com/LVlq97j.png';
EXECUTIONER.on('ready', () => { console.info('[Blacklist] Executioner is ready to enact your will.'); });
USERBOT.on('ready', () => {
let guilds=USERBOT.guilds.size-CONFIG.Home_Server_IDs.length;
console.info('[Blacklist] Now Checking '+guilds+' Blacklisted Servers.');
USERBOT.user.setPresence({'status':'invisible'});
});
// TIMESTAMP BASED ON SET TIMEZONE
function postTime(timezone){
let timeNow=new Date().getTime();
if(!timezone || timezone=='GMT' || timezone==null){ return moment.tz(timeNow,timezone).format('dddd, MMMM Do, h:mm A')+' GMT'; }
else{ return moment.tz(timeNow,timezone).format('dddd, MMMM Do, h:mm A'); }
}
// CHECK THE USER FOR SPOOF SERVERS
function checkUser(userID){
return new Promise(function(resolve, reject) {
let foundServers='', num=0;
let guilds=USERBOT.guilds.map(g => g);
guilds.forEach((guild) => {
if(CONFIG.Home_Server_IDs.indexOf(guild.id)<0){
let isMember=guild.members.get(userID); num++
if(isMember){ foundServers+='`'+guild.name+'`,'; }
}
});
if(num>1){ foundServers=foundServers.replace(/,/g,'\n').slice(0,-1); }
else{ foundServers=foundServers.slice(0,-1); }
resolve(foundServers);
});
}
USERBOT.on('guildMemberAdd', member => {
// IGNORE IF THEY USER IS ON THE WHITELIST
if(CONFIG.Whitelist.indexOf(member.id)>=0){ return; }
// CHECK EACH HOME SERVER
CONFIG.Home_Server_IDs.forEach((guildID,index) => {
// CHECK IF THE USER IS A GUILDMEMBER
let guildMember=USERBOT.guilds.get(guildID).members.get(member.id);
if(guildMember){
checkUser(member.id).then(function(foundServers){
let timeNow=new Date().getTime(), joinTime=moment(timeNow).format('DD/MMM/YY'), uName='', spoofLog;
// GET NICKNAME OR USE USERNAME
if(member.nickname){ uName=member.nickname; } else{ uName=member.user.username; }
// USER JOINED MY SERVER AND IS IN SPOOF SERVERS
if(CONFIG.Home_Server_IDs.indexOf(member.guild.id)>=0 && foundServers){
let newMemberSpoof=new Discord.RichEmbed().setColor('ff0000')
.setAuthor(uName+' ('+member.id+')', member.user.displayAvatarURL)
.addField('New Member is in Blacklisted Servers.', foundServers, false)
.setFooter(postTime(CONFIG.Timezone));
EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(newMemberSpoof).catch(console.error).then( m => {
// FETCH THE MEMBER AND SEND WARNING MESSAGE
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
let configWarn=CONFIG.Joined_My_Server_While_In_Spoof_Servers_Warning.replace(/%SPOOFSERVER%/g, foundServers).replace(/%SERVERNAME%/g, CONFIG.Home_Server_Names[index]);
let warnMessage=new Discord.RichEmbed().setColor('ff0000').setThumbnail('https://i.imgur.com/fE3yYLz.jpg?1').setDescription(configWarn+'\n**Blacklisted Server(s):**\n'+foundServers);
TARGET.send(warnMessage).catch(console.error);
let warnConfirmation=new Discord.RichEmbed().setColor('00ff00')
.setDescription('Warned '+TARGET+'.')
.setFooter(postTime(CONFIG.Timezone));
EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(warnConfirmation).catch(console.error);
}).catch(console.error);
// CHECK AGAIN IN AFTER A PERIOD OF TIME DETERMINED IN THE CONFIG
setTimeout(function(){
let stillMember=USERBOT.guilds.get(guildID).members.get(member.id);
if(!stillMember){
let leftMessage=new Discord.RichEmbed().setColor('00ff00')
.setDescription(uName+' has decided to leave our server.')
.setFooter(postTime(CONFIG.Timezone));
EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(leftMessage).catch(console.error);
}
else{
foundServers='';
checkUser(member.id).then(function(foundServers){
if(foundServers){
switch(CONFIG.Pound_Level){
case 'KICK':
// KICK THE USER
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
let configKick=CONFIG.Kicked_Message.replace(/%SPOOFSERVER%/g, foundServers).replace(/%SERVERNAME%/g, CONFIG.Home_Server_Names[index]);
let kickMessage=new Discord.RichEmbed().setColor('ff0000').setThumbnail('https://i.imgur.com/Qa1ik69.jpg?1').setDescription(configKick);
TARGET.send(kickMessage).catch(console.error).then( m => {
TARGET.kick('Member of a spoofing server.').catch(console.error);
let kickConfirmation=new Discord.RichEmbed().setColor('00ff00')
.setDescription('Kicked '+TARGET+'.')
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(kickConfirmation).catch(console.error);
});
}).catch(console.error); break;
case 'BAN':
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
let configBan=CONFIG.Banned_Message.replace(/%SPOOFSERVER%/g, foundServers).replace(/%SERVERNAME%/g, CONFIG.Home_Server_Names[index]);
let banMessage=new Discord.RichEmbed().setColor('ff0000').setThumbnail('https://i.imgur.com/Qa1ik69.jpg?1').setDescription(configBan);
TARGET.send(banMessage).catch(console.error).then( m => {
TARGET.ban('Member of a spoofing server.').catch(console.error);
let banConfirmation=new Discord.RichEmbed().setColor('00ff00')
.setDescription('Banned '+TARGET+'.')
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(banConfirmation).catch(console.error);
});
}).catch(console.error);
default:
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
return;
}).catch(console.error); break;
}
}
else{
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
let configLeft=CONFIG.Left_Spoof_Message.replace(/%SPOOFSERVER%/g, foundServers).replace(/%SERVERNAME%/g, CONFIG.Home_Server_Names[index]);
let leftMessage=new Discord.RichEmbed().setColor('00ff00').setThumbnail('https://i.imgur.com/UtIms4t.jpg').setDescription(configLeft);
TARGET.send(leftMessage).catch(console.error);
}).catch(console.error);
}
});
}
}, 60000 * CONFIG.Minutes_Til_Punish);
}).catch(console.error);
}
else{
// USER IS A MEMBER OF MY SERVER AND JOINED A SPOOF SERVER
if(foundServers){
let memberSpoofing=new Discord.RichEmbed().setColor('ff0000')
.setAuthor(uName+' ('+member.id+')', member.user.displayAvatarURL)
.setTitle('Member has joined a Blacklisted Server.')
.addField('Blacklisted Server(s):', foundServers, false)
.setFooter(postTime(CONFIG.Timezone));
EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(memberSpoofing).catch(console.error).then( m => {
// GET THE USER AND SEND THEM AN INITIAL WARNING
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
let configWarn=CONFIG.Joined_Spoof_Server_While_In_My_Server_Warning.replace(/%SPOOFSERVER%/g, foundServers).replace(/%SERVERNAME%/g, CONFIG.Home_Server_Names[index]);
let warnMessage=new Discord.RichEmbed().setColor('ff0000')
.setThumbnail('https://i.imgur.com/gXw71sr.jpg?1')
.setDescription(configWarn)
.setFooter(postTime(CONFIG.Timezone));
TARGET.send(warnMessage).catch(console.error);
let warnConfirmation=new Discord.RichEmbed().setColor('00ff00')
.setDescription('Warned '+TARGET+'.')
.setFooter(postTime(CONFIG.Timezone));
EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(warnConfirmation).catch(console.error);
}).catch(console.error);
// CHECK AGAIN IN AFTER A PERIOD OF TIME DETERMINED IN THE CONFIG
setTimeout(function() {
// CHECK IF THE USER LEFT MY SERVER
let stillMember=USERBOT.guilds.get(guildID).members.get(member.id);
if(!stillMember){
let leftMessage=new Discord.RichEmbed().setColor('00ff00').setDescription(uName+' has decided to leave our server.');
return EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(leftMessage).catch(console.error);
}
else{
foundServers='';
checkUser(member.id).then(function(foundServers){
// KICK OR BAN THEM IF THEY ARE STILL IN A SPOOF SERVER
if(foundServers){
switch(CONFIG.Pound_Level){
case 'KICK':
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
let configKick=CONFIG.Kicked_Message.replace(/%SPOOFSERVER%/g, foundServers).replace(/%SERVERNAME%/g, CONFIG.Home_Server_Names[index]);
let kickMessage=new Discord.RichEmbed().setColor('ff0000')
.setThumbnail('https://i.imgur.com/Qa1ik69.jpg?1')
.setDescription(configKick)
.setFooter(postTime(CONFIG.Timezone));
TARGET.send(kickMessage).catch(console.error).then( m => {
TARGET.kick('Member of a spoofing server.').catch(console.error);
let kickConfirmation=new Discord.RichEmbed().setColor('00ff00')
.setDescription('Kicked '+TARGET+'.')
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(kickConfirmation).catch(console.error);
});
}).catch(console.error); break;
case 'BAN':
let configBan=CONFIG.Banned_Message.replace(/%SPOOFSERVER%/g, foundServers).replace(/%SERVERNAME%/g, CONFIG.Home_Server_Names[index]);
let banMessage=new Discord.RichEmbed().setColor('ff0000')
.setThumbnail('https://i.imgur.com/Qa1ik69.jpg?1')
.setDescription(configBan)
.setFooter(postTime(CONFIG.Timezone));
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
TARGET.send(banMessage).catch(console.error).then( m => {
TARGET.ban('Member of a spoofing server.').catch(console.error);
let banConfirmation=new Discord.RichEmbed().setColor('00ff00')
.setDescription('Banned '+TARGET+'.')
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(banConfirmation).catch(console.error);
});
}).catch(console.error); break;
default:
EXECUTIONER.guilds.get(CONFIG.Home_Server_ID[index]).fetchMember(member.id).then( TARGET => {
return;
}).catch(console.error);
}
}
else{
// SEND CONFIRMATION THAT THEY HAVE LEFT THE SPOOF SERVER
EXECUTIONER.guilds.get(guildID).fetchMember(member.id).then( TARGET => {
let configLeft=CONFIG.Left_Spoof_Message.replace(/%SPOOFSERVER%/g, foundServers).replace(/%SERVERNAME%/g, CONFIG.Home_Server_Names[index]);
let leftMessage=new Discord.RichEmbed().setColor('00ff00')
.setThumbnail('https://i.imgur.com/UtIms4t.jpg')
.setDescription(configLeft)
.setFooter(postTime(CONFIG.Timezone));
TARGET.send(leftMessage).catch(console.error);
}).catch(console.error);
}
});
}
}, 60000 * CONFIG.Minutes_Til_Punish);
});
}
}
});
}
});
});
USERBOT.on('guildMemberRemove', member => {
if(CONFIG.Whitelist.indexOf(member.id)>=0){ return; }
if(CONFIG.Home_Server_IDs.indexOf(member.guild.id)>=0){ return; }
CONFIG.Home_Server_IDs.forEach((guildID,index) => {
let guildMember = USERBOT.guilds.get(guildID).members.get(member.id);
if(guildMember){
checkUser(member.id).then(function(foundServers){
let guild=member.guild, richEmbed='', uName='';
// GET NICKNAME OR USE USERNAME
if(member.nickname){ uName=member.nickname; } else{ uName=member.user.username; }
if(foundServers){
let stillInServers=new Discord.RichEmbed().setColor('ffa100')
.setAuthor(uName+' ('+member.id+')', member.user.displayAvatarURL)
.setTitle('Member has left '+member.guild.name)
.addField('Remaining Blacklisted Server(s):', foundServers, false)
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(stillInServers).catch(console.error);
}
else{
if(!foundServers){
let leftAllServers=new Discord.RichEmbed().setColor('00ff00')
.setAuthor(uName+' ('+member.id+')', member.user.displayAvatarURL)
.setTitle('No longer a member of any Blacklisted Servers.')
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(CONFIG.Command_Channels[index]).send(leftAllServers).catch(console.error);
}
}
});
}
});
});
EXECUTIONER.on('message', message => {
if(!message.content.startsWith(CONFIG.Prefix)){return;}
if(CONFIG.Command_Channels.indexOf(message.channel.id)<0){ return; }
let richEmbed='', badServer='', guild=message.member.guild, uName='';
if(message.member.hasPermission('ADMINISTRATOR') || mesage.member.hasPermission('MANAGE_ROLES') || message.memeber.id===BOT.OwnerID){
let args=message.content.split(' ').slice(1), command=message.content.split(' ')[0].slice(CONFIG.Prefix.length);
// if(command==='status'){
// richEmbed=new Discord.RichEmbed().setColor('00ff00')
// .setTitle('**Operational. Standing By.**');
// return EXECUTIONER.channels.get(CONFIG.Command_Channels[s]).send(richEmbed).catch(console.error);
// }
// if(command=='bhelp' || command=='commands'){
// if(!args[0]){
// richEmbed=new Discord.RichEmbed().setColor('00ff00')
// .setTitle('**Available Commands**').setThumbnail(USERBOT.LEFT_IMG)
// .setDescription('`'+CONFIG.Prefix+'check @mention or userid`\n`'+CONFIG.Prefix+'check @JohnDoe#1234`\n`'+CONFIG.Prefix+'check 237597448032354304`\n`'+CONFIG.Prefix+'check all`\n`'+CONFIG.Prefix+'check all sudo`\n');
// return EXECUTIONER.channels.get(CONFIG.Command_Channels[s]).send(richEmbed).catch(console.error);
// }
// }
if(command=='check'){
let member=message.guild.members.get(args[0]), badMembers=0;
if(member){if(member.nickname){uName=member.nickname;}else{uName=member.user.username;}}
if(args[0]=='server' || args[0]=='all'){
console.log('[Blacklist] Beginning Check of Entire Server.')
let members=message.guild.members.map(m => m.id);
members.forEach(function(id,index){
if(CONFIG.Whitelist.indexOf(id)<0 || args[1]=='sudo'){
checkUser(id).then(function(foundServers){
if(foundServers){
let uName=''; badMembers++;
EXECUTIONER.guilds.get(message.guild.id).fetchMember(id).then( TARGET => {
if(TARGET.nickname){ uName=TARGET.nickname; } else{ uName=TARGET.user.username; }
let alertMessage=new Discord.RichEmbed().setColor('ff0000')
.setAuthor(uName+' ('+TARGET.id+')', TARGET.user.displayAvatarURL)
.setDescription('Tag: '+TARGET)
.addField('Blacklisted Server(s):', foundServers, false)
.setFooter(postTime(CONFIG.Timezone));
EXECUTIONER.channels.get(message.channel.id).send(alertMessage).catch(console.error);
}).catch(console.error);
}
});
}
});
if(badMembers>0){
richEmbed=new Discord.RichEmbed().setColor('ff0000')
.setAuthor(badMembers+' Members were found in Blacklisted Servers').setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(message.channel.id).send(richEmbed).catch(console.error);
}
}
else if(isNaN(args[0])==false && args[0].length==18){
EXECUTIONER.fetchUser(args[0]).then( user => {
if(CONFIG.Whitelist.indexOf(user.id)>=0 && args[1]!='sudo'){
richEmbed=new Discord.RichEmbed().setColor('ff0000').setAuthor('That user is whitelisted.');
return EXECUTIONER.channels.get(message.channel.id).send(richEmbed).catch(console.error);
}
checkUser(user.id).then(function(foundServers){
if(member){
if(foundServers){
EXECUTIONER.guilds.get(message.guild.id).fetchMember(args[0]).then( TARGET => {
let badUser=new Discord.RichEmbed().setColor('ff0000')
.setAuthor(uName+' ('+member.id+')', member.user.displayAvatarURL)
.setDescription('Tag: '+TARGET)
.addField('Blacklisted Server(s):', foundServers, false)
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(message.channel.id).send(badUser).catch(console.error);
}).catch(console.error);
}
else{
let goodUser=new Discord.RichEmbed().setColor('00ff00').setThumbnail(USERBOT.APPROVED_IMG)
.setAuthor(uName+' ('+member.id+')', user.displayAvatarURL)
.setTitle('Not a member of any Blacklisted Servers.')
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(message.channel.id).send(goodUser).catch(console.error);
}
}
else{
if(foundServers){
let badUser=new Discord.RichEmbed().setColor('ff0000')
.setAuthor(user.username+' ('+user.id+')', user.displayAvatarURL)
.addField('Blacklisted Server(s):', foundServers, false)
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(message.channel.id).send(badUser).catch(console.error);
}
else{
let goodUser=new Discord.RichEmbed().setColor('00ff00').setThumbnail(USERBOT.APPROVED_IMG)
.setAuthor(user.username+' ('+user.id+')', user.displayAvatarURL)
.setTitle('Not a member of any Blacklisted Servers.')
.setFooter(postTime(CONFIG.Timezone));
return EXECUTIONER.channels.get(message.channel.id).send(goodUser).catch(console.error);
}
}
});
}).catch(console.error);
}
else{
richEmbed=new Discord.RichEmbed().setColor('ff0000').setAuthor('That is not a valid check option.');
return EXECUTIONER.channels.get(message.channel.id).send(richEmbed).catch(console.error);
}
}
if(command=='warn'){
let member=USERBOT.guilds.get(message.guild.id).members.get(args[0]);
let warnMessage=new Discord.RichEmbed().setColor('ff0000').setThumbnail('https://i.imgur.com/gXw71sr.jpg?1')
.setDescription('Good Afternoon. We have recently found **BMPGo** to be a spoofing app support server and it is now blacklisted. If you wish to stay a member of **'+message.guild.name+'**, you will need to leave that server in the next 2 hours. Please contact an Admin if you have any questions. Have a good day!');
EXECUTIONER.guilds.get(message.guild.id).fetchMember(args[0]).then( TARGET => {
TARGET.send(warnMessage).catch(console.error);
EXECUTIONER.channels.get(CONFIG.Command_Channels).send('Warned '+TARGET+'.').catch(console.error);
}).catch(console.error);
}
if(command=='restart'){
process.exit(1).catch(console.error);
}
}
else{
richEmbed=new Discord.RichEmbed().setColor('ff0000').setAuthor('You do not have permission to use that command.');
return EXECUTIONER.channels.get(message.channel.id).send(richEmbed).catch(console.error);
}
});
function blacklistAlert(embed,user){
for(let s=0; s<CONFIG.Home_Server_IDs; s++){
let member=USERBOT.guilds.get(CONFIG.Home_Server_IDs[s]).members.get(user.id);
if(member){ EXECUTIONER.channels.get(CONFIG.Command_Channels[s]).send(richEmbed).catch(console.error); }
}
}
// BOT LOGIN TO DISCORD
USERBOT.login(CONFIG.User_Token); EXECUTIONER.login(CONFIG.Bot_Token);