-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathBPS - BESClient - Watchdog Install.bes
92 lines (83 loc) · 17.2 KB
/
BPS - BESClient - Watchdog Install.bes
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
<?xml version="1.0" encoding="UTF-8"?>
<BES xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="BES.xsd">
<Task>
<Title>BPS | BESClient | Watchdog Install</Title>
<Description><![CDATA[
<STYLE> .header { font-size: 14px; background-color: #990000; color: white; padding: 6px 40px 6px 10px; white-space: nowrap; } .row { font-size: 14px; padding: 6px 40px 6px 10px; border: 1px solid black; border-top: none; } .nowrap { white-space: nowrap; } </STYLE>
<DIV style="BORDER-TOP: medium none; BORDER-RIGHT: #1976d2 10px solid; BORDER-BOTTOM: #1976d2 10px solid; BORDER-LEFT: #1976d2 10px solid">
<DIV style="COLOR: white; PADDING-BOTTOM: 10px; PADDING-TOP: 10px; PADDING-LEFT: 10px; PADDING-RIGHT: 10px; BACKGROUND-COLOR: #1976d2"><IMG style="VERTICAL-ALIGN: top; PADDING-BOTTOM: 0px; PADDING-TOP: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px" src=""> </DIV>
<DIV style="FONT-SIZE: 18px; FONT-FAMILY: sans-serif; FONT-WEIGHT: 300; PADDING-BOTTOM: 20px; PADDING-TOP: 20px; PADDING-LEFT: 20px; PADDING-RIGHT: 20px">This fixlet installs the watchdog solution for the Linux-based BESClient services.<BR> <BR>The BESClient service can be stopped on client machines for various reasons. To ensure the BESClient service is running across your environment, use the action below to use the Linux scheduler <EM>(aka cron)</EM> and schedule an hourly task that checks the BESClient service and restarts them if necessary.<BR> <BR><STRONG>Note:</STRONG> Do not set the "Reapply" behavior when taking this action or you may cause the BES Client to constantly schedule new tasks.<BR> <BR><STRONG>Note:</STRONG> One Bash script will be downloaded to and scheduled via crontab to run hourly on client machines.</DIV></DIV>]]></Description>
<Relevance>unix of operating system</Relevance>
<Relevance>(operating system as string as lowercase contains "CentOS" as lowercase) OR (operating system as string as lowercase contains "Red Hat" as lowercase) OR (operating system as string as lowercase contains "RedHat" as lowercase) OR (operating system as string as lowercase contains "Debian" as lowercase) OR (operating system as string as lowercase contains "Ubuntu" as lowercase)</Relevance>
<Relevance>exists file "/bin/sh"</Relevance>
<Relevance>not exists relay service</Relevance>
<Category>BESClient, Watchdog, Install</Category>
<Source>HCL BigFix Professional Services</Source>
<SourceID>[email protected]</SourceID>
<SourceReleaseDate>2020-08-01</SourceReleaseDate>
<SourceSeverity>High</SourceSeverity>
<CVENames></CVENames>
<SANSID></SANSID>
<MIMEField>
<Name>x-fixlet-modification-time</Name>
<Value>Tue, 06 Oct 2020 21:42:23 +0000</Value>
</MIMEField>
<Domain>BESC</Domain>
<DefaultAction ID="Action1">
<Description>
<PreLink>Click </PreLink>
<Link>here</Link>
<PostLink> to run this fixlet.</PostLink>
</Description>
<ActionScript MIMEType="application/x-Fixlet-Windows-Shell"><![CDATA[// Prefetch the current version of the BESClient watchdog Bash script
prefetch besclient_watchdog.sh sha1:8788a6d9038a791f672da7409df59b1d21142c76 size:5782 https://raw.githubusercontent.com/cmcannady/bigfix/master/besclient_watchdog.sh sha256:1a5c51c7d93889a7156ac443c1a35a5eb31a498e1b762da48dcd4ffcb5a46529
// Make sure that the BESTools directory exists on the BESClient
wait sudo su - root -c "mkdir -p /var/opt/BESTools"
parameter "__ExitCode01" = "{if exist exit code of action then exit code of action as string else "999"}"
if {parameter "__ExitCode01" != "0"}
exit {parameter "__ExitCode01"}
endif
// Good housekeeping
wait sudo su - root -c "rm -f /var/opt/BESTools/crontab.tmp"
// Validate the BESClient watchdog Bash script
if {exists file "/var/opt/BESTools/besclient_watchdog.sh"}
if {not (sha1 of file "/var/opt/BESTools/besclient_watchdog.sh" = "8788a6d9038a791f672da7409df59b1d21142c76") OR not (sha256 of file "/var/opt/BESTools/besclient_watchdog.sh" = "1a5c51c7d93889a7156ac443c1a35a5eb31a498e1b762da48dcd4ffcb5a46529")}
wait sudo su - root -c "rm -f /var/opt/BESTools/besclient_watchdog.sh"
move __Download/besclient_watchdog.sh "/var/opt/BESTools/besclient_watchdog.sh"
endif
else
move __Download/besclient_watchdog.sh "/var/opt/BESTools/besclient_watchdog.sh"
endif
// Check for non-zero exit code from AS move commands above
parameter "__ExitCode02" = "{if exist exit code of action then exit code of action as string else "998"}"
if {parameter "__ExitCode02" != "0"}
exit {parameter "__ExitCode02"}
endif
// Set permissions of BESClient watchdog Bash script
wait sudo su - root -c "chmod 744 /var/opt/BESTools/besclient_watchdog.sh"
parameter "__ExitCode03" = "{if exist exit code of action then exit code of action as string else "997"}"
if {parameter "__ExitCode03" != "0"}
exit {parameter "__ExitCode03"}
endif
// Dump crontab list to temporary file
wait sudo su - root -c "crontab -l > /var/opt/BESTools/crontab.tmp"
parameter "__ExitCode04" = "{if exist exit code of action then exit code of action as string else "996"}"
if {parameter "__ExitCode04" != "0"}
if {parameter "__ExitCode04" != "1" and not exists file "/var/opt/BESTools/crontab.tmp"}
exit {parameter "__ExitCode04"}
endif
endif
// Inspect crontab tmp file for watchdog keywords & insert record if necessary
if {if (exists file "/var/opt/BESTools/crontab.tmp") then (if (not exists (lines whose (it contains "besclient_watchdog.sh") of file "/var/opt/BESTools/crontab.tmp" as trimmed string)) then (True) else (False)) else (False)}
wait sudo su - root -c "echo \"@hourly /var/opt/BESTools/besclient_watchdog.sh\" >> /var/opt/BESTools/crontab.tmp; crontab /var/opt/BESTools/crontab.tmp"
parameter "__ExitCode5" = "{if exist exit code of action then exit code of action as string else "995"}"
if {parameter "__ExitCode5" != "0"}
exit {parameter "__ExitCode5"}
endif
endif
// Good housekeeping
wait sudo su - root -c "rm -f /var/opt/BESTools/crontab.tmp"]]></ActionScript>
<SuccessCriteria Option="CustomRelevance">exit code of action != 0</SuccessCriteria>
</DefaultAction>
</Task>
</BES>