-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.js
executable file
·220 lines (188 loc) · 8.7 KB
/
index.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
//var config = require('./config.js');
try{
var config = process.cwd()+'/config.js';
config = require(config);
}catch (error){
console.error('ERROR -> Unable to load config file.');
process.exit(1);
}
var chat = require("./functions/chat.js");
var check = require("./functions/check.js");
var command = require("./functions/command.js");
var cron = require("./functions/cron.js");
// var storage = require("./functions/storage.js");
var log = require("./functions/log.js");
/* ------------------------------------------------------------------------------ */
// // // // // // // // // // // // // // // // // // // // // // // // // // // //
/* ------------------------------------------------------------------------------ */
const { Client } = require('discord.js');
const client = new Client();
global.globalClient = client;
var cooldownTimes = {}; // Cooldown timers by user, id and timestamp
/* Latest active users */
var activeUsers = [];
/* BOT ENABLE/DISABLE */
var botEnabled = 1;
// Coin price if real price enabled on config
global.coinPrice = 0;
global.coinCentPrice = 0;
/* ------------------------------------------------------------------------------ */
// // // // // // // // // // // // // // // // // // // // // // // // // // // //
/* ------------------------------------------------------------------------------ */
client.on('error', console.error);
process.on('unhandledRejection', error => console.error('Uncaught Promise Rejection', error));
client.on('ready', () => {
log.log_write_console(config.messages.botStarted + ` ${client.user.tag}!`);
client.user.setPresence({ status: 'online', game: { name: config.bot.gameMessage } });
if(config.bot.setNewAvatar){
client.user.setAvatar(config.bot.avatar);
}
});
client.on('message', msg => {
var userID = msg.author.id;
var userName = msg.author;
var messageFull = msg;
var messageType = msg.channel.type;
var messageContent = msg.content;
var channelID = msg.channel.id;
var userRoles = 'none';
var serverUsers = [];
var userBot = msg.author.bot;
var currentTimestamp = Math.floor(Date.now() / 1000);
// Only check messages if its not the bot itself or another bot
if(userID == config.bot.botID)
return;
// Only check if its not other bot
if(userBot)
return;
// Save and delete active users by time
activeUsers[userID] = currentTimestamp;
//console.log('Added/Updated -> '+userID+' t: '+currentTimestamp);
// -> and remove inactive if no more in timeframe
for (var key in activeUsers) {
if(activeUsers[key] < (currentTimestamp-config.bot.activeUserTime)){
//console.log('deleted: '+activeUsers[key]+' - id: '+ key);
delete activeUsers[key];
}
}
// If message has command prefix
if(messageContent.startsWith(config.bot.commandPrefix)){
// Get user role if not direct message
if(messageType !== 'dm'){
try{
var userRoles = msg.member.roles;
}catch (error){
log.log_write_console('Failed to get role 1');
var userRoles = 'none';
}
}
try{
var userRole = check.check_user_role(userID,userRoles);
}catch (error){
log.log_write_console('Failed to get role 2');
var userRole = 0;
}
// Enable / Disable bot commands
// Check if command is start or stop
var startStopCheck = messageContent.split(/ +/);
if(startStopCheck[0].substr(1) === 'stop' && userRole == 3){
botEnabled = 0;
chat.chat_reply(msg,'embed',false,messageType,config.colors.special,false,false,false,config.messages.startstop.disabled,false,false,false,false);
return;
}
if(startStopCheck[0].substr(1) === 'start' && userRole == 3){
botEnabled = 1;
chat.chat_reply(msg,'embed',false,messageType,config.colors.special,false,false,false,config.messages.startstop.enabled,false,false,false,false);
return;
}
if(!botEnabled){
return;
}
// If its not a dm message check if its a valid channel for commands
if(!check.check_respond_channel(channelID) && messageType !== 'dm')
return;
// Check if admin mode is enabled and only allow commands from admins
if(config.bot.adminMode && userRole != 3){
if(messageType !== 'dm')
msg.delete();
//msg,replyType,replyUsername,senderMessageType,replyEmbedColor,replyAuthor,replyTitle,replyFields,replyDescription,replyFooter,replyThumbnail,replyImage,replyTimestamp
chat.chat_reply(msg,'embed',userName,messageType,config.colors.warning,false,config.messages.title.warning,false,config.messages.adminMode,false,false,false,false);
return;
}
// Save and check cooldown timer but ignor admins/mods/vips ˇˇ
if(userRole < 1){
if(cooldownTimes[userID] > (currentTimestamp-config.bot.cooldownTime) && cooldownTimes[userID] !== undefined){
//msg,replyType,replyUsername,senderMessageType,replyEmbedColor,replyAuthor,replyTitle,replyFields,replyDescription,replyFooter,replyThumbnail,replyImage,replyTimestamp
chat.chat_reply(msg,'embed',userName,messageType,config.colors.warning,false,config.messages.title.warning,false,config.messages.cooldown,false,false,false,false);
return;
}
cooldownTimes[userID] = currentTimestamp;
}
// Check if direct messages to bot are disabled
if(!config.bot.allowDM && messageType === 'dm'){
//msg,replyType,replyUsername,senderMessageType,replyEmbedColor,replyAuthor,replyTitle,replyFields,replyDescription,replyFooter,replyThumbnail,replyImage,replyTimestamp
chat.chat_reply(msg,'embed',userName,messageType,config.colors.error,false,config.messages.title.error,false,config.messages.DMDisabled,false,false,false,false);
return;
}
// Check if its a valid message and if it use the right prefix
if(!check.check_valid_content(messageContent)){ // if not valid
// Delete message if not direct message and delete
if(messageType !== 'dm')
msg.delete();
//msg,replyType,replyUsername,senderMessageType,replyEmbedColor,replyAuthor,replyTitle,replyFields,replyDescription,replyFooter,replyThumbnail,replyImage,replyTimestamp
chat.chat_reply(msg,'embed',userName,messageType,config.colors.error,false,config.messages.title.error,false,config.messages.notValidCommand,false,false,false,false);
return;
}
// Check if command is withdrawal request and not lowercase it because of address
var withdrawalCheck = messageContent.split(/ +/);
if(withdrawalCheck[0].substr(1) === 'w' || withdrawalCheck[0].substr(1) === 'withdraw'){
var recievedCommand = messageContent.split(/ +/);
}else{
var recievedCommand = messageContent.toLowerCase().split(/ +/);
}
// Build recievedCommand partFive for drop phrase
var dropPhrase = "";
for (var i = 4 ; i < recievedCommand.length ; ++i){
if(i != 4)
dropPhrase = dropPhrase + ' ';
dropPhrase = dropPhrase + recievedCommand[i];
// If phrase is longer as defined on config
if(dropPhrase.length > config.bot.dropMessageMaxLength){
i = recievedCommand.length;
}
}
// Cut it to max lengh and remove space on start and end
dropPhrase = dropPhrase.substring(0,config.bot.dropMessageMaxLength);
dropPhrase = dropPhrase.trim();
/// DISABLED AND NOT USED AND OVERWRITTEN ON RAIN FUNCTION // Check if command is rain and get user list from discord server
var rainCheck = messageContent.split(/ +/);
if(rainCheck[0].substr(1) === 'rain' && rainCheck[1] === 'all' || rainCheck[1] === 'random'){
// This crashes the bot if there are to many discord users and multiple channel the bot is in so changed to grab random users from database with maxRainRandomUsers from config as more is not needed because rain all just grabs total count and credits all users
/*if(client.users){
Array.from(client.users.filter(user => user.bot == false).values()).forEach(element => {
serverUsers.push(element.id);
});
}*/
}
// Check if command is on ignor list
var ignorCheck = recievedCommand[0].substr(1);
if(config.bot.commandIgnor.includes(ignorCheck)){
return;
}
// Process command
command.fire_command(messageFull,userID,userName,messageType,userRole,recievedCommand[0].substr(1),recievedCommand[1],recievedCommand[2],recievedCommand[3],dropPhrase,serverUsers,activeUsers);
}
});
// Start the bot
client.login(config.bot.botToken);
// Start cronjobs
if(config.wallet.check) // Check for new deposits
cron.cron_get_deposits();
if(config.wallet.credit) // Credit new deposits
cron.cron_credit_deposits();
if(config.staking.check) // Check for new stakes
cron.cron_get_stakes();
if(config.staking.credit) // Credit new stakes
cron.cron_credit_stakes();
if(config.coinPrice.enabled) // Get coin price
cron.cron_price();