-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathIPSubnetInfo - Global - BES Infra - Default Settings.bes
141 lines (125 loc) · 22.4 KB
/
IPSubnetInfo - Global - BES Infra - Default Settings.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
<?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 | BES Infra | Default Settings</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 settings for ALL BES infrastructure endpoints managed by BigFix on the <STRONG><EM><FONT color=#ff0000><<<PUT_CLIENT_NAME_HERE>>></FONT></EM></STRONG> network.</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>(exists relay service) AND (not exists main gather service)</Relevance>
<Relevance>(not exists setting "__RelaySelect_Automatic" whose (value of it = "0") of client)</Relevance>
<Relevance>(not exists setting "__RelayServer1" whose (value of it = "http://BESRELAY_FDQN-GOES-HERE:52311/bfmirror/downloads/") of client)</Relevance>
<Relevance>(not exists setting "__RelayServer2" whose (value of it = "http://BESRELAY_FDQN-GOES-HERE:52311/bfmirror/downloads/") 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, BES Infra, Default Settings</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:07:50 +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 :: IPSubnetInfo | Global | BES Infra | 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
// 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 AdvertisementList using the IPSubnetInfo CSV file query
// *** ************************************************** ***
// *** Please make sure to remove the * at the end of the ***
// *** AdvertisementList to remove the wild card option. ***
// *** ************************************************** ***
setting "_BESRelay_Register_Affiliation_AdvertisementList"="{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 AdvertisementList using the AD-Site client property
setting "_BESRelay_Register_Affiliation_AdvertisementList"="*" on "{now}" for client
endif
// Set agents to use automatic relay selection
setting "__RelaySelect_Automatic"="0" on "{now}" for client
// Set manual relay affiliation
// *** ********************************************************************** ***
// *** MAKE SURE TO UPDATE THE BESRELAY-FDQN-GOES-HERE WITH CORRECT VALUES ***
// *** ********************************************************************** ***
setting "__RelayServer1"="http://BESRELAY_FDQN-GOES-HERE:29450/bfmirror/downloads/" on "{now}" for client
setting "__RelayServer2"="http://BESRELAY_FDQN-GOES-HERE:29450/bfmirror/downloads/" on "{now}" for client
// Force client to register with relay
relay select
// 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
// Set the SeekList using the client property
setting "_BESRelay_Register_Affiliation_AdvertisementList"="{parameter "__IPSubnet_SiteID" & "," & parameter "__IPSubnet_Country" & "," & parameter "__IPSubnet_Region" & ",*"}" on "{now}" for client
// Set the failover relay setting to the DMZ address
setting "_BESClient_RelaySelect_FailoverRelay"="{parameter "__DMZ_RELAY"}" 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
// Sets the discovery date property
setting "Discovery Date"="{minimum of subscribe times of sites}" 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>