-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmattermost-alerts_linux.cna
98 lines (81 loc) · 4.13 KB
/
mattermost-alerts_linux.cna
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
# Author: @nickvourd.
# Spacial thanks to @sec_groundzero.
# Based on the work of @bluescreenofjeff.
$mattermost_webhookURL = 'https://your-mattermost-server.com/hooks/xxx-generatedkey-xxx'; # Change this with your Mattermost webhook url
$teamserver_hostname = 'XXXXXX'; # Change this with your hostname
$active_users = "";
$mm_emoji_beacon = ':skull:';
$mm_emoji_connect = ':warning:';
$mm_emoji_web_hit = ':bell:';
$mm_emoji_info = ':information_source:';
$mm_emoji_message = ':memo:';
$mm_emoji_keystrokes = ':bomb:';
$mm_emoji_site = ':construction_worker:';
$mm_emoji_screenshot = ':eyes:';
# csusersinfo function
sub csusersinfo {
foreach %csuser (users()) {
$active_users .= "- " . %csuser . "\n\n";
}
}
# New Beacon Alert
on beacon_initial {
$user = beacon_data($1)["user"];
$computer = beacon_data($1)["computer"];
$host = beacon_data($1)["host"];
$arch = beacon_data($1)["barch"];
$external = beacon_data($1)["external"];
$internal = beacon_data($1)["internal"];
$listener = beacon_data($1)["listener"];
$process = beacon_data($1)["process"];
$pid = beacon_data($1)["pid"];
@curl_command = @('curl','-X','POST','-H', 'Content-Type: application/json', '-d', '{"text": "@all '.$mm_emoji_beacon.' New Beacon on '.$teamserver_hostname.'. GameOn!\n\nInitial beacon from '.$user.'@'.$host.' ('. $computer .')\n\n'.$mm_emoji_info.' Beacon Details:\n\nExternal: '.$external.'\n\nInternal: '.$internal.'\n\nListener: '.$listener.'\n\nUser: '.$user.'\n\nComputer: '.$computer.'\n\nProccess: '.$process.'\n\nPid: '.$pid.'\n\nArch: '.$arch.'"}', $mattermost_webhookURL);
exec(@curl_command);
}
# New CS Client Connected Alert
on event_join {
# Call function named csusersinfo
csusersinfo();
@curl_command = @('curl', '-X', 'POST', '-H', 'Content-Type: application/json', '-d', '{"text": "'.$mm_emoji_connect.' '.$1.' has connected to '.$teamserver_hostname.'!\n\n'.$mm_emoji_info.' Active CS users:\n\n'.$active_users.'"}', $mattermost_webhookURL);
exec(@curl_command);
# Clean the variable
$active_users = "";
}
# New CS Client Disconnected Alert
on event_quit {
# Call function named csusersinfo
csusersinfo();
@curl_command = @('curl', '-X', 'POST', '-H', 'Content-Type: application/json', '-d', '{"text": "'.$mm_emoji_connect.' '.$1.' has disconnected to '.$teamserver_hostname.'!\n\n'.$mm_emoji_info.' Active CS users:\n\n'.$active_users.'"}', $mattermost_webhookURL);
exec(@curl_command);
# Clean the variable
$active_users = "";
}
# CS Client Public Message Event Alert
on event_public {
@curl_command = @('curl', '-X', 'POST', '-H', 'Content-Type: application/json', '-d', '{"text": "'.$mm_emoji_message.' New public message from: '.$1.'\n\n'.$mm_emoji_info .' Message content:\n\n '.$2.'"}', $mattermost_webhookURL);
exec(@curl_command);
}
# New Site Event Log Alert
on event_newsite {
@curl_command = @('curl', '-X', 'POST', '-H', 'Content-Type: application/json', '-d', '{"text": "'.$mm_emoji_site.' '.$1.' set up a new site on '.$teamserver_hostname.'!\n\n'.$mm_emoji_info.' New site details:\n\n'.$2.'"}', $mattermost_webhookURL);
exec(@curl_command);
}
# New Keystrokes Alert
on keystrokes {
$keyuser = $1['user'];
$keytitle = $1['title'];
@curl_command = @('curl', '-X', 'POST', '-H', 'Content-Type: application/json', '-d', '{"text": "'.$mm_emoji_keystrokes.' Received new Keystrokes from '.$keytitle.' by '.$keyuser.'!"}', $mattermost_webhookURL);
exec(@curl_command);
}
# New Web Hit Alert
on web_hit {
@curl_command = @('curl','-X','POST', '-H', 'Content-Type: application/json', '-d', '{"text": "'.$mm_emoji_web_hit.' New Web hit!\n\n'.$mm_emoji_info.' Web Log Details:\n\nFrom: '.$3.'\n\nRequest: '.$1.' '.$2.'\n\nResponse: '.$5.'\n\nUser-Agent: '.$4.'"}',$mattermost_webhookURL);
exec(@curl_command);
}
# New Screenshot Alert
on screenshots {
$screenuser = $1['user'];
$screentitle = $1['title'];
@curl_command = @('curl', '-X', 'POST', '-H', 'Content-Type: application/json', '-d', '{"text": "'.$mm_emoji_screenshot.' Received new screenshot of '.$screentitle.' by '.$screenuser.'!"}', $mattermost_webhookURL);
exec(@curl_command);
}