Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
epsylon
GitHub Repository: epsylon/ufonet
Path: blob/master/core/js/ufo.js
1208 views
1
/*
2
UFONet - Denial of Service Toolkit - 2013/2020 - by psy ([email protected])
3
4
You should have received a copy of the GNU General Public License along
5
with UFONet; if not, write to the Free Software Foundation, Inc., 51
6
Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
7
*/
8
9
// this variable defines the delay between each ajax update (statistics and geoip information)
10
var AJAX_DELAY = 1234
11
12
// interface control definitions, managed by leaflet
13
var UfoControlClass = L.Control.extend({
14
options: {
15
position: 'bottomright'
16
},
17
onAdd: function (map) {
18
var container = L.DomUtil.create('div', 'ufo_msg_div leaflet-control-layers leaflet-control-layers-expanded')
19
L.DomEvent.on(container,'mousedown',L.DomEvent.stopPropagation)
20
.on(container,'doubleclick',L.DomEvent.stopPropagation)
21
.on(container,'click',L.DomEvent.stopPropagation)
22
return container;
23
}
24
});
25
26
var UfoTitleClass = L.Control.extend({
27
options: {
28
position: 'topleft'
29
},
30
onAdd: function (map) {
31
var container = L.DomUtil.create('div', 'ufo_title_div leaflet-control-layers leaflet-control-layers-expanded')
32
return container;
33
}
34
});
35
36
var UfoErrorClass = L.Control.extend({
37
options: {
38
position: 'bottomleft'
39
},
40
onAdd: function (map) {
41
var container = L.DomUtil.create('div', 'ufo_error_div leaflet-control-layers leaflet-control-layers-expanded')
42
return container;
43
}
44
});
45
46
var UfoStatClass = L.Control.extend({
47
options: {
48
position: 'bottomleft'
49
},
50
onAdd: function (map) {
51
var container = L.DomUtil.create('div', 'ufo_stat_div leaflet-control-layers leaflet-control-layers-expanded')
52
L.DomEvent.on(container,'mousedown',L.DomEvent.stopPropagation)
53
.on(container,'doubleclick',L.DomEvent.stopPropagation)
54
.on(container,'click',L.DomEvent.stopPropagation)
55
return container;
56
}
57
});
58
59
// leaflet cluster, regrouping zombies by country
60
function Cluster(){
61
this._clusters=new Array()
62
this.add=function(zombie,marker){
63
cc=zombie.country_code
64
cg=false
65
if(cc){
66
cg=this.find(cc)
67
if(cg==false){
68
cg=new L.MarkerClusterGroup()
69
this._clusters.push({"cc":cc,"z":zombie,"cg":cg})
70
}
71
cg.addLayer(marker)
72
map.addLayer(cg)
73
}
74
}
75
this.find=function(cc){
76
for(c in this._clusters){
77
if(this._clusters[c].cc==cc){
78
return this._clusters[c].cg
79
}
80
}
81
return false
82
}
83
}
84
85
// Target object
86
function Doll(name){
87
this.name = name
88
this.data=false
89
this.latlong = false
90
this.city = false
91
this.country = false
92
this.country_code = false
93
this.asn = false
94
this.ip = false
95
this.hostname = false
96
this.drawnLayers = new Array()
97
this.show=function(){
98
target_icon=L.icon({iconUrl:"",
99
iconSize: [25, 41],
100
iconAnchor: [13, 42],
101
popupAnchor: [-3, -76],
102
shadowUrl: '',
103
shadowSize: [68, 95],
104
shadowAnchor: [22, 94]
105
})
106
var marker = L.marker(this.latlong,{icon: target_icon})
107
var popup = L.Popup({
108
maxHeight: 50})
109
var popupcontent = "<b>"+this.name+"</b>"
110
+"<br />-------------<br />"
111
+"Localisation: "+this.city+"/"+this.country
112
+"<br/>"
113
+"IP: "+this.ip+"<br/>"
114
+"Hostname: "+this.hostname+"<br/>"
115
+"ASN: "+this.asn+"<br/>"
116
marker.bindPopup(popupcontent)
117
this.drawnLayers.push(marker)
118
map.addLayer(marker)
119
}
120
this.setData = function(data){
121
this.data=data
122
this.latlong = data[0]
123
this.city = data[1]
124
this.country = data[2]
125
this.country_code = data[3]
126
this.asn = data[4]
127
this.ip = data[5]
128
this.hostname = data[6]
129
}
130
}
131
132
// object for each zombie
133
function zombieEntry(name,data){
134
this.data=data
135
this.name = name
136
this.latlong = data[0]
137
this.city = data[1]
138
this.country = data[2]
139
this.country_code = data[3]
140
this.asn = data[4]
141
this.ip = data[5]
142
this.hostname = data[6]
143
this.drawnLayers = new Array()
144
this.index=0
145
this.state='awakening'
146
this.speed= 1000 // animation speed in ms
147
this.cluster = false
148
this.show=function(){
149
if(this.state==='awakening'){
150
this.state='awake'
151
this.stop_anim=false
152
this.drawMarker()
153
}
154
}
155
this.drawMarker=function(){
156
if(!zombie_icon)
157
zombie_icon=L.icon({iconUrl:"",
158
iconSize: [16, 15],
159
iconAnchor: [8, 8],
160
popupAnchor: [-3, -76]
161
})
162
var marker = L.marker(this.latlong,{icon:zombie_icon}) //,{icon: this.makeCustomMarker()})
163
var popup = L.Popup({
164
maxHeight: 50})
165
var popupcontent = "<b>"+this.name+"</b>"
166
+"<br />-------------<br />"
167
+"Localisation: "+this.city+"/"+this.country+"<br/>"
168
+"IP: "+this.ip+"<br/>"
169
+"Hostname: "+this.hostname+"<br/>"
170
+"ASN: "+this.asn+"<br/>"
171
marker.bindPopup(popupcontent)
172
cluster.add(this,marker)
173
this.drawnLayers.push(marker)
174
this.fire()
175
}
176
this.fire = function(){
177
if(doll){
178
var src = this.latlong
179
var dest = doll.latlong
180
var b = new R.BezierAnim([src, dest])
181
map.addLayer(b)
182
this.drawnLayers.push(b)
183
}
184
}
185
this.makeCustomMarker= function(){
186
if (this.index < this.counter_max){
187
var customIcon = new L.icon({
188
iconUrl: '',
189
iconSize: [30, 30], // size of the icon
190
iconAnchor: [15, 15], // point of the icon which will correspond to marker's location
191
popupAnchor: [-150, 50] // point from which the popup should open relative to the iconAnchor
192
});
193
}
194
if (this.index == this.counter_max){
195
var customIcon = new L.icon({
196
iconUrl: '',
197
iconSize: [30, 30], // size of the icon
198
iconAnchor: [15, 15], // point of the icon which will correspond to marker's location
199
popupAnchor: [-150, 0] // point from which the popup should open relative to the iconAnchor
200
});
201
}
202
return customIcon
203
}
204
this.makeClusterGroups=function(country_code_list){
205
for (var i = 0; i < this.unique_country_code_list.length; i++){
206
if (this.unique_country_code_list[i] == this.country_code_list[this.index]){
207
if (this.clusterGroups[this.unique_country_code_list[i]]){
208
//checks if a cluster for the country already exists
209
return
210
}
211
else
212
//if not make it.
213
this.clusterGroups[this.unique_country_code_list[i]] = new L.MarkerClusterGroup();
214
}
215
}
216
}
217
this.AddMarkerCluster= function(marker){
218
this.clusterGroups[this.country_code_list[this.index]].addLayer(marker)
219
map.addLayer(this.clusterGroups[this.country_code_list[this.index]])
220
this.drawnLayers.push(this.clusterGroups[this.country_code_list[this.index]])
221
}
222
this.AddMarker=function(src){
223
var marker = L.marker([src[0], src[1]],{icon: this.makeCustomMarker()})
224
this.drawnLayers.push(marker)
225
}
226
this.hide=function() {
227
$('.header').hide()
228
this.index =0
229
this.state='awakening'
230
this.stop_anim=true
231
for (i in this.drawnLayers){
232
if(map.hasLayer(this.drawnLayers[i]))
233
map.removeLayer(this.drawnLayers[i])
234
}
235
this.drawnLayers=new Array()
236
}
237
}
238
239
// List of zombies
240
function Herd(){
241
this.zombieEntries = new Array
242
this.find=function (name){
243
for (z in this.zombieEntries){
244
if (this.zombieEntries[z].name === name){
245
return this.zombieEntries[z]
246
}
247
}
248
return false;
249
}
250
this.load=function(name){
251
e=this.find(name)
252
if(e){
253
e.show()
254
return
255
}
256
return false
257
}
258
this.hideAll = function(){
259
for (ufoe in this.zombieEntries)
260
this.zombieEntries[ufoe].hide()
261
this.render()
262
}
263
this.hide = function(name){
264
var ufoe=this.find(name)
265
if(!ufoe) return
266
ufoe.hide()
267
this.render()
268
}
269
this.remove = function(name){
270
for (z in this.zombieEntries){
271
if(this.zombieEntries[z].name === name){
272
this.zombieEntries[z].hide()
273
this.zombieEntries.splice(z,1)
274
this.render()
275
return
276
}
277
}
278
}
279
this.add = function(name,data){
280
var ufoe=this.find(name)
281
if(!ufoe){
282
ufoe=new zombieEntry(name,data)
283
this.zombieEntries.push(ufoe)
284
}
285
ufoe.show()
286
return ufoe
287
}
288
this.stop=function() {
289
for(i=0;i<this.zombieEntries.length;i++) {
290
this.zombieEntries[i].stop();
291
}
292
this.render()
293
}
294
this.count=function(){
295
return this.zombieEntries.length
296
}
297
}
298
299
// jquery shortcuts
300
function ufomsg(msg){
301
if ($('#ufomsg').html().indexOf(msg) == -1){
302
$('#ufomsg').append(msg+"<br/>\n")
303
$('#ufomsg_last').html(msg)
304
}
305
}
306
307
function show_error(){
308
$(".ufo_error_div").toggle()
309
}
310
311
function zombie_detail(data=''){
312
t=''
313
if (data!=''){
314
t+="<h2>Zombie: <i>"+data.name+"</i> <a href='#' onclick='zombie_detail()'>X</a></h2>"
315
t+=data.hits+" hits / "+data.retries+" retries / "+data.fails+" fails <br/>"
316
t+=data.min_time+" min time / "+data.avg_time+" average time / "+data.max_time+" max time <br/>"
317
t+=data.min_size+" min size / "+data.avg_size+" average size / "+data.max_size+" max size <br/>"
318
}
319
$('#zombie_detail').html(t)
320
}
321
322
// watchdog function
323
function ufowatch(){
324
// if attack mode we have a doll, and do a check if herd is done and bail if so
325
// if herd is not done, get stats
326
if(doll && !hdone){
327
d = new Date()
328
$("#ufostat").load("/js/ajax.js?stats="+d.getTime()).show()
329
}
330
// load doll geoip data
331
if(doll && !doll.data)
332
$(".ufo_error_div").load("/js/ajax.js?fetchdoll="+doll.name)
333
// bail if all zombies are done in view mode
334
if (zdone)
335
return
336
// we are not finished loading zombie geoip data, let's start...
337
d=new Date
338
var lw=d.getTime()
339
error=''
340
// basic check to prevent overload - relies on AJAX_DELAY variable
341
if(last_watch < lw - AJAX_DELAY){
342
last_watch=lw
343
// loading next zombie
344
$(".ufo_error_div").load('/js/ajax.js?zombie='+btoa(unescape(encodeURIComponent(last_zombie))))
345
label=Zombies.count()+"/"+total_zombies
346
if (Zombies.count()== total_zombies)
347
label = total_zombies
348
else
349
if (Zombies.count() +dead_zombies.length== total_zombies){
350
label=total_zombies
351
if(dead_zombies.length>0){
352
label=total_zombies -dead_zombies.length
353
$('.ufo_error_div').html('<div id="ufo_error_div">To be discarded : <br/><ul>'
354
+dead_zombies.join("<li> -")+'</ul></div>')
355
error = "<a href='#' onclick='show_error()'> + "+dead_zombies.length+" not listed...</a>"
356
}
357
}
358
$(".ufo_title_div").html('<div id="status"><center><h2><font color="red">Zombies:</font></h2><h3><font color="green" size="9px"><b>'+label+'</b></font></h3>'+error+'</center></div>');
359
}
360
}
361
362
// (leaflet) map initialization
363
function initMap (targetdoll=false) {
364
if(map){
365
return
366
}
367
if(targetdoll){
368
doll=targetdoll
369
}
370
index = 0
371
osm_sat = L.tileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png')
372
map = L.map('map',{
373
minZoom: 2,
374
maxZoom: 7,
375
zoomControl:false,
376
layers: [osm_sat]
377
});
378
if (typeof latlong !== 'undefined') {
379
map.setView(latlong[index], 1)
380
}
381
else{
382
map.setView(new L.LatLng(0,0), 1)
383
}
384
osm_sat.addTo(map)
385
var baseMaps = {
386
"Sats": osm_sat,
387
}
388
// initializing controls:
389
new L.control.layers(baseMaps, null, {collapsed:false}).addTo(map)
390
new L.Control.Zoom({position: 'topright'}).addTo(map)
391
map.scrollWheelZoom.disable()
392
map.addControl(new UfoControlClass())
393
$('.ufo_msg_div').html("<h2 style='text-align:right'>Map Console <a href=\"#\" id='showMsg'>[+]</a> <a href=\"#\" id='hideMsg'>[-]</a></h2><div id='ufomsg'>[Info] [AI] [Control] Locating zombies... -> [Waiting!]<br/><br/></div><div id='ufomsg_last'>[Info] [AI] [Control] Locating zombies.... -> [Waiting!]<br/></div>")
394
map.addControl(new UfoTitleClass())
395
$(".ufo_title_div").html('<div id="status"><h2><font color="red">Zombies:</font></h2><center><h3><font color="green" size="9px"><b>'+total_zombies+'</b></font></h3></center></div>');
396
map.addControl(new UfoErrorClass())
397
$('.ufo_error_div').hide()
398
map.addControl(new UfoStatClass())
399
$('.ufo_stat_div').html("<h2 style='text-align:right'>Last Statistics <a href=\"#\" id='showStat'>[+]</a> <a href=\"#\" id='hideStat'>[-]</a></h2><div id='zombie_detail'></div><div id=\"ufostat\"></div>").hide()
400
$('a#showStat').hide()
401
$('a#showStat').click(function(){
402
$('a#showStat').hide()
403
$('a#hideStat').show()
404
$('#ufostat').show()
405
})
406
$('a#hideStat').click(function(){
407
$('a#hideStat').hide()
408
$('a#showStat').show()
409
$('#ufostat').hide()
410
})
411
$('a#hideMsg').hide()
412
$('#ufomsg').hide()
413
$('a#showMsg').click(function(){
414
$('a#showMsg').hide()
415
$('a#hideMsg').show()
416
$('#ufomsg').show()
417
$('#ufomsg_last').hide()
418
})
419
$('a#hideMsg').click(function(){
420
$('a#hideMsg').hide()
421
$('a#showMsg').show()
422
$('#ufomsg').hide()
423
$('#ufomsg_last').show()
424
})
425
// starting watchdog ajax request
426
window.setInterval("ufowatch()",AJAX_DELAY)
427
}
428
// global variables
429
var Zombies = new Herd()
430
var cluster = new Cluster()
431
var map = false
432
var last_zombie = 'None'
433
var zombie_icon = false
434
d=new Date
435
var last_watch = d.getTime()
436
var target_icon = false
437
var doll = false
438
var dead_zombies = new Array()
439
var errdiv = false
440
var hdone = false
441
var zdone = false
442
var total_zombies=false
443
444