]>
Commit | Line | Data |
---|---|---|
1 | <?php | |
2 | require_once "../inc/common.php"; | |
3 | require_once "../inc/header.php"; | |
4 | ||
5 | if (!empty($_POST)) | |
6 | { | |
7 | require_once "../inc/connection.php"; | |
8 | if (isset($_POST['tklch']) && !empty($_POST['tklch'])) // User has asked to delete these tkls | |
9 | { | |
10 | if (!current_user_can(PERMISSION_SERVER_BAN_DEL)) | |
11 | { | |
12 | Message::Fail("Could not delete: Permission denied"); | |
13 | } | |
14 | else { | |
15 | foreach ($_POST['tklch'] as $key => $value) { | |
16 | $tok = explode(",", $value); | |
17 | $ban = base64_decode($tok[0]); | |
18 | $type = base64_decode($tok[1]); | |
19 | $success = false; | |
20 | if ($type == "except") | |
21 | $success = $rpc->serverbanexception()->delete($ban); | |
22 | else if ($type == "qline" || $type == "local-qline") | |
23 | $success = $rpc->nameban()->delete($ban); | |
24 | else | |
25 | $success = $rpc->serverban()->delete($ban, $type); | |
26 | ||
27 | ||
28 | if ($success) | |
29 | Message::Success("$type has been removed for $ban"); | |
30 | else | |
31 | Message::Fail("Unable to remove $type on $ban: $rpc->error"); | |
32 | } | |
33 | } | |
34 | } | |
35 | elseif (isset($_POST['tkl_add']) && !empty($_POST['tkl_add'])) | |
36 | { | |
37 | if (!current_user_can(PERMISSION_SERVER_BAN_ADD)) | |
38 | { | |
39 | Message::Fail("Could not add: Permission denied"); | |
40 | } | |
41 | else | |
42 | { | |
43 | if (!($iphost = $_POST['tkl_add'])) | |
44 | Message::Fail("No mask was specified"); | |
45 | else if (!($bantype = (isset($_POST['bantype'])) ? $_POST['bantype'] : false)) | |
46 | { | |
47 | Message::Fail("Unable to add Server Ban: No ban type selected"); | |
48 | } else /* It did */{ | |
49 | ||
50 | if ( | |
51 | ( | |
52 | $bantype == "gline" || | |
53 | $bantype == "gzline" || | |
54 | $bantype == "shun" || | |
55 | $bantype == "eline" | |
56 | ) && strpos($iphost, "@") == false | |
57 | ) // doesn't have full mask | |
58 | $iphost = "*@" . $iphost; | |
59 | ||
60 | $soft = ($_POST['soft']) ? true : false; | |
61 | ||
62 | if ($soft) | |
63 | $iphost = "%" . $iphost; | |
64 | /* duplicate code for now [= */ | |
65 | $banlen_w = (isset($_POST['banlen_w'])) ? $_POST['banlen_w'] : NULL; | |
66 | $banlen_d = (isset($_POST['banlen_d'])) ? $_POST['banlen_d'] : NULL; | |
67 | $banlen_h = (isset($_POST['banlen_h'])) ? $_POST['banlen_h'] : NULL; | |
68 | $duration = ""; | |
69 | if (!$banlen_d && !$banlen_h && !$banlen_w) | |
70 | $duration .= "0"; | |
71 | else { | |
72 | if ($banlen_w) | |
73 | $duration .= $banlen_w; | |
74 | if ($banlen_d) | |
75 | $duration .= $banlen_d; | |
76 | if ($banlen_h) | |
77 | $duration .= $banlen_h; | |
78 | } | |
79 | $msg_msg = ($duration == "0" || $duration == "0w0d0h") ? "permanently" : "for " . rpc_convert_duration_string($duration); | |
80 | $reason = (isset($_POST['ban_reason'])) ? $_POST['ban_reason'] : "No reason"; | |
81 | if ($bantype == "qline") { | |
82 | if ($rpc->nameban()->add($iphost, $reason, $duration)) | |
83 | Message::Success("Name Ban set against \"$iphost\": $reason"); | |
84 | else | |
85 | Message::Fail("Name Ban could not be set against \"$iphost\": $rpc->error"); | |
86 | } elseif ($bantype == "except") { | |
87 | if ($rpc->serverbanexception()->add($iphost, "", $duration, $reason)) | |
88 | Message::Success("Exception set for \"$iphost\": $reason"); | |
89 | else | |
90 | Message::Fail("Exception could not be set \"$iphost\": $rpc->error"); | |
91 | } else if ($rpc->serverban()->add($iphost, $bantype, $duration, $reason)) { | |
92 | Message::Success("Host / IP: $iphost has been $bantype" . "d $msg_msg: $reason"); | |
93 | } else | |
94 | Message::Fail("The $bantype against \"$iphost\" could not be added: $rpc->error"); | |
95 | } | |
96 | } | |
97 | } | |
98 | elseif (isset($_POST['search_types']) && !empty($_POST['search_types'])) | |
99 | { | |
100 | ||
101 | } | |
102 | } | |
103 | ||
104 | ?> | |
105 | <h4>Server Bans Overview</h4> | |
106 | Here are all your network bans, from K-Lines to G-Lines, it's all here.<br><br> | |
107 | <!-- Add ban --> | |
108 | <p><button type="button" class="btn btn-primary" data-toggle="modal" data-target="#myModal" <?php echo (current_user_can(PERMISSION_SERVER_BAN_ADD)) ? "" : "disabled"; ?>> | |
109 | Add entry | |
110 | </button></p></table> | |
111 | <div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="confirmModalCenterTitle" aria-hidden="true"> | |
112 | <div class="modal-dialog modal-dialog-centered" role="document"> | |
113 | <div class="modal-content"> | |
114 | <div class="modal-header"> | |
115 | <h5 class="modal-title" id="myModalLabel">Add new Server Ban</h5> | |
116 | <button type="button" class="close" data-dismiss="modal" aria-label="Close"> | |
117 | <span aria-hidden="true">×</span> | |
118 | </button> | |
119 | </div> | |
120 | <div class="modal-body"> | |
121 | ||
122 | <form method="post"> | |
123 | <div class="align_label">IP / Host: </div> <input class="curvy" type="text" id="tkl_add" name="tkl_add"><br> | |
124 | <div class="align_label">Ban Type: </div> <select class="curvy" name="bantype" id="bantype"> | |
125 | <option value=""></option> | |
126 | <optgroup label="Bans"> | |
127 | <option value="kline">Kill Line (KLine)</option> | |
128 | <option value="gline">Global Kill Line (GLine)</option> | |
129 | <option value="zline">Zap Line (ZLine)</option> | |
130 | <option value="gzline">Global Zap Line (GZLine)</option> | |
131 | ||
132 | </optgroup> | |
133 | </select><br> | |
134 | <div class="align_label"><label for="banlen_w">Duration: </label></div> | |
135 | <select class="curvy" name="banlen_w" id="banlen_w"> | |
136 | <?php | |
137 | for ($i = 0; $i <= 56; $i++) | |
138 | { | |
139 | if (!$i) | |
140 | echo "<option value=\"0w\"></option>"; | |
141 | else | |
142 | { | |
143 | $w = ($i == 1) ? "week" : "weeks"; | |
144 | echo "<option value=\"$i" . "w\">$i $w" . "</option>"; | |
145 | } | |
146 | } | |
147 | ?> | |
148 | </select> | |
149 | <select class="curvy" name="banlen_d" id="banlen_d"> | |
150 | <?php | |
151 | for ($i = 0; $i <= 31; $i++) | |
152 | { | |
153 | if (!$i) | |
154 | echo "<option value=\"0d\"></option>"; | |
155 | else | |
156 | { | |
157 | $d = ($i == 1) ? "day" : "days"; | |
158 | echo "<option value=\"$i" . "d\">$i $d" . "</option>"; | |
159 | } | |
160 | } | |
161 | ?> | |
162 | </select> | |
163 | <select class="curvy" name="banlen_h" id="banlen_h"> | |
164 | <?php | |
165 | for ($i = 0; $i <= 24; $i++) | |
166 | { | |
167 | if (!$i) | |
168 | echo "<option value=\"0d\"></option>"; | |
169 | else | |
170 | { | |
171 | $h = ($i == 1) ? "hour" : "hours"; | |
172 | echo "<option value=\"$i" . "h\">$i $h" . "</option>"; | |
173 | } | |
174 | } | |
175 | ?> | |
176 | </select> | |
177 | <br><div class="align_label"><label for="ban_reason">Reason: </label></div> | |
178 | <input class="curvy input_text" type="text" id="ban_reason" name="ban_reason"><br> | |
179 | <input class="curvy input_text" type="checkbox" id="soft" name="soft">Don't affect logged-in users (soft) | |
180 | ||
181 | </div> | |
182 | ||
183 | <div class="modal-footer"> | |
184 | <button id="CloseButton" type="button" class="btn btn-secondary" data-dismiss="modal">Cancel</button> | |
185 | <button type="submit" action="post" class="btn btn-danger">Add Ban</button> | |
186 | </form> | |
187 | </div> | |
188 | </div> | |
189 | </div> | |
190 | </div> | |
191 | ||
192 | <!-- The banlist table --> | |
193 | ||
194 | <form method="post"> | |
195 | <table id="data_list" class="container-xxl table table-sm table-responsive caption-top table-striped"> | |
196 | <thead class="table-primary"> | |
197 | <th scope="col"><input type="checkbox" label='selectall' onClick="toggle_tkl(this)" /></th> | |
198 | <th scope="col">Mask</th> | |
199 | <th scope="col">Type</th> | |
200 | <th scope="col">Duration</th> | |
201 | <th scope="col">Reason</th> | |
202 | <th scope="col">Set By</th> | |
203 | <th scope="col">Set On</th> | |
204 | <th scope="col">Expires</th> | |
205 | </thead> | |
206 | </table> | |
207 | ||
208 | <!-- Delete button --> | |
209 | <p><button type="button" class="btn btn-danger" data-toggle="modal" data-target="#myModal2" <?php echo (current_user_can(PERMISSION_SERVER_BAN_DEL)) ? "" : "disabled"; ?>> | |
210 | Delete selected | |
211 | </button></p> | |
212 | <div class="modal fade" id="myModal2" tabindex="-1" role="dialog" aria-labelledby="confirmModalCenterTitle" aria-hidden="true"> | |
213 | <div class="modal-dialog modal-dialog-centered" role="document"> | |
214 | <div class="modal-content"> | |
215 | <div class="modal-header"> | |
216 | <h5 class="modal-title" id="myModalLabel">Confirm deletion</h5> | |
217 | <button type="button" class="close" data-dismiss="modal" aria-label="Close"> | |
218 | <span aria-hidden="true">×</span> | |
219 | </button> | |
220 | </div> | |
221 | <div class="modal-body"> | |
222 | Are you sure you want to do this?<br> | |
223 | This cannot be undone. | |
224 | </div> | |
225 | <div class="modal-footer"> | |
226 | <button id="CloseButton" type="button" class="btn btn-secondary" data-dismiss="modal">Cancel</button> | |
227 | <button type="submit" action="post" class="btn btn-danger">Delete</button> | |
228 | ||
229 | </div> | |
230 | </div> | |
231 | </div> | |
232 | </div></form></div></div> | |
233 | ||
234 | <script> | |
235 | $(document).ready( function () { | |
236 | $('#data_list').DataTable({ | |
237 | 'ajax': { | |
238 | 'url': '<?php echo get_config("base_url"); ?>api/server-bans.php', | |
239 | dataSrc: '' | |
240 | }, | |
241 | 'columns': [ | |
242 | { 'data': 'Select' }, | |
243 | { 'data': 'Mask' }, | |
244 | { 'data': 'Type' }, | |
245 | { 'data': 'Duration' }, | |
246 | { 'data': 'Reason' }, | |
247 | { 'data': 'Set By' }, | |
248 | { 'data': 'Set On' }, | |
249 | { 'data': 'Expires' }, | |
250 | ], | |
251 | 'columnDefs': [ | |
252 | { targets: '_all', 'type': 'natural' } | |
253 | ], | |
254 | 'pageLength':100, | |
255 | }); | |
256 | } ); | |
257 | </script> | |
258 | ||
259 | <?php require_once '../inc/footer.php'; ?> |