-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathindex.php
138 lines (118 loc) · 4.69 KB
/
index.php
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
<?php
// Include requirements and perfom initial steps
include_once(__DIR__ . '/core/bot/requirements.php');
if ($metrics){
$requests_total->inc(['/']);
}
// Start logging.
debug_log("RAID-BOT '" . $config->BOT_ID . "'");
// Check API Key and get input from telegram / webhook
include_once(CORE_BOT_PATH . '/apikey.php');
$update = get_verified_update(); // This also sets API_KEY
// We maybe receive a webhook so far...
if ($update){
foreach ($update as $raid) {
if (isset($raid['type']) && $raid['type'] == 'raid') {
// Create raid(s) and exit.
include_once(ROOT_PATH . '/commands/raid_from_webhook.php');
$dbh = null;
exit();
}
}
}
// Init empty data array.
$data = [];
// Callback data found.
if (isset($update['callback_query']['data'])) {
// Bridge mode?
if($config->BRIDGE_MODE) {
// Split bot folder name away from actual data.
$botnameData = explode(':', $update['callback_query']['data'], 2);
$botname = $botnameData[0];
$thedata = $botnameData[1];
// Write to log
debug_log('Bot Name: ' . $botname);
debug_log('The Data: ' . $thedata);
$botname_length = count(str_split($botname));
if($botname_length > 8) {
info_log("ERROR! Botname '" . $botname . "' is too long, max: 8","!");
exit();
}
} else {
// Data is just the data.
$thedata = $update['callback_query']['data'];
}
// Split callback data and assign to data array.
$splitData = explode(':', $thedata);
$data['id'] = $splitData[0];
$data['action'] = $splitData[1];
$data['arg'] = $splitData[2];
}
// DDOS protection
if($config->ENABLE_DDOS_PROTECTION) {
include_once(CORE_BOT_PATH . '/ddos.php');
}
// Update the user
update_user($update);
// Get language
include_once(CORE_BOT_PATH . '/userlanguage.php');
// Run cleanup if requested
if (isset($update['cleanup'])) {
include_once(CORE_BOT_PATH . '/cleanup_run.php');
cleanup_auth_and_run($update);
}
// Callback query received.
if (isset($update['callback_query'])) {
// Logic to get the module
include_once(CORE_BOT_PATH . '/modules.php');
// Inline query received.
} else if (isset($update['inline_query'])) {
// List quests and exit.
raid_list($update);
$dbh = null;
exit();
// Location received.
} else if (isset($update['message']['location']) && $update['message']['chat']['type'] == 'private') {
if($config->RAID_VIA_LOCATION_FUNCTION == 'list') {
include_once(ROOT_PATH . '/mods/share_raid_by_location.php');
}else {
// Create raid and exit.
include_once(ROOT_PATH . '/mods/raid_by_location.php');
}
$dbh = null;
exit();
// Cleanup collection from channel/supergroup messages.
} else if ((isset($update['channel_post']) && $update['channel_post']['chat']['type'] == "channel") || (isset($update['message']) && $update['message']['chat']['type'] == "supergroup")) {
// Collect cleanup information
include_once(CORE_BOT_PATH . '/cleanup_collect.php');
// Message is required to check for commands.
} else if (isset($update['message']) && ($update['message']['chat']['type'] == 'private' || $update['message']['chat']['type'] == 'channel')) {
// Portal message?
if(isset($update['message']['entities']['1']['type']) && $update['message']['entities']['1']['type'] == 'text_link' && strpos($update['message']['entities']['1']['url'], 'https://intel.ingress.com/intel?ll=') === 0) {
// Import portal.
include_once(ROOT_PATH . '/mods/importal.php');
} else {
// Check if user is expected to be posting something we want to save to db
if($update['message']['chat']['type'] == 'private') {
$q = my_query("SELECT id, handler, modifiers FROM user_input WHERE user_id='{$update['message']['from']['id']}' LIMIT 1");
if( $q->rowCount() > 0 ) {
debug_log("Expecting a response message from user: " . $update['message']['from']['id']);
$res = $q->fetch();
// Modifiers to pass to handler
$modifiers = json_decode($res['modifiers'], true);
debug_log("Calling: " . $res['handler'] . '.php');
debug_log("With modifiers: " . $res['modifiers']);
include_once(ROOT_PATH . '/mods/' . $res['handler'] . '.php');
debug_log("Response handeled successfully!");
// Delete the entry if the call was handled without errors
my_query("DELETE FROM user_input WHERE id='{$res['id']}'");
$dbh = null;
exit();
}
}
// Logic to get the command
include_once(CORE_BOT_PATH . '/commands.php');
}
}
$dbh = null;
?>