-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathIPSubnetInfo - Global - BESClient - Default Settings with Exception Option.bes
165 lines (150 loc) · 24.4 KB
/
IPSubnetInfo - Global - BESClient - Default Settings with Exception Option.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
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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
<?xml version="1.0" encoding="UTF-8"?>
<BES xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="BES.xsd">
<Task>
<Title>IPSubnetInfo | Global | BESClient | Default Settings with Exception Option</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 manages the default BESClient settings for ALL non-infrastructure endpoints managed by BigFix on the <FONT color=#ff0000><STRONG><EM><<<PUT_CLIENT_NAME_HERE>>></EM></STRONG></FONT> network with an exception option to exclude specific settings.</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">Please see <A href="https://github.com/cmcannady/IPSubnetInfo"><FONT color=#0066cc>https://github.com/cmcannady/IPSubnetInfo</FONT></A> for additional details and documentation for the IPSubnetInfo and related open-source projects.</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"><STRONG><FONT color=#ff0000>NOTE: All content available from my personal GitHub is provided AS-IS and without warranty</FONT></STRONG></DIV></DIV>]]></Description>
<Relevance>(not exists relay service) AND (not exists main gather service)</Relevance>
<Relevance>(not exists setting "__RelaySelect_Automatic" whose (value of it = "1") of client)</Relevance>
<Relevance>(not exists setting "_BESClient_Report_MinimumInterval" whose (value of it = "600") of client)</Relevance>
<Relevance>(not exists setting "_BESClient_RelaySelect_ResistFailureIntervalSeconds" whose (value of it = "21600") of client)</Relevance>
<Relevance>if (not exists setting "__IPSubnetInfo_Default_Settings_Exception" whose (value of it = "1") of client) then ((not exists setting "_BESClient_Comm_CommandPollEnable" whose (value of it = "1") of client)) else (true)</Relevance>
<Relevance>(not exists setting "_BESClient_Comm_CommandPollIntervalSeconds" whose (value of it = "21600") of client)</Relevance>
<Relevance>(not exists setting "_BESClient_Download_PreCacheStageDiskLimitMB" whose (value of it = "8192") of client)</Relevance>
<Relevance>/* MAKE SURE TO UPDATE THE DMZ-FDQN-GOES-HERE WITH CORRECT C-NAME ALIAS */
(not exists setting "_BESClient_RelaySelect_FailoverRelay" whose (value of it = "http://DMZ-FDQN-GOES-HERE:52311/bfmirror/downloads/") of client)</Relevance>
<Relevance>(not exists setting "_BESClient_NetSignature" whose (value of it = unique value of concatenations ";" of (it as string) whose(it != "127.0.0.1" and it does not start with "169.") of addresses of ip interfaces of network as string) of client)</Relevance>
<Category>IPSubnetInfo, Global, BESClient, Default, Settings, Exception, Option</Category>
<Source>HCL BigFix Professional Services</Source>
<SourceID></SourceID>
<SourceReleaseDate>2019-10-23</SourceReleaseDate>
<SourceSeverity>Low</SourceSeverity>
<CVENames></CVENames>
<SANSID></SANSID>
<MIMEField>
<Name>x-fixlet-modification-time</Name>
<Value>Thu, 01 Jun 2023 14:06:58 +0000</Value>
</MIMEField>
<Domain>BESC</Domain>
<DefaultAction ID="Action1">
<Description>
<PreLink>Click </PreLink>
<Link>here</Link>
<PostLink> to run the action.</PostLink>
</Description>
<ActionScript MIMEType="application/x-Fixlet-Windows-Shell"><![CDATA[// *** *************************************************************************** ***
// *** Title :: IPSubnet | Global | BESClient | Default Settings ***
// *** Author :: Casey Cannady ([email protected]) ***
// *** Company :: HCL Software - BigFix Professional Services ***
// *** Date Created :: 10/23/2019 ***
// *** Date Modified :: 06/01/2023 ***
// *** *************************************************************************** ***
// Static parameters
// *** ********************************************************************** ***
// *** MAKE SURE TO UPDATE THE DMZ-FDQN-GOES-HERE WITH CORRECT C-NAME ALIAS ***
// *** ********************************************************************** ***
parameter "__DMZ_RELAY" = "http://DMZ-FDQN-GOES-HERE:52311/bfmirror/downloads/"
// Handle registration address requirement
if {exists setting "_BESClient_RegistrationAddress" of client}
parameter "__RegistrationAddress" = "{value of setting "_BESClient_RegistrationAddress" of client}"
else
if {exists registration address of client}
parameter "__RegistrationAddress" = "{registration address of client}"
else
exit "999"
endif
endif
// Set agents to use automatic relay selection
setting "__RelaySelect_Automatic"="1" on "{now}" for client
// Check for existance of IPSubnetInfo CSV file in current site cache
if {exists file "IPSubnetInfo.csv" of folder (pathname of client folder of current site)}
// Identify IPSubnetInfo record from CSV by CIDR string comparison
// *** ************************************************** ***
// *** PLEASE do not change the following relevance ***
// *** unless you're very comfortable with advance ***
// *** relevance concepts like concatenations and tuples. ***
// *** ************************************************** ***
parameter "__IPSubnetInfo" = "{((item 1 of it as string) of (maximum of (tuple string items 0 of substrings separated by "|" of it as integer) |0 , substrings separated by "|" of it) whose (item 0 of it = (tuple string item 0 of item 1 of it as integer)) of concatenation "|" of (concatenation ", " of tuple string items of item 0 of it) of (elements of item 0 of it , elements of item 1 of it) whose (item 1 of it starts with tuple string item 1 of item 0 of it) of ((set of(concatenation ", " of ((following text of first "/" of it) of tuple string item 0 of it /*the mask size*/ ;((first (following text of first "/" of it as integer) of it) of ((concatenation of lasts 8 of padded strings of (it as integer as bit set) of substrings separated by "." of preceding text of first "/" of tuple string item 0 of it) & "/" & following text of first "/" of it) of tuple string item 0 of it);(tuple string items of it))) of (concatenation ", " of substrings separated by "," of it) of lines whose (it starts with (preceding text of last "." of preceding text of last "." of (value of setting "_BESClient_RegistrationAddress" of client))) of (file "IPSubnetInfo.csv" of folder (pathname of client folder of current site))) , (set of (concatenation of lasts 8 of padded strings of (it as integer as bit set) of substrings separated by "." of (value of setting "_BESClient_RegistrationAddress" of client))))) as string}"
// Extract subnet info for client
parameter "__IPSubnet_Subnet" = "{(tuple string item 2 of it|"IPMissing") of (parameter "__IPSubnetInfo") as trimmed string}"
parameter "__IPSubnet_SubnetMask" = "{(tuple string item 0 of it|"SubnetMissing") of (parameter "__IPSubnetInfo") as trimmed string}"
parameter "__IPSubnet_Region" = "{(tuple string item 7 of it|"RegionMissing") of (parameter "__IPSubnetInfo") as trimmed string}"
parameter "__IPSubnet_Country" = "{(tuple string item 6 of it|"CountryMissing") of (parameter "__IPSubnetInfo") as trimmed string}"
parameter "__IPSubnet_State" = "{(tuple string item 5 of it|"StateMissing") of (parameter "__IPSubnetInfo") as trimmed string}"
parameter "__IPSubnet_SiteName" = "{(tuple string item 4 of it|"SiteNameMissing") of (parameter "__IPSubnetInfo") as trimmed string}"
parameter "__IPSubnet_SiteID" = "{(tuple string item 3 of it|"SiteCodeMissing") of (parameter "__IPSubnetInfo") as trimmed string}"
// Set the SeekList using the IPSubnetInfo CSV file query
// *** ************************************************** ***
// *** Please make sure to remove the * at the end of the ***
// *** SeekList to remove the wild card option. ***
// *** ************************************************** ***
setting "_BESClient_Register_Affiliation_SeekList"="{parameter "__IPSubnet_SiteID" & ";" & parameter "__IPSubnet_SiteName" & ";" & parameter "__IPSubnet_State" & ";" & parameter "__IPSubnet_Country" & ";" & parameter "__IPSubnet_Region" & ";*"}" on "{now}" for client
else
// Record current state in absence of IPSubnetInfo CSV file
parameter "__IPSubnet_Subnet" = "{subnet address of adapters of network}"
parameter "__IPSubnet_SubnetMask" = "{subnet mask of adapters of network}"
parameter "__IPSubnet_Region" = "UNKNOWN"
parameter "__IPSubnet_Country" = "UNKNOWN"
parameter "__IPSubnet_State" = "UNKNOWN"
parameter "__IPSubnet_SiteName" = "UNKNOWN"
parameter "__IPSubnet_SiteID" = "UNKNOWN"
// Set the SeekList using the AD-Site client property
setting "_BESClient_Register_Affiliation_SeekList"="*" on "{now}" for client
endif
// Set subnet info client properties
setting "__IPSubnet_BESClient_Subnet"="{parameter "__IPSubnet_Subnet"}" on "{now}" for client
setting "__IPSubnet_BESClient_SubnetMask"="{parameter "__IPSubnet_SubnetMask"}" on "{now}" for client
setting "__IPSubnet_BESClient_Region"="{parameter "__IPSubnet_Region"}" on "{now}" for client
setting "__IPSubnet_BESClient_Country"="{parameter "__IPSubnet_Country"}" on "{now}" for client
setting "__IPSubnet_BESClient_State"="{parameter "__IPSubnet_State"}" on "{now}" for client
setting "__IPSubnet_BESClient_SiteName"="{parameter "__IPSubnet_SiteName"}" on "{now}" for client
setting "__IPSubnet_BESClient_SiteID"="{parameter "__IPSubnet_SiteID"}" on "{now}" for client
// Force client to register with relay
relay select
// Override default client settings for BES managed endpoints
if {(not exists setting "__IPSubnetInfo_Default_Settings_Exception" whose (value of it = "1") of client)}
setting "_BESClient_Report_MinimumInterval"="600" on "{now}" for client
setting "_BESClient_RelaySelect_ResistFailureIntervalSeconds"="21600" on "{now}" for client
setting "_BESClient_Report_Encryption"="optional" on "{now}" for client
setting "_BESClient_Comm_CommandPollEnable"="1" on "{now}" for client
setting "_BESClient_Comm_CommandPollIntervalSeconds"="21600" on "{now}" for client
setting "_BESClient_Download_MinimumDiskFreeMB"="2048" on "{now}" for client
setting "_BESClient_Log_Days"="30" on "{now}" for client
setting "_BESClient_Log_MaxSize"="1536000" on "{now}" for client
setting "_BESClient_Download_UtilitiesCacheLimitMB"="4096" on "{now}" for client
setting "_BESClient_Download_DownloadsCacheLimitMB"="4096" on "{now}" for client
setting "_BESClient_Download_NormalStageDiskLimitMB"="8192" on "{now}" for client
setting "_BESClient_Download_PreCacheStageDiskLimitMB"="8192" on "{now}" for client
setting "_BESClient_Resource_AccelerateForPendingMessage"="1" on "{now}" for client
else
setting delete "_BESClient_Comm_CommandPollEnable" on "{now}" for client
setting "_BESClient_Report_MinimumInterval"="600" on "{now}" for client
setting "_BESClient_RelaySelect_ResistFailureIntervalSeconds"="21600" on "{now}" for client
setting "_BESClient_Report_Encryption"="optional" on "{now}" for client
setting "_BESClient_Comm_CommandPollIntervalSeconds"="21600" on "{now}" for client
setting "_BESClient_Download_MinimumDiskFreeMB"="2048" on "{now}" for client
setting "_BESClient_Log_Days"="30" on "{now}" for client
setting "_BESClient_Log_MaxSize"="1536000" on "{now}" for client
setting "_BESClient_Download_UtilitiesCacheLimitMB"="4096" on "{now}" for client
setting "_BESClient_Download_DownloadsCacheLimitMB"="4096" on "{now}" for client
setting "_BESClient_Download_NormalStageDiskLimitMB"="8192" on "{now}" for client
setting "_BESClient_Download_PreCacheStageDiskLimitMB"="8192" on "{now}" for client
setting "_BESClient_Resource_AccelerateForPendingMessage"="1" on "{now}" for client
endif
// Sets the discovery date property
setting "Discovery Date"="{minimum of subscribe times of sites}" on "{now}" for client
// Tattoo the settings with the Network Signature
setting "_BESClient_NetSignature"="{unique value of concatenations ";" of (it as string) whose(it != "127.0.0.1" and it does not start with "169.") of addresses of ip interfaces of network as string}" on "{now}" for client
// Set the failover relay setting to the DMZ address
setting "_BESClient_RelaySelect_FailoverRelay"="{parameter "__DMZ_RELAY"}" on "{now}" for client
// Force client to post updated results
Notify Client ForceRefresh]]></ActionScript>
<SuccessCriteria Option="CustomRelevance">exit code of action != 0</SuccessCriteria>
</DefaultAction>
</Task>
</BES>