<?xml version="1.0" encoding="UTF-8"?><unload unload_date="2019-04-15 18:05:44">
<sys_remote_update_set action="INSERT_OR_UPDATE">
<application display_value="Global">global</application>
<application_name>Global</application_name>
<application_scope>global</application_scope>
<application_version/>
<collisions/>
<commit_date/>
<deleted/>
<description>http://smartersets.snc.guru/</description>
<inserted/>
<name>SNG-Smarter Update Sets-v1.3</name>
<origin_sys_id/>
<parent display_value=""/>
<release_date/>
<remote_base_update_set display_value=""/>
<remote_parent_id/>
<remote_sys_id>d984124b3733a70090b68cf6c3990e57</remote_sys_id>
<state>loaded</state>
<summary/>
<sys_class_name>sys_remote_update_set</sys_class_name>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>ab5313863770f30090b68cf6c3990e2f</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<update_set display_value=""/>
<update_source display_value=""/>
<updated/>
</sys_remote_update_set>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_29e55b5537c0770090b68cf6c3990e06</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Protect Default Update Set Fields&lt;/strong&gt;&lt;br /&gt;&#13;
Set this to a comma-delimited string containing a list of fields to be protected on the "Default" Update Set. &lt;br /&gt;&#13;
&lt;i&gt;&lt;strong&gt;Note&lt;/strong&gt;: This property only applies if "sng.update_sets.protect_default_set_fields" is set to &lt;strong&gt;true&lt;/strong&gt;&lt;/i&gt;&lt;br /&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: name,state,parent,release_date,completed_by</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>sng.update_sets.protect_default_set_fields</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-07 03:34:15</sys_created_on><sys_id>29e55b5537c0770090b68cf6c3990e06</sys_id><sys_mod_count>2</sys_mod_count><sys_name>sng.update_sets.protect_default_set_fields</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_29e55b5537c0770090b68cf6c3990e06</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-07 03:40:16</sys_updated_on><type>string</type><value>name,state,parent,release_date,completed_by</value><write_roles>admin</write_roles></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=29e55b5537c0770090b68cf6c3990e06"/></record_update>]]></payload>
<payload_hash>1046007205</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>235313863770f30090b68cf6c3990e31</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169563cc9e70000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.protect_default_set_fields</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>524753d534c07700a2479e97fbc2cdf2</update_guid>
<update_guid_history>524753d534c07700a2479e97fbc2cdf2:1046007205,9b561b553fc0770039c625b1eae984e6:1134617003,02e55b5515c07700cca73f220462160a:-1651128932</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_460d03ce3730f30090b68cf6c3990e4e</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>1000</order><property display_value="alert_on_default_set.exclude_tables" name="alert_on_default_set.exclude_tables">5f4d7b293781ab0090b68cf6c3990e20</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-04-15 17:38:02</sys_created_on><sys_id>460d03ce3730f30090b68cf6c3990e4e</sys_id><sys_mod_count>1</sys_mod_count><sys_name>alert_on_default_set.exclude_tables.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_460d03ce3730f30090b68cf6c3990e4e</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:38:36</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>1337099854</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>23535fc63770f30090b68cf6c3990e28</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a221449f10000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.exclude_tables.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>9e2d43ce2a30f3004e9fe650ba4aa4a2</update_guid>
<update_guid_history>9e2d43ce2a30f3004e9fe650ba4aa4a2:1337099854,0e0d03ce5630f3000d964173fed6d14f:-1731390758</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_script_client_ff3da111378c370090b68cf6c3990ef6</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update sys_domain="global" table="sys_script_client"&gt;&lt;sys_script_client action="INSERT_OR_UPDATE"&gt;&lt;active&gt;true&lt;/active&gt;&lt;applies_extended&gt;false&lt;/applies_extended&gt;&lt;condition/&gt;&lt;description&gt;Relies on "Set Scratchpad - Smarter Update Sets" display Business Rule getting value of the sng.update_sets.warn_on_duplicate_name system property.&amp;#13;
If the sng.update_sets.warn_on_duplicate_name system property is set to true, then when the name field changes, if there is another Update Set with the same name that the user has chosen, alert the user to the name collision. &amp;#13;
This also applies on load, but not if the field is blank. &lt;/description&gt;&lt;field&gt;name&lt;/field&gt;&lt;global&gt;true&lt;/global&gt;&lt;isolate_script&gt;true&lt;/isolate_script&gt;&lt;messages/&gt;&lt;name&gt;Warn on duplicate Update Set name&lt;/name&gt;&lt;order/&gt;&lt;script&gt;&lt;![CDATA[function onChange(control, oldValue, newValue, isLoading, isTemplate) {
	var warnOnDuplicateName = (g_scratchpad.update_set_properties['sng.update_sets.warn_on_duplicate_name'].toString() == 'true');
	
	//If the system property that controls this functionality is set to false or not found, stop here.
	if (!warnOnDuplicateName) {
		return;
	}
	
	//If the name field is blank, show no message and leave it alone. 
	if (newValue === '') {
		g_form.hideFieldMsg('name', true);
		return;
	}
	
	//If the name is "Default" and we're not on the new record form, show no messages and leave it alone
	if (newValue == 'Default' &amp;&amp; !g_form.isNewRecord()) {
		g_form.hideFieldMsg('name', true);
		return;
	}
	
	var setID = g_form.getUniqueValue();
	var setName = g_form.getValue('name');
	var setScope = g_form.getValue('sys_scope');
	
	var grUpdateSet = new GlideRecord('sys_update_set');
	
	grUpdateSet.addQuery('sys_id', '!=', setID); //This set is not a duplicate of itself
	grUpdateSet.addQuery('name', setName);
	grUpdateSet.addQuery('sys_scope', setScope);
	grUpdateSet.setLimit(1);
	
	grUpdateSet.query(cbCheckDuplicateSetName);
}

function cbCheckDuplicateSetName(grUpdateSet) {
	g_form.hideFieldMsg('name', true);
	
	if (!grUpdateSet.next()) {
		//No duplicate Update Set name, so halt here
		return;
	}
	
	g_form.showFieldMsg('name', 'There is already an Update Set with this name. Please choose another name.', 'error');
}]]&gt;&lt;/script&gt;&lt;sys_class_name&gt;sys_script_client&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2019-03-06 20:36:56&lt;/sys_created_on&gt;&lt;sys_domain&gt;global&lt;/sys_domain&gt;&lt;sys_domain_path&gt;/&lt;/sys_domain_path&gt;&lt;sys_id&gt;ff3da111378c370090b68cf6c3990ef6&lt;/sys_id&gt;&lt;sys_mod_count&gt;3&lt;/sys_mod_count&gt;&lt;sys_name&gt;Warn on duplicate Update Set name&lt;/sys_name&gt;&lt;sys_overrides/&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_script_client_ff3da111378c370090b68cf6c3990ef6&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-03-06 20:49:19&lt;/sys_updated_on&gt;&lt;table&gt;sys_update_set&lt;/table&gt;&lt;type&gt;onChange&lt;/type&gt;&lt;ui_type&gt;10&lt;/ui_type&gt;&lt;view/&gt;&lt;/sys_script_client&gt;&lt;/record_update&gt;</payload>
<payload_hash>-726046227</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>23535fc63770f30090b68cf6c3990e2b</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16954c4864a0000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table>sys_update_set</table>
<target_name>Warn on duplicate Update Set name</target_name>
<type>Client Script</type>
<update_domain>global</update_domain>
<update_guid>4a39bd595f8c3700949e93406cbb4cf5</update_guid>
<update_guid_history>4a39bd595f8c3700949e93406cbb4cf5:-726046227,2717b5d5c48c3700efb534819f66765b:-2126548167,18e6b1d5e08c370038e91fb5c08d4cb4:-211006851,ec667ddd004c3700461582b41adbbac7:1229414601</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>DELETE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_0ec3c0793781ab0090b68cf6c3990ed9</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="DELETE"><category display_value="Default Update Set Alerts">47b3c83d3781ab0090b68cf6c3990e4e</category><order>1</order><property display_value="alert_on_default_set.exclude_tables" name="alert_on_default_set.exclude_tables">5f4d7b293781ab0090b68cf6c3990e20</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2018-10-09 22:24:49</sys_created_on><sys_id>0ec3c0793781ab0090b68cf6c3990ed9</sys_id><sys_mod_count>0</sys_mod_count><sys_name>alert_on_default_set.exclusion_filter.Update Set Properties</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_0ec3c0793781ab0090b68cf6c3990ed9</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2018-10-09 22:24:49</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>-1310760894</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>27535fc63770f30090b68cf6c3990e27</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a2213c6860000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.exclusion_filter.Update Set Properties</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>ce0d03ce6f30f3000587b5a93cc3f052</update_guid>
<update_guid_history>ce0d03ce6f30f3000587b5a93cc3f052:-1310760894,06c3c079b281ab00e99242de3e6eefdb:-1720517327</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_script_06a933a53781ab0090b68cf6c3990ed4</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update sys_domain="global" table="sys_script"&gt;&lt;sys_script action="INSERT_OR_UPDATE"&gt;&lt;abort_action&gt;false&lt;/abort_action&gt;&lt;access&gt;package_private&lt;/access&gt;&lt;action_delete&gt;true&lt;/action_delete&gt;&lt;action_insert&gt;true&lt;/action_insert&gt;&lt;action_query&gt;false&lt;/action_query&gt;&lt;action_update&gt;true&lt;/action_update&gt;&lt;active&gt;true&lt;/active&gt;&lt;add_message&gt;false&lt;/add_message&gt;&lt;advanced&gt;true&lt;/advanced&gt;&lt;change_fields&gt;false&lt;/change_fields&gt;&lt;client_callable&gt;false&lt;/client_callable&gt;&lt;collection&gt;sys_metadata&lt;/collection&gt;&lt;condition&gt;(gs.getProperty('alert_on_default_set.enable', 'false') == 'true') &amp;amp;&amp;amp; new UpdateSetUtils().default_set.alertRequired(current)&lt;/condition&gt;&lt;description/&gt;&lt;execute_function&gt;false&lt;/execute_function&gt;&lt;filter_condition/&gt;&lt;is_rest&gt;false&lt;/is_rest&gt;&lt;message&gt;&lt;![CDATA[&lt;p&gt;test&lt;/p&gt;]]&gt;&lt;/message&gt;&lt;name&gt;Warn on change in default set&lt;/name&gt;&lt;order&gt;100&lt;/order&gt;&lt;priority&gt;100&lt;/priority&gt;&lt;rest_method/&gt;&lt;rest_method_text/&gt;&lt;rest_service/&gt;&lt;rest_service_text/&gt;&lt;rest_variables/&gt;&lt;role_conditions/&gt;&lt;script&gt;&lt;![CDATA[(function executeRule(current, previous /*null when async*/) {
	
	gs.addErrorMessage('Whoa there! You\'ve just updated &lt;a href="' + current.getLink() + '" target="_blank"&gt;this record&lt;/a&gt; in the &lt;b&gt;default&lt;/b&gt; update set! Was that on purpose?');
	
})(current, previous);
]]&gt;&lt;/script&gt;&lt;sys_class_name&gt;sys_script&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2018-10-09 22:54:07&lt;/sys_created_on&gt;&lt;sys_domain&gt;global&lt;/sys_domain&gt;&lt;sys_domain_path&gt;/&lt;/sys_domain_path&gt;&lt;sys_id&gt;06a933a53781ab0090b68cf6c3990ed4&lt;/sys_id&gt;&lt;sys_mod_count&gt;40&lt;/sys_mod_count&gt;&lt;sys_name&gt;Warn on change in default set&lt;/sys_name&gt;&lt;sys_overrides/&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_script_06a933a53781ab0090b68cf6c3990ed4&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-04-15 18:05:30&lt;/sys_updated_on&gt;&lt;template/&gt;&lt;when&gt;before&lt;/when&gt;&lt;/sys_script&gt;&lt;sys_translated_text action="delete_multiple" query="documentkey=06a933a53781ab0090b68cf6c3990ed4"/&gt;&lt;/record_update&gt;</payload>
<payload_hash>-43873168</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>27535fc63770f30090b68cf6c3990e2a</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a222cec760000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table>sys_metadata</table>
<target_name>Warn on change in default set</target_name>
<type>Business Rule</type>
<update_domain>global</update_domain>
<update_guid>50539b86a070f300e4d2f42530259e79</update_guid>
<update_guid_history>50539b86a070f300e4d2f42530259e79:-43873168,774c0f4e2630f30080d11792c6f6c51f:844306040,a98bc74e4a30f300be12911109ee5650:-766946972,adfe910ac4cdab00a3777e225d16f352:43186216,e6ee510a69cdab00e376768990ea838e:-1051566210,99deddc687cdab00cd49a9f191f84161:-1502179049,79fdd1c656cdab002c7fcb1b7f1c5089:-1947867849,37cb5d4662cdab00dfe44444be9c116c:-1960225141,82fa190679cdab0017291ad854516b69:-1502179049,32da91463dcdab003da86168471d7255:-1947867849,ae4a590662cdab0083eced617e27945b:43186216,cfa9d106dacdab00fdf38ad2fd42d6ce:1981435169,e07999c29bcdab00ecfd6ac7e1f78a9c:-1949984757,dbe895c252cdab00e33b0569f9f19a33:1314495340,54e7d9823acdab00e292818abfc9a837:-1949984757,6b18c90ab68dab0024e2a099a23343e2:-224878325,ccf9f802968dab00be121cff517aa5e4:-281360716,4d593802cc8dab0071e079833232f6d5:-1713652350,28e878ce384dab002969cd0b4f73378b:-281360716,a92b0482850dab00cf2b58f6185fdaeb:1144712187,01a73bf51ac9ab009a46881b88f10d93:-52067281,48e01875e8c1ab00bd2efbd8c000d6ad:832044951,6cdf8c35f2c1ab009775b2903bef385f:94815229,4bcf8435f7c1ab00feb4fd732023884e:989810735,e67f4835b9c1ab00e954008e597ca7be:-632400166,f47f8435d2c1ab0002b84861a94c83e3:1687510220,4f6fc035b5c1ab005ed44ccec39df1b8:-632400166,556f4835f3c1ab00142fe98c4bc3dcb6:1687510220,c13f403506c1ab002916242520f094e0:-784584993,4b2f443524c1ab001bb84bb81e16fad8:-1332178515,44ce403579c1ab009fa5d84eec38d05e:-632400166,e9beccb1b2c1ab00a63c77c01aba6807:1687510220,2cdcccb137c1ab00727d910841b9b954:-2006601855,5b0cc4b125c1ab002cdda6bf360cf8da:1879954127,f0db80b1b1c1ab0086d4639e3713cd18:-2006601855,b2cbc0b174c1ab000edbfdfd149e42dd:1879954127,9cab0871a6c1ab0042b8fc1604a628e7:904594500,d5bac4710fc1ab00819e199382aa73ee:2009222533,6f9a84711dc1ab00de7b91fe4e2986d6:-239368528,c09a8471eec1ab00a35e4f8ec21370cf:-30450114,5b7a4c7d1f81ab00f7aa75b73d8ccdd3:-239368528</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_a84a8991370c370090b68cf6c3990e98</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Prevent Closing Mixed-Scope Update Sets&lt;/strong&gt;&lt;br /&gt;&#13;
If true, this will prevent anyone from closing an Update Set that contains updates in multiple scopes, which could not be deployed in another environment. &lt;br /&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: true</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>sng.update_sets.prevent_mixed_scope_sets</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 17:26:37</sys_created_on><sys_id>a84a8991370c370090b68cf6c3990e98</sys_id><sys_mod_count>7</sys_mod_count><sys_name>sng.update_sets.prevent_mixed_scope_sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_a84a8991370c370090b68cf6c3990e98</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:56:45</sys_updated_on><type>boolean</type><value>true</value><write_roles>admin</write_roles></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=a84a8991370c370090b68cf6c3990e98"/></record_update>]]></payload>
<payload_hash>-1380503012</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>2b535fc63770f30090b68cf6c3990e26</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a2224eda40000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.prevent_mixed_scope_sets</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>60515346b770f3008a87d189657bc989</update_guid>
<update_guid_history>60515346b770f3008a87d189657bc989:-1380503012,42311b062a70f300682bc1d28d9b790b:499091869,505b659d1e4c37006a23f36213d69bb3:-1380503012,58a36dd52b4c370090a4d5f70137d76f:-1219993200,628b0dd1eb0c370031887dd9fcd97dcf:-1731418024,f96b81d11d0c370085e90c58dc6ed490:-2046367482,886bc9d1dd0c370080d0c52b0b8e2a18:-1018382050,c5da41d1e20c3700f83cce1dd5df7eb6:-2046367482</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>DELETE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_cdef00c6370dab0090b68cf6c3990ea5</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="DELETE"><category display_value="Default Update Set Alerts">47b3c83d3781ab0090b68cf6c3990e4e</category><order>100</order><property display_value="alert_on_default_set.determine_default_by" name="alert_on_default_set.determine_default_by">761e8c06370dab0090b68cf6c3990ece</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2018-10-10 17:56:13</sys_created_on><sys_id>cdef00c6370dab0090b68cf6c3990ea5</sys_id><sys_mod_count>0</sys_mod_count><sys_name>alert_on_default_set.determine_default_by.Update Set Properties</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_cdef00c6370dab0090b68cf6c3990ea5</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2018-10-10 17:56:13</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>1672837258</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>2b535fc63770f30090b68cf6c3990e29</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a22135def0000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.determine_default_by.Update Set Properties</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>67ec8f8e4730f3000267d60633ea6d8e</update_guid>
<update_guid_history>67ec8f8e4730f3000267d60633ea6d8e:1672837258,49ef00c6440dab0013e3f64acd3bd6a7:1451704089</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_a9fc8f8e3730f30090b68cf6c3990ea1</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>800</order><property display_value="alert_on_default_set.alert_on_scoped_default" name="alert_on_default_set.alert_on_scoped_default">036010c6370dab0090b68cf6c3990ee3</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-04-15 17:37:44</sys_created_on><sys_id>a9fc8f8e3730f30090b68cf6c3990ea1</sys_id><sys_mod_count>1</sys_mod_count><sys_name>alert_on_default_set.alert_on_scoped_default.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_a9fc8f8e3730f30090b68cf6c3990ea1</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:38:29</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>1188893513</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>2f535fc63770f30090b68cf6c3990e28</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a221430f70000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.alert_on_scoped_default.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>fc2d8f8e8430f30001cf880e112e43ac</update_guid>
<update_guid_history>fc2d8f8e8430f30001cf880e112e43ac:1188893513,61fc8f8e2230f300b26e8eb642ea16a3:-1567609534</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_0bcbc515370c370090b68cf6c3990eff</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>100</order><property display_value="sng.update_sets.prevent_mixed_scope_sets" name="sng.update_sets.prevent_mixed_scope_sets">a84a8991370c370090b68cf6c3990e98</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 17:30:52</sys_created_on><sys_id>0bcbc515370c370090b68cf6c3990eff</sys_id><sys_mod_count>2</sys_mod_count><sys_name>sng.update_sets.prevent_mixed_scope_sets.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_0bcbc515370c370090b68cf6c3990eff</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-06 23:03:59</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>471303801</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>63535fc63770f30090b68cf6c3990e27</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169553fd1350000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.prevent_mixed_scope_sets.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>2208d655be007700877e1fb0aa20445e</update_guid>
<update_guid_history>2208d655be007700877e1fb0aa20445e:471303801,bfc7dadd65cc3700d72e1d09656ccd2b:-1848955387,03cb0915130c3700b134ad1f23061501:847144185</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_script_05a0a155374c370090b68cf6c3990eb0</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update sys_domain="global" table="sys_script"&gt;&lt;sys_script action="INSERT_OR_UPDATE"&gt;&lt;abort_action&gt;false&lt;/abort_action&gt;&lt;access&gt;package_private&lt;/access&gt;&lt;action_delete&gt;false&lt;/action_delete&gt;&lt;action_insert&gt;false&lt;/action_insert&gt;&lt;action_query&gt;false&lt;/action_query&gt;&lt;action_update&gt;false&lt;/action_update&gt;&lt;active&gt;true&lt;/active&gt;&lt;add_message&gt;false&lt;/add_message&gt;&lt;advanced&gt;true&lt;/advanced&gt;&lt;change_fields&gt;false&lt;/change_fields&gt;&lt;client_callable&gt;false&lt;/client_callable&gt;&lt;collection&gt;sys_update_set&lt;/collection&gt;&lt;condition/&gt;&lt;description/&gt;&lt;execute_function&gt;false&lt;/execute_function&gt;&lt;filter_condition/&gt;&lt;is_rest&gt;false&lt;/is_rest&gt;&lt;message/&gt;&lt;name&gt;Set Scratchpad - Smarter Update Sets&lt;/name&gt;&lt;order&gt;100&lt;/order&gt;&lt;priority&gt;100&lt;/priority&gt;&lt;rest_method/&gt;&lt;rest_method_text/&gt;&lt;rest_service/&gt;&lt;rest_service_text/&gt;&lt;rest_variables/&gt;&lt;role_conditions/&gt;&lt;script&gt;&lt;![CDATA[(function executeRule(current, previous /*null when async*/) {
	
	var i, prop, sysProperties = [
		'sng.update_sets.warn_on_duplicate_name',
		'sng.update_sets.protect_default_set',
		'sng.update_sets.protect_default_set_fields'
	];
	g_scratchpad.update_set_properties = {};
	
	for (i = 0; i &lt; sysProperties.length; i++) {
		prop = sysProperties[i];
		g_scratchpad.update_set_properties[prop] = gs.getProperty(prop, true);
	}
	
	g_scratchpad.is_default = current.getValue('is_default') == true;
	
})(current, previous);]]&gt;&lt;/script&gt;&lt;sys_class_name&gt;sys_script&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2019-03-06 19:55:05&lt;/sys_created_on&gt;&lt;sys_domain&gt;global&lt;/sys_domain&gt;&lt;sys_domain_path&gt;/&lt;/sys_domain_path&gt;&lt;sys_id&gt;05a0a155374c370090b68cf6c3990eb0&lt;/sys_id&gt;&lt;sys_mod_count&gt;3&lt;/sys_mod_count&gt;&lt;sys_name&gt;Set Scratchpad - Smarter Update Sets&lt;/sys_name&gt;&lt;sys_overrides/&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_script_05a0a155374c370090b68cf6c3990eb0&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-03-07 04:07:03&lt;/sys_updated_on&gt;&lt;template/&gt;&lt;when&gt;before_display&lt;/when&gt;&lt;/sys_script&gt;&lt;sys_translated_text action="delete_multiple" query="documentkey=05a0a155374c370090b68cf6c3990eb0"/&gt;&lt;/record_update&gt;</payload>
<payload_hash>1654464958</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>63535fc63770f30090b68cf6c3990e2a</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16956554a480000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table>sys_update_set</table>
<target_name>Set Scratchpad - Smarter Update Sets</target_name>
<type>Business Rule</type>
<update_domain>global</update_domain>
<update_guid>1e6d9b99e0c0770062dfbc3f9645efc7</update_guid>
<update_guid_history>1e6d9b99e0c0770062dfbc3f9645efc7:1654464958,20885fd528c0770034709c187f590ca0:1375108076,98d6db553ac077006505e0c432442ef9:-1386650536,efcca19d764c37005e041af65325ac07:2096512586</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_761e8c06370dab0090b68cf6c3990ece</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices>Name,Default set,Both</choices><description>&lt;strong&gt;Determine default by&lt;/strong&gt;&lt;br/&gt;&#13;
How should it be determined whether the selected update set is the default?&lt;br/&gt;&#13;
&lt;ul&gt;&#13;
	&lt;li&gt;&lt;b&gt;Name&lt;/b&gt;: When the update set name &lt;i&gt;begins with&lt;/i&gt; &lt;b&gt;"Default"&lt;/b&gt;&lt;/li&gt;&#13;
	&lt;li&gt;&lt;b&gt;Default set&lt;/b&gt;: When the update set's &lt;b&gt;Default set [is_default]&lt;/b&gt; field if set to &lt;b&gt;true&lt;/b&gt;.&lt;/li&gt;&#13;
	&lt;li&gt;&lt;b&gt;Both&lt;/b&gt;: When either the update set name begins with &lt;b&gt;"Default"&lt;/b&gt;, or the &lt;b&gt;Default set [is_default]&lt;/b&gt;&#13;
		field is set to true.&lt;/li&gt;&#13;
&lt;/ul&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: Both&#13;
</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>alert_on_default_set.determine_default_by</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2018-10-10 17:48:24</sys_created_on><sys_id>761e8c06370dab0090b68cf6c3990ece</sys_id><sys_mod_count>6</sys_mod_count><sys_name>alert_on_default_set.determine_default_by</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_761e8c06370dab0090b68cf6c3990ece</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:46:42</sys_updated_on><type>choicelist</type><value>Both</value><write_roles/></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=761e8c06370dab0090b68cf6c3990ece"/></record_update>]]></payload>
<payload_hash>1688940405</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>67535fc63770f30090b68cf6c3990e26</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a221bb9a70000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.determine_default_by</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>950f8b42a770f30079d77953e50e4302</update_guid>
<update_guid_history>950f8b42a770f30079d77953e50e4302:1688940405,c7bd8bceb930f3006d181f5437e41344:1978577816,7158814ab38dab00dc34d38faa34029d:-1749279377,ae50d4c68d0dab00800aa433e831026c:580296637,583090c6490dab00a39f5568ef4f970f:1769970450,38df8c865c0dab00d00115c80af66c6e:629005216,471e0846d60dab009390a9e6d61d9fce:372792130</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_c0b113863770f30090b68cf6c3990e09</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>750</order><property display_value="alert_on_default_set.enable" name="alert_on_default_set.enable">0e919b463770f30090b68cf6c3990ee6</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-04-15 17:58:23</sys_created_on><sys_id>c0b113863770f30090b68cf6c3990e09</sys_id><sys_mod_count>1</sys_mod_count><sys_name>alert_on_default_set.enable.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_c0b113863770f30090b68cf6c3990e09</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:58:37</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>374574870</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>67535fc63770f30090b68cf6c3990e29</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a22269d360000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.enable.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>67b1db469470f300064ab1c3078ec244</update_guid>
<update_guid_history>67b1db469470f300064ab1c3078ec244:374574870,48b11386a370f30007380a0a1a4e980b:-830986537</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_88e5069537cc370090b68cf6c3990ecf</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>200</order><property display_value="sng.update_sets.prevent_closing_active_wf_sets" name="sng.update_sets.prevent_closing_active_wf_sets">c9750e5537cc370090b68cf6c3990e38</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 21:44:37</sys_created_on><sys_id>88e5069537cc370090b68cf6c3990ecf</sys_id><sys_mod_count>1</sys_mod_count><sys_name>sng.update_sets.prevent_closing_active_wf_sets.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_88e5069537cc370090b68cf6c3990ecf</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-06 23:04:34</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>-1532968567</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>6b535fc63770f30090b68cf6c3990e28</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169554058360000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.prevent_closing_active_wf_sets.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>8f28d655bd00770026cd14763ffc7b61</update_guid>
<update_guid_history>8f28d655bd00770026cd14763ffc7b61:-1532968567,44e506950dcc370053568d34af0623d1:1825283144</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_ui_action_cc37595d370c370090b68cf6c3990ef8</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update sys_domain="global" table="sys_ui_action"&gt;&lt;sys_ui_action action="INSERT_OR_UPDATE"&gt;&lt;action_name&gt;split_into_scopes&lt;/action_name&gt;&lt;active&gt;false&lt;/active&gt;&lt;client&gt;false&lt;/client&gt;&lt;client_script_v2&gt;&lt;![CDATA[function onClick(g_form) {

}]]&gt;&lt;/client_script_v2&gt;&lt;comments/&gt;&lt;condition/&gt;&lt;form_action&gt;true&lt;/form_action&gt;&lt;form_button&gt;false&lt;/form_button&gt;&lt;form_button_v2&gt;false&lt;/form_button_v2&gt;&lt;form_context_menu&gt;false&lt;/form_context_menu&gt;&lt;form_link&gt;true&lt;/form_link&gt;&lt;form_menu_button_v2&gt;false&lt;/form_menu_button_v2&gt;&lt;form_style/&gt;&lt;hint/&gt;&lt;isolate_script&gt;false&lt;/isolate_script&gt;&lt;list_action&gt;false&lt;/list_action&gt;&lt;list_banner_button&gt;false&lt;/list_banner_button&gt;&lt;list_button&gt;false&lt;/list_button&gt;&lt;list_choice&gt;false&lt;/list_choice&gt;&lt;list_context_menu&gt;false&lt;/list_context_menu&gt;&lt;list_link&gt;false&lt;/list_link&gt;&lt;list_save_with_form_button&gt;false&lt;/list_save_with_form_button&gt;&lt;list_style/&gt;&lt;name&gt;Split into scopes&lt;/name&gt;&lt;onclick/&gt;&lt;order&gt;100&lt;/order&gt;&lt;script&gt;&lt;![CDATA[//todo: Build "split" functionality, then activate this BR.]]&gt;&lt;/script&gt;&lt;show_insert&gt;true&lt;/show_insert&gt;&lt;show_multiple_update&gt;false&lt;/show_multiple_update&gt;&lt;show_query&gt;false&lt;/show_query&gt;&lt;show_update&gt;true&lt;/show_update&gt;&lt;sys_class_name&gt;sys_ui_action&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2019-03-06 18:54:43&lt;/sys_created_on&gt;&lt;sys_domain&gt;global&lt;/sys_domain&gt;&lt;sys_domain_path&gt;/&lt;/sys_domain_path&gt;&lt;sys_id&gt;cc37595d370c370090b68cf6c3990ef8&lt;/sys_id&gt;&lt;sys_mod_count&gt;0&lt;/sys_mod_count&gt;&lt;sys_name&gt;Split into scopes&lt;/sys_name&gt;&lt;sys_overrides/&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_ui_action_cc37595d370c370090b68cf6c3990ef8&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-03-06 18:54:43&lt;/sys_updated_on&gt;&lt;table&gt;sys_update_set&lt;/table&gt;&lt;ui11_compatible&gt;true&lt;/ui11_compatible&gt;&lt;ui16_compatible&gt;false&lt;/ui16_compatible&gt;&lt;/sys_ui_action&gt;&lt;/record_update&gt;</payload>
<payload_hash>727598646</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>6b535fc63770f30090b68cf6c3990e2b</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169545b9a390000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table>sys_update_set</table>
<target_name>Split into scopes</target_name>
<type>UI Action</type>
<update_domain>global</update_domain>
<update_guid>93fe9519e40c370036a2f382d7c5266b</update_guid>
<update_guid_history>93fe9519e40c370036a2f382d7c5266b:727598646</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_0e919b463770f30090b68cf6c3990ee6</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Alert on changes in Default Update Set&lt;/strong&gt;&lt;br/&gt;&#13;
Enable or disable the "alert on changes in default update set" functionality. &#13;
&lt;strong&gt;Default&lt;/strong&gt;: true</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>alert_on_default_set.enable</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-04-15 17:57:58</sys_created_on><sys_id>0e919b463770f30090b68cf6c3990ee6</sys_id><sys_mod_count>0</sys_mod_count><sys_name>alert_on_default_set.enable</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_0e919b463770f30090b68cf6c3990ee6</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:57:58</sys_updated_on><type>boolean</type><value>true</value><write_roles/></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=0e919b463770f30090b68cf6c3990ee6"/></record_update>]]></payload>
<payload_hash>1130735900</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>6f5313863770f30090b68cf6c3990e30</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a22260c960000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.enable</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>d291db46e270f3003d790f402c935249</update_guid>
<update_guid_history>d291db46e270f3003d790f402c935249:1130735900</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_37f16595374c370090b68cf6c3990e25</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>400</order><property display_value="sng.update_sets.warn_on_duplicate_name" name="sng.update_sets.warn_on_duplicate_name">02e16155374c370090b68cf6c3990ec5</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 19:07:52</sys_created_on><sys_id>37f16595374c370090b68cf6c3990e25</sys_id><sys_mod_count>1</sys_mod_count><sys_name>sng.update_sets.warn_on_duplicate_name.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_37f16595374c370090b68cf6c3990e25</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-06 23:04:39</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>-2093343550</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>6f535fc63770f30090b68cf6c3990e27</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16955406c6a0000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.warn_on_duplicate_name.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>d0381611cb00770080eda481ae040a7e</update_guid>
<update_guid_history>d0381611cb00770080eda481ae040a7e:-2093343550,3bf16595b74c370019e5a48a9bf33027:1689080831</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_script_client_35e45b1537c0770090b68cf6c3990e23</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update sys_domain="global" table="sys_script_client"&gt;&lt;sys_script_client action="INSERT_OR_UPDATE"&gt;&lt;active&gt;true&lt;/active&gt;&lt;applies_extended&gt;false&lt;/applies_extended&gt;&lt;condition/&gt;&lt;description&gt;Relies on "Set Scratchpad - Smarter Update Sets" display Business Rule getting value of the "sng.update_sets.protect_default_set" and "sng.update_sets.protect_default_set_fields" system properties, and the is_default field. &amp;#13;
If the former property is set to true, then this script will set the fields indicated in the latter property to read-only on the default Update Set.&lt;/description&gt;&lt;field&gt;application&lt;/field&gt;&lt;global&gt;true&lt;/global&gt;&lt;isolate_script&gt;true&lt;/isolate_script&gt;&lt;messages/&gt;&lt;name&gt;Protect Default Update Set&lt;/name&gt;&lt;order/&gt;&lt;script&gt;&lt;![CDATA[function onLoad() {
	
	var i, field;
	var isDefault = g_scratchpad.is_default;
	var protectDefault = g_scratchpad.update_set_properties['sng.update_sets.protect_default_set'].toString() == 'true';
	var protectFields = g_scratchpad.update_set_properties['sng.update_sets.protect_default_set_fields'].toString().split(',');
	
	
	if (!isDefault || !protectDefault || !protectFields || g_form.isNewRecord()) {
		return;
	}
	
	//If the set is default, protection is on, and we have valid fields to protect...
	for (i = 0; i &lt; protectFields.length; i++) {
		field = protectFields[i];
		g_form.setDisabled(field, true);
	}
	
}]]&gt;&lt;/script&gt;&lt;sys_class_name&gt;sys_script_client&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2019-03-07 03:58:09&lt;/sys_created_on&gt;&lt;sys_domain&gt;global&lt;/sys_domain&gt;&lt;sys_domain_path&gt;/&lt;/sys_domain_path&gt;&lt;sys_id&gt;35e45b1537c0770090b68cf6c3990e23&lt;/sys_id&gt;&lt;sys_mod_count&gt;7&lt;/sys_mod_count&gt;&lt;sys_name&gt;Protect Default Update Set&lt;/sys_name&gt;&lt;sys_overrides/&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_script_client_35e45b1537c0770090b68cf6c3990e23&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-03-07 04:08:05&lt;/sys_updated_on&gt;&lt;table&gt;sys_update_set&lt;/table&gt;&lt;type&gt;onLoad&lt;/type&gt;&lt;ui_type&gt;10&lt;/ui_type&gt;&lt;view/&gt;&lt;/sys_script_client&gt;&lt;/record_update&gt;</payload>
<payload_hash>1093809281</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>6f535fc63770f30090b68cf6c3990e2a</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16956563a510000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table>sys_update_set</table>
<target_name>Protect Default Update Set</target_name>
<type>Client Script</type>
<update_domain>global</update_domain>
<update_guid>1daddb1db6c077007fb01d667bfa4024</update_guid>
<update_guid_history>1daddb1db6c077007fb01d667bfa4024:1093809281,369d571d24c07700094457dd69c761e8:-1366436530,1d8d1b1dbcc07700a7d934a05f543c14:1093809281,e1db93d9cdc07700b29b98b744888907:1512619628,ef9b5b99fac07700275c7aaea7bc94fb:737252350,ac9b1f997bc0770076160dfabb94ddd6:-121796917,327b9399bcc0770061e3d5e5f147dda3:2068682529,3f5b5b99a8c07700a20b6530ed555187:1026891342</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_5f4d7b293781ab0090b68cf6c3990e20</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Tables to exclude&lt;/strong&gt;&lt;br/&gt;&#13;
A comma-separated list of the table names to exclude so that changes in these tables will not trigger the alert about an update being made in the default update set.&#13;
&lt;ul&gt;&#13;
&lt;li&gt;For "table name contains..." begin the string with an asterisk (e.g. *licensing)&lt;/li&gt;&#13;
&lt;li&gt;For "table name begins with...", add an asterisk to the end of the string. (e.g. sys_ui_*)&lt;/li&gt;&#13;
&lt;/ul&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: *pa_,*scheduled_data,*discovery,*clone,*sys_filter,*report,*sys_ui,*licensing,*sys_template,*asmt_metric,*sys_export,asmt_metric*,sys_data_source,sys_update_xml*&#13;
</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>alert_on_default_set.exclude_tables</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2018-10-09 21:59:45</sys_created_on><sys_id>5f4d7b293781ab0090b68cf6c3990e20</sys_id><sys_mod_count>20</sys_mod_count><sys_name>alert_on_default_set.exclude_tables</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_5f4d7b293781ab0090b68cf6c3990e20</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:45:07</sys_updated_on><type>string</type><value>*pa_,*scheduled_data,*discovery,*clone,*sys_filter,*report,*sys_ui,*licensing,*sys_template,*asmt_metric,*sys_export,asmt_metric*,sys_data_source*</value><write_roles/></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=5f4d7b293781ab0090b68cf6c3990e20"/></record_update>]]></payload>
<payload_hash>94365435</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>a3535fc63770f30090b68cf6c3990e26</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a221a47490000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.exclude_tables</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>82aecf022170f300254fa2c9f4fa5cf4</update_guid>
<update_guid_history>82aecf022170f300254fa2c9f4fa5cf4:94365435,759e4f029c70f3002e3945f2b9a47d0b:1289233983,e8de19d62f09eb005bcf312e124f9da0:1885589408,43ced5d65609eb003c49bc248e6be2d9:1370986049,2cff194a33cdab0057fd0ac85aa1fe3e:1885589408,5befd54a52cdab00913fb148913fbe69:333779924,7ccf9d0a0ecdab0014c26c713e65ddb5:1885589408,97af114a3acdab00d8d3e2b280671073:-1972651809,169f5d0aaecdab00a5bc83238ab6ea7a:-404256841,096f590a59cdab00bf19b91a6b43b320:-1519760699,e43f550a81cdab000ec7aaf1d9799c70:1885589408,e019d5c24ecdab001d9eb18d272420b2:-1519760699,50e8d9827bcdab00a733be50ae58864e:-404256841,29769542c6cdab00eaa36b1725995d9b:1121773628,7248014ae28dab009b51886e2b141663:1885589408,617e4846780dab00eb6ebb8a74c6f97e:977398702,9f5e0c46280dab0049ce1cd26dacc0cf:-1281141581,5adac482c60dab0042fa598c5cc6841f:-401264106,446737f564c9ab00c3209a704a27c2b9:1476854522,9d3733f520c9ab00c955689e0b55fee6:944120802,89640c7d3181ab00c0da217cfad16a7d:-76243330,79b3483dd881ab00e0b74436c23a006e:1801568178,c72fff659381ab00b63e53f5d562db21:944120802,df0ef3652881ab008c878acadaee9e2e:-983088029</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_bcc51b5537c0770090b68cf6c3990edc</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>600</order><property display_value="sng.update_sets.protect_default_set" name="sng.update_sets.protect_default_set">e3355f1537c0770090b68cf6c3990ee4</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-07 03:33:39</sys_created_on><sys_id>bcc51b5537c0770090b68cf6c3990edc</sys_id><sys_mod_count>1</sys_mod_count><sys_name>sng.update_sets.protect_default_set.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_bcc51b5537c0770090b68cf6c3990edc</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-07 03:36:56</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>242156005</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>a3535fc63770f30090b68cf6c3990e29</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>1695639b6870000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.protect_default_set.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>c9861f55b3c0770033b2e6db120602e1</update_guid>
<update_guid_history>c9861f55b3c0770033b2e6db120602e1:242156005,b0c51b5551c07700c7ab00f41f3515df:-78091062</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_81dae95d374c370090b68cf6c3990e35</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>500</order><property display_value="sng.update_sets.prevent_duplicate_name" name="sng.update_sets.prevent_duplicate_name">2f2a2919374c370090b68cf6c3990ef5</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 19:46:27</sys_created_on><sys_id>81dae95d374c370090b68cf6c3990e35</sys_id><sys_mod_count>1</sys_mod_count><sys_name>sng.update_sets.prevent_duplicate_name.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_81dae95d374c370090b68cf6c3990e35</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-06 23:04:42</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>800888701</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>a7535fc63770f30090b68cf6c3990e28</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169554078560000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.prevent_duplicate_name.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>c938daddc4cc3700791c65b2f49ed008</update_guid>
<update_guid_history>c938daddc4cc3700791c65b2f49ed008:800888701,85dae95d044c37002626ea5b563ff137:1549153913</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_script_include_4024095d37c8370090b68cf6c3990e6f</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update table="sys_script_include"&gt;&lt;sys_script_include action="INSERT_OR_UPDATE"&gt;&lt;access&gt;public&lt;/access&gt;&lt;active&gt;true&lt;/active&gt;&lt;api_name&gt;global.UpdateSetUtils&lt;/api_name&gt;&lt;caller_access/&gt;&lt;client_callable&gt;false&lt;/client_callable&gt;&lt;description/&gt;&lt;name&gt;UpdateSetUtils&lt;/name&gt;&lt;script&gt;&lt;![CDATA[var UpdateSetUtils = Class.create();
UpdateSetUtils.prototype = {
	initialize: function(updateSet) {
		var grCurrent;
		//Get this.current
		if (typeof updateSet == 'undefined') {
			gs.logError('Update Set not provided.', 'UpdateSetUtils SI');
		} else if (typeof updateSet == 'string') {
			grCurrent = new GlideRecord('sys_update_set');
			
			if (!grCurrent.get(updateSet)) {
				this.current = grCurrent;
			} else {
				gs.logError('Invalid Update Set ID provided: ' + updateSet, 'UpdateSetUtils SI');
			}
		} else {
			this.current = updateSet;
		} //end: get this.current
	},
	
	/**
	 * Determine if the indicated Update Set has updates from mixed scopes.
	 * @returns {Boolean}
	 */
	hasMixedScope: function() {
		var scopeCondition;
		var current = this.current;
		var updateSetScope = current.getValue('application'); //either "global" or the scope sys_id
		var setIsGlobal = (updateSetScope.toLowerCase() == 'global');
		
		var grInvalidScopeUpdate = new GlideRecord('sys_update_xml');
		
		//Check for updates that are NOT in the same scope as the set itself
		grInvalidScopeUpdate.addQuery('update_set', current.getValue('sys_id'));
		scopeCondition = grInvalidScopeUpdate.addQuery('application', '!=', updateSetScope);
		
		if (setIsGlobal) {
			//If update set is global, also allow updates with no application scope
			grInvalidScopeUpdate.addQuery('application', '!=', '');
		} else {
			//if set is not global, updates without a scope count as global and will break deploy,
			// so add an 'or' condition to prevent them.
			scopeCondition.addOrCondition('application', '');
		}
		
		grInvalidScopeUpdate.setLimit(1);
		grInvalidScopeUpdate.query();
		
		//If a record is found,
		return grInvalidScopeUpdate.hasNext();
	},
	
	/**
	 * Checks if the current Update Set has checked out workflows, and returns an array of either the workflow names, or strings containing the workflow names, links, and who they're checked out by.
	 * @param {Boolean} [returnWFList=false] Whether to return the list of currently checked-out Workflows, or just a boolean indicating that checked-out workflows exist.
	 * @param {Boolean} [asHTML=false] Whether to return the list of currently checked-out WFs as HTML with links (only applies if returnWFList is true).
	 * @returns {boolean|Array}
	 */
	hasCheckedOutWorkflows: function(returnWFList, asHTML) {
		//Set up default values
		returnWFList = (typeof returnWFList == 'boolean') ? returnWFList : false;
		asHTML = (typeof asHTML == 'boolean') ? asHTML : false;
		
		//init
		var hasCheckedOutWorkflows = false;
		var workflowIDs = getWorkflowsInSet(current);
		var checkedOutWorkflows = getCheckedOutWorkflows(workflowIDs);
		
		//Get a boolean indicating if any workflows in this update set are checked out.
		hasCheckedOutWorkflows = (checkedOutWorkflows.length &gt; 0);
		
		if (hasCheckedOutWorkflows &amp;&amp; returnWFList) {
			return getReturnVal(checkedOutWorkflows, asHTML);
		}
		
		return hasCheckedOutWorkflows;
		
		/*
			Private helper functions below
		*/
		function getWorkflowsInSet(current) {
			var updateName, workflowID;
			var workflowIDs = [];
			var grUpdate = new GlideRecord('sys_update_xml');
			
			grUpdate.addQuery('update_set', current.getValue('sys_id'));
			grUpdate.addQuery('type', 'Workflow');
			grUpdate.query();
			
			while (grUpdate.next()) {
				updateName = grUpdate.getValue('name');
				workflowID = updateName.substring(updateName.lastIndexOf('_') + 1);
				
				workflowIDs.push(workflowID);
			}
			
			return workflowIDs;
		}
		
		/**
		 * Given an array of sys_ids of workflows in the "wf_workflow" table, retrieve an array
		 *  consisting of a sub-set of those workflows which are currently checked out.
		 * If none are found, return a blank array.
		 * @param workflowIDs {Array} - An array of sys_ids of workflows in the "wf_workflow" table.
		 * @returns {CheckedOutWorkflow[]} - An array of "CheckedOutWorkflow" objects corresponding
		 *  to the workflows which are currently checked out. If none are checked out, this will
		 *  return a blank array.
		 */
		function getCheckedOutWorkflows(workflowIDs) {
			var grCheckedOutBy;
			var checkedOutWorkflows = [];
			var grWfVersion = new GlideRecord('wf_workflow_version');
			
			grWfVersion.addQuery('workflow', 'IN', workflowIDs.join(','));
			grWfVersion.addNotNullQuery('checked_out_by');
			grWfVersion.query();
			
			while (grWfVersion.next()) {
				grCheckedOutBy = grWfVersion.checked_out_by.getRefRecord();
				
				checkedOutWorkflows.push(
					new CheckedOutWorkflow(grWfVersion, grCheckedOutBy)
				);
			}
			
			return checkedOutWorkflows;
		}
		
		/**
		 * Generate error message to display to a user with information about the checked out
		 *  workflows, from an array of checked out workflows.
		 * @param checkedOutWorkflows {CheckedOutWorkflow[]} An array of objects with the
		 *  CheckedOutWorkflow prototype, corresponding to one or more workflows which are checked out.
		 *  @param asHTML {Boolean} Whether to return the value as an array of HTML string, or plain-text strings.
		 * @returns {Array} The error message to display to a user with information about the
		 *  checked out workflows.
		 */
		function getReturnVal(checkedOutWorkflows, asHTML) {
			var i, checkedOutWf;
			var msg = [];
			
			for (i = 0; i &lt; checkedOutWorkflows.length; i++) {
				checkedOutWf = checkedOutWorkflows[i];
				if (asHTML) {
					msg.push(
						'&lt;a href="' + checkedOutWf.workflow_version_link + '" target="_blank"&gt;' +
						checkedOutWf.workflow_name + '&lt;/a&gt; checked out by &lt;a href="' +
						checkedOutWf.checked_out_by_link + '" target="_blank"&gt;' +
						checkedOutWf.checked_out_by_name + '&lt;/a&gt;&lt;br /&gt;'
					);
				} else {
					msg.push(checkedOutWf.workflow_name);
				}
			}
			
			return msg;
		}
		
		/**
		 * Constructor for checked out workflow data objects.
		 * @param grWfVersion {GlideRecord} - The *checked out* Workflow version record from wf_workflow_version
		 * @param grCheckedOutBy {GlideRecord} - The User record from the sys_user table
		 * @constructor
		 */
		function CheckedOutWorkflow(grWfVersion, grCheckedOutBy) {
			this.workflow_id = grWfVersion.getValue('workflow');
			this.workflow_name = grWfVersion.getValue('name');
			this.workflow_version_link = grWfVersion.getLink(true);
			this.checked_out_by_name = grCheckedOutBy.getValue('name');
			this.checked_out_by_id = grCheckedOutBy.getValue('sys_id');
			this.checked_out_by_link = grCheckedOutBy.getLink(true);
		}
	},
	
	scope_split: { //Note: this = scope_split
		
		/**
		 *
		 * @param {GlideRecord} grCurrentSet - The Update Set to create the new scoped set from
		 * @param {boolean} [changeToNewSet=true] - Whether to change to the newly created Update Set
		 * @param {boolean} [addSetToScopeBatch=true] - Whether to add the newly created Update Set to a scope batch
		 * @returns {GlideRecord|boolean} The new Update Set (or false if there was an error)
		 */
		createNewScopeSet: function(grCurrentSet, changeToNewSet, addSetToScopeBatch) {
			if (!this.isCurrentScopeDifferentFromSet(grCurrentSet)) {
				gs.addErrorMessage(
					'The grCurrentSet Update Set\'s scope is the same as the selected scope.');
				return false;
			}
			changeToNewSet = (typeof changeToNewSet == 'boolean') ? changeToNewSet : true;
			addSetToScopeBatch = (typeof addSetToScopeBatch == 'boolean') ? addSetToScopeBatch : true;
			
			var newSetName, newScopeName, newUpdateSetID;
			
			var currentUpdateSetName = grCurrentSet.getValue('name');
			
			var grCurrentScope = grCurrentSet.application.getRefRecord();
			var currentScopeName = grCurrentScope.getValue('name');
			var newScopeID = gs.getPreference('apps.current_app', 'global');
			
			var grNewUpdateSet = new GlideRecord('sys_update_set');
			var grNewScope = new GlideRecord('sys_scope');
			
			grNewScope.get(newScopeID);
			
			newScopeName = grNewScope.getValue('name');
			newSetName = this.getNewUpdateSetName(currentUpdateSetName, newScopeName);
			
			grNewUpdateSet.initialize();
			
			grNewUpdateSet.setValue('application', newScopeID);
			grNewUpdateSet.setValue('name', newSetName);
			grNewUpdateSet.setValue('state', 'in progress');
			grNewUpdateSet.setValue('descriptoin',
				'Created in Scope Batch from Update Set ' + grCurrentSet.getValue('name'));
			
			newUpdateSetID = grNewUpdateSet.insert();
			
			if (addSetToScopeBatch) {
				this.addToScopeBatch(grCurrentSet, grNewUpdateSet);
			}
			
			if (changeToNewSet) {
				this.changeUpdateSetTo(newUpdateSetID);
			}
			
			if (typeof action !== 'undefined') {
				action.setRedirect(grNewUpdateSet);
			}
			
			return grNewUpdateSet;
		},
		
		isCurrentScopeDifferentFromSet: function(current) {
			var newScopeID = gs.getPreference('apps.current_app', 'global');
			var currentSetScopeID = current.getValue('application');
			
			if (!newScopeID) {
				newScopeID = 'global';
			}
			if (!currentSetScopeID) {
				currentSetScopeID = 'global';
			}
			
			return !!(newScopeID != currentSetScopeID);
		},
		
		/**
		 * Adds the Update Set in the provided GlideRecord object to a "scope batch".
		 * If it's already in a scope batch, returns the GlideRecord for that batch. If not, creates one and returns *that* GlideRecord.
		 * @param {GlideRecord} grCurrentSet - The current sys_update_set record.
		 * @param {GlideRecord} grNewSet - The GlideRecord for the new scoped Update Set.
		 * @returns {GlideRecord} - A GlideRecord at the u_scope_batch record containing the current and new Update Sets
		 */
		addToScopeBatch: function(grCurrentSet, grNewSet) {
			var currentBatchSets;
			var currentSetID = grCurrentSet.getValue('sys_id');
			var newSetID = grNewSet.getValue('sys_id');
			var grScopeBatch = new GlideRecord('u_scope_batch');
			
			//Validate
			if (grCurrentSet.getTableName() != 'sys_update_set') {
				gs.logError(
					'Unable to create or add to a scope batch. Provided GlideRecord is not for a sys_update_set record.',
					'UpdateSetUtils.scope_split.addToScopeBatch');
				return false;
			}
			
			grScopeBatch.addQuery('u_update_sets', 'CONTAINS', currentSetID);
			grScopeBatch.setLimit(1);
			grScopeBatch.query();
			//If we find a batch that already contains the current set
			if (grScopeBatch.next()) {
				currentBatchSets = grScopeBatch.getValue('u_update_sets').split(',');
				//If the current scope batch already contains the new update set (somehow), just return it.
				if (currentBatchSets.indexOf(newSetID) &gt;= 0) {
					return currentBatchSets;
				}
				//If the scope batch that contains the current set doesn't contain the new set,
				// then add the new set, update the batch, and return it.
				currentBatchSets.push(newSetID);
				grScopeBatch.setValue('u_update_sets', currentBatchSets.join(','));
				grScopeBatch.update();
				return grScopeBatch;
				
			}
			
			//If we didn't find a batch that already contains the current set, create one
			grScopeBatch.initialize();
			grScopeBatch.setValue('u_update_sets', [currentSetID, newSetID].join(','));
			grScopeBatch.insert();
			return grScopeBatch;
		},
		
		/**
		 * Get the new Update Set name, making sure the new name isn't too long. If it is, just truncate it haphazardly.
		 * @param {string} currentSetName - The name of the current Update Set
		 * @param {string} scopeName - The name of the new scope to append to the current set
		 * @returns {string} - The new Update Set name
		 * @private
		 */
		getNewUpdateSetName: function(currentSetName, scopeName) {
			var newName = currentSetName + ' (' + scopeName + ')';
			//Make sure the new name isn't too long. If it is, just truncate it haphazardly.
			if (newName.length &gt; 80) {
				newName = newName.substr(0, 80);
			}
			return newName;
		},
		
		changeUpdateSetTo: function(newSetID) {
			var us = new GlideUpdateSet();
			us.set(newSetID);
		}
	},
	
	default_set: {
		alertRequired: function(current) {
			//init
			var alertOnScopedDefault, excludeTables, determineDefaultBy;
			var returnVal = false, setIsDefault = false, setIsScoped = false, isTableExcluded = false;
			
			var updateSetID = gs.getPreference('sys_update_set', -1);
			var grUpdateSet = new GlideRecord('sys_update_set');
			
			//Get the GlideRecord for the user's currently selected update set
			if (!grUpdateSet.get(updateSetID)) {
				gs.logError('A change to a record in table ' + current.getTableName() +
					' with sys_id ' + current.getValue('sys_id') + ' was made while the ' +
					'user was in an Update Set with sys_id ' + updateSetID + '. However, ' +
					'this update set could not be found in the sys_update_set table.',
					'DefaultUpdateSetUtil.defaultSetSelected method.');
				return false;
			}
			
			//Get property values
			//boolean expression to convert this prop from string to bool
			alertOnScopedDefault =
				(gs.getProperty('alert_on_default_set.alert_on_scoped_default', 'false') == 'true');
			//If we're in a scoped app (anything that isn't rhino.global), and we don't alert on scoped apps, stop here for efficiency.
			if ((gs.getCurrentScopeName() != 'rhino.global') &amp;&amp; !alertOnScopedDefault) {
				return false;
			}
			
			excludeTables = gs.getProperty('alert_on_default_set.exclude_tables',
				'*pa_,*scheduled_data,*discovery,*clone,*sys_filter,*report,*sys_ui,*licensing,*sys_template,*asmt_metric,*sys_export');
			
			//If the table the record is in, is excluded, return false and halt.
			if (this._isExcluded(current.getTableName(), excludeTables)) {
				return false;
			}
			
			determineDefaultBy =
				gs.getProperty('alert_on_default_set.determine_default_by', 'Both');
			setIsDefault = this._defaultSetSelected(grUpdateSet, determineDefaultBy);
			setIsScoped = this._isScoped(grUpdateSet);
			
			if (setIsDefault) {
				if (setIsScoped) {
					return alertOnScopedDefault;
				}
				return true;
			}
			
			//If set is not default, we fall through the conditional above. In this case, just return false.
			return false;
		},
		
		_isScoped: function(grUpdateSet) {
			return (gs.getCurrentScopeName() != 'rhino.global');
		},
		
		_defaultSetSelected: function(grUpdateSet, determineDefaultBy) {
			var updateSetName = grUpdateSet.getValue('name');
			var isDefaultName = updateSetName.indexOf('Default') == 0;
			var isDefaultSet = (grUpdateSet.getValue('is_default') == true);
			
			if (isDefaultName &amp;&amp; (determineDefaultBy == 'Both' || determineDefaultBy == 'Name')) {
				return true;
			}
			if (isDefaultSet &amp;&amp; (determineDefaultBy == 'Both' || determineDefaultBy == 'Default set')) {
				return true;
			}
			
			return false;
		},
		
		
		_isExcluded: function(tableName, exclusionList) {
			var i, exclusion, wildcardIndex;
			exclusionList = exclusionList.split(',');
			
			for (i = 0; i &lt; exclusionList.length; i++) {
				exclusion = exclusionList[i].trim();
				wildcardIndex = exclusion.indexOf('*');
				if (wildcardIndex == -1) { //wildcard not found
					if (tableName == exclusion) {
						return true;
					}
				} else if (wildcardIndex == 0) { //wildcard at beginning
					if (tableName.contains(exclusion.substring(1))) {
						return true;
					}
				} else if (wildcardIndex == (exclusion.length - 1)) { //wildcard at end
					if (tableName.indexOf(exclusion.substring(0, exclusion.length - 1)) == 0) {
						return true;
					}
				} else {
					//wildcard found inside exclusion string, which is not valid
					gs.logWarning('The exclusion string ' + exclusion +
						' seems to contain a wildcard ("*") which is not at the beginning or end. This is not valid, so it has been ignored.',
						'DefaultUpdateSetUtil._isExcluded');
				}
			}
			//If none of the 'if' blocks above fired, then the table is not excluded, so we return false
			return false;
		}
	},
	
	type: 'UpdateSetUtils'
};]]&gt;&lt;/script&gt;&lt;sys_class_name&gt;sys_script_include&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2019-03-06 16:57:36&lt;/sys_created_on&gt;&lt;sys_id&gt;4024095d37c8370090b68cf6c3990e6f&lt;/sys_id&gt;&lt;sys_mod_count&gt;5&lt;/sys_mod_count&gt;&lt;sys_name&gt;UpdateSetUtils&lt;/sys_name&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_script_include_4024095d37c8370090b68cf6c3990e6f&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-04-15 17:34:07&lt;/sys_updated_on&gt;&lt;/sys_script_include&gt;&lt;/record_update&gt;</payload>
<payload_hash>167293502</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>a7535fc63770f30090b68cf6c3990e2b</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a221032600000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>UpdateSetUtils</target_name>
<type>Script Include</type>
<update_domain>global</update_domain>
<update_guid>bc2ccb4e1b30f3004056b304f0bc27bd</update_guid>
<update_guid_history>bc2ccb4e1b30f3004056b304f0bc27bd:167293502,40aa7eb912f0b3003e6fb6067742fb7a:1565741406,e0e8f27962f0b300941e5c516c0eefb3:-619218819,6ae67eb5fdf0b300e442871cccb2a7d5:867554972,d0953ef174f0b300fd4851889f6228f5:2077026420,a724895dbbc8370044024d4aa7843be1:1036220469</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_036010c6370dab0090b68cf6c3990ee3</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Alert on &lt;i&gt;scoped&lt;/i&gt; Default set&lt;/strong&gt;&lt;br/&gt;&#13;
If the Update Set is in a scoped app, should the alert still be shown if it is the default set for that scope?&lt;br/&gt;&#13;
Based on &lt;i&gt;alert_on_default_set.determine_default_by&lt;/i&gt; system property.&lt;br /&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: true</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>alert_on_default_set.alert_on_scoped_default</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2018-10-10 17:58:32</sys_created_on><sys_id>036010c6370dab0090b68cf6c3990ee3</sys_id><sys_mod_count>12</sys_mod_count><sys_name>alert_on_default_set.alert_on_scoped_default</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_036010c6370dab0090b68cf6c3990ee3</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:56:56</sys_updated_on><type>boolean</type><value>true</value><write_roles/></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=036010c6370dab0090b68cf6c3990ee3"/></record_update>]]></payload>
<payload_hash>-2004739947</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>ab5313863770f30090b68cf6c3990e30</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a22251a670000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.alert_on_scoped_default</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>9b519706ae70f300155ab8ece8b2b8ed</update_guid>
<update_guid_history>9b519706ae70f300155ab8ece8b2b8ed:-2004739947,2c219fc2b070f3005f4a5023675850e5:-1313837808,9fe09fc2f470f300fb7de40f0e522c9a:-2004739947,84e01fc21870f300ae9214b6ad801727:933793022,e6d0dbc2d770f300a9fb5f44b2722848:600533969,79c093829e70f300f90abcaf7fed457d:933793022,abde07428c70f300e2bcce503d000a98:600533969,352e07026170f30024a4a7a92322d72b:691503711,260e8bcefb30f300e13ac539789f25e0:1263796007,53ddc3cecf30f3002a1791e78abb4234:2106818781,f7788d0ad38dab0028889b7eba8506da:-179147266,8881540a0d0dab0039534d6be415b334:-1215799509,e76010c6fd0dab0009e024bf26dff3e6:1155432149</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>DELETE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_3451d00a370dab0090b68cf6c3990e8b</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="DELETE"><category display_value="Default Update Set Alerts">47b3c83d3781ab0090b68cf6c3990e4e</category><order>100</order><property display_value="alert_on_default_set.alert_on_scoped_default" name="alert_on_default_set.alert_on_scoped_default">036010c6370dab0090b68cf6c3990ee3</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2018-10-10 18:02:28</sys_created_on><sys_id>3451d00a370dab0090b68cf6c3990e8b</sys_id><sys_mod_count>0</sys_mod_count><sys_name>alert_on_default_set.alert_on_scoped_default.Default Update Set Alerts</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_3451d00a370dab0090b68cf6c3990e8b</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2018-10-10 18:02:28</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>659893202</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>ab535fc63770f30090b68cf6c3990e27</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a22137fba0000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.alert_on_scoped_default.Default Update Set Alerts</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>25fc8f8e4b30f300cd8a5d703c02eaa6</update_guid>
<update_guid_history>25fc8f8e4b30f300cd8a5d703c02eaa6:659893202,3851d00a730dab00a0adbc047251418d:-1172791330</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_script_b927650637022f0090b68cf6c3990e72</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update sys_domain="global" table="sys_script"&gt;&lt;sys_script action="INSERT_OR_UPDATE"&gt;&lt;abort_action&gt;false&lt;/abort_action&gt;&lt;access&gt;package_private&lt;/access&gt;&lt;action_delete&gt;false&lt;/action_delete&gt;&lt;action_insert&gt;false&lt;/action_insert&gt;&lt;action_query&gt;false&lt;/action_query&gt;&lt;action_update&gt;true&lt;/action_update&gt;&lt;active&gt;true&lt;/active&gt;&lt;add_message&gt;false&lt;/add_message&gt;&lt;advanced&gt;true&lt;/advanced&gt;&lt;change_fields&gt;false&lt;/change_fields&gt;&lt;client_callable&gt;false&lt;/client_callable&gt;&lt;collection&gt;sys_update_set&lt;/collection&gt;&lt;condition&gt;gs.getProperty('sng.update_sets.prevent_closing_active_wf_sets', 'true').toString() == 'true'&lt;/condition&gt;&lt;description/&gt;&lt;execute_function&gt;false&lt;/execute_function&gt;&lt;filter_condition table="sys_update_set"&gt;stateCHANGESTOcomplete^EQ&lt;item endquery="false" field="state" goto="false" newquery="false" operator="CHANGESTO" or="false" value="complete"/&gt;&lt;item endquery="true" field="" goto="false" newquery="false" operator="=" or="false" value=""/&gt;&lt;/filter_condition&gt;&lt;is_rest&gt;false&lt;/is_rest&gt;&lt;message/&gt;&lt;name&gt;Prevent Close when WF Checked Out&lt;/name&gt;&lt;order&gt;100&lt;/order&gt;&lt;priority&gt;100&lt;/priority&gt;&lt;rest_method/&gt;&lt;rest_method_text/&gt;&lt;rest_service/&gt;&lt;rest_service_text/&gt;&lt;rest_variables/&gt;&lt;role_conditions/&gt;&lt;script&gt;&lt;![CDATA[(function executeRule(current, previous /*null when async*/) {
	
	var workflowIDs = getWorkflowsInSet(current);
	var checkedOutWorkflows = getCheckedOutWorkflows(workflowIDs);
	
	//If any workflows in this update set are currently checked out...
	if (checkedOutWorkflows.length &gt; 0) {
		/*
			Revert the state and completed_on values to whatever they were previously,
			 but don't prevent the entire update (to prevent losing anything else the
			 developer might have added/changed, such as the description).
		*/
		current.setValue('state', previous.getValue('state'));
		if (current.completed_on.changes()) {
			current.setValue('completed_on', previous.getValue('completed_on'));
		}
		if (current.completed_by.changes()) {
			current.setValue('completed_by', previous.getValue('completed_by'));
		}
		var errorMsg = getErrorMsg(checkedOutWorkflows);
		gs.addErrorMessage(errorMsg);
	} //end: if any workflows in the set are checked out
	
})(current, previous);


function getWorkflowsInSet(current) {
	var updateName, workflowID;
	var workflowIDs = [];
	var grUpdate = new GlideRecord('sys_update_xml');
	
	grUpdate.addQuery('update_set', current.getValue('sys_id'));
	grUpdate.addQuery('type', 'Workflow');
	grUpdate.query();
	
	while (grUpdate.next()) {
		updateName = grUpdate.getValue('name');
		workflowID = updateName.substring(updateName.lastIndexOf('_') + 1);
		
		workflowIDs.push(workflowID);
	}
	
	return workflowIDs;
}

/**
 * Given an array of sys_ids of workflows in the "wf_workflow" table, retrieve an array consisting of a sub-set of those workflows which are currently checked out. If none are found, return a blank array.
 * @param workflowIDs {Array} - An array of sys_ids of workflows in the "wf_workflow" table.
 * @returns {CheckedOutWorkflow[]} - An array of "CheckedOutWorkflow" objects corresponding to the workflows which are currently checked out. If none are checked out, this will return a blank array.
 */
function getCheckedOutWorkflows(workflowIDs) {
	var checkedOutWorkflows = [];
	var grWfVersion = new GlideRecord('wf_workflow_version');
	
	grWfVersion.addQuery('workflow', 'IN', workflowIDs.join(','));
	grWfVersion.addNotNullQuery('checked_out_by');
	grWfVersion.query();
	
	while (grWfVersion.next()) {
		var grCheckedOutBy = grWfVersion.checked_out_by.getRefRecord();
		
		checkedOutWorkflows.push(
			new CheckedOutWorkflow(grWfVersion, grCheckedOutBy)
		);
	}
	
	return checkedOutWorkflows;
}

/**
 * Generate error message to display to a user with information about the checked out workflows, from an array of checked out workflows.
 * @param checkedOutWorkflows {CheckedOutWorkflow[]} An array of objects with the CheckedOutWorkflow prototype, corresponding to one or more workflows which are checked out.
 * @returns {string} The error message to display to a user with information about the checked out workflows.
 */
function getErrorMsg(checkedOutWorkflows) {
	var i, checkedOutWf;
	var msg = 'Update set closure prevented because the following Workflow(s) are currently checked out:&lt;br /&gt;';
	
	for (i = 0; i &lt; checkedOutWorkflows.length; i++) {
		checkedOutWf = checkedOutWorkflows[i];
		
		msg += '- &lt;a href="' + checkedOutWf.workflow_version_link + '" target="_blank"&gt;' +
			checkedOutWf.workflow_name + '&lt;/a&gt; checked out by &lt;a href="' +
			checkedOutWf.checked_out_by_link + '" target="_blank"&gt;' +
			checkedOutWf.checked_out_by_name + '&lt;/a&gt;&lt;br /&gt;';
	}
	
	return msg;
}

/**
 * Constructor for checked out workflow data objects.
 * @param grWfVersion {GlideRecord} - The *checked out* Workflow version record from wf_workflow_version
 * @param grCheckedOutBy {GlideRecord} - The User record from the sys_user table
 * @constructor
 */
function CheckedOutWorkflow(grWfVersion, grCheckedOutBy) {
	this.workflow_id = grWfVersion.getValue('workflow');
	this.workflow_name = grWfVersion.getValue('name');
	this.workflow_version_link = grWfVersion.getLink(true);
	this.checked_out_by_name = grCheckedOutBy.getValue('name');
	this.checked_out_by_id = grCheckedOutBy.getValue('sys_id');
	this.checked_out_by_link = grCheckedOutBy.getLink(true);
}
]]&gt;&lt;/script&gt;&lt;sys_class_name&gt;sys_script&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2018-11-29 17:21:36&lt;/sys_created_on&gt;&lt;sys_domain&gt;global&lt;/sys_domain&gt;&lt;sys_domain_path&gt;/&lt;/sys_domain_path&gt;&lt;sys_id&gt;b927650637022f0090b68cf6c3990e72&lt;/sys_id&gt;&lt;sys_mod_count&gt;16&lt;/sys_mod_count&gt;&lt;sys_name&gt;Prevent Close when WF Checked Out&lt;/sys_name&gt;&lt;sys_overrides/&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_script_b927650637022f0090b68cf6c3990e72&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-03-06 22:21:31&lt;/sys_updated_on&gt;&lt;template/&gt;&lt;when&gt;before&lt;/when&gt;&lt;/sys_script&gt;&lt;sys_translated_text action="delete_multiple" query="documentkey=b927650637022f0090b68cf6c3990e72"/&gt;&lt;/record_update&gt;</payload>
<payload_hash>-1924866066</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>ab535fc63770f30090b68cf6c3990e2a</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>1695518efbf0000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table>sys_update_set</table>
<target_name>Prevent Close when WF Checked Out</target_name>
<type>Business Rule</type>
<update_domain>global</update_domain>
<update_guid>6c5e0695a2cc37002373b938ac4863dc</update_guid>
<update_guid_history>6c5e0695a2cc37002373b938ac4863dc:-1924866066,16958e5527cc37008d670cf6c77abb86:-1809651922,20f1b6c25ec22f00fd7583f506dbc09f:1559295294,20803e4225c22f0029cea9920c99588c:-550960149,ac50be428ec22f001c95f59ca1625a40:-381898403,7fefea423cc22f00940c112b50c3de6c:779916482,1e1fa6421dc22f009af01313bc0aff2b:1052770426,240fe642ffc22f0045213803620dbd1f:491761775,20eeaa0278c22f008038d3cf8d1bb8c2:2080689572,434d2e0ee9822f003958f9b1729a96e9:406912648,6cffa58a51022f0065db1d18f1e98a35:-176794083,42cf6d4aee022f009e8aa13f8a6edb00:1086000634,a71fed4aca022f00e65978b699b267a4:1504412746,f90f6d4a13022f00f85f50a4aff603d5:1355563052,decea94a2a022f005ae557726d3d6473:-447886983,6abead0ae2022f00ebfcc7b8b3527b60:1321989261,5977e906f7022f0058b1c698cdacddc7:409078085</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_4cab4515370c370090b68cf6c3990ed9</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update table="sys_properties_category"&gt;&lt;sys_properties_category action="INSERT_OR_UPDATE"&gt;&lt;name&gt;Smarter Update Sets&lt;/name&gt;&lt;sys_class_name&gt;sys_properties_category&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2019-03-06 17:30:52&lt;/sys_created_on&gt;&lt;sys_id&gt;4cab4515370c370090b68cf6c3990ed9&lt;/sys_id&gt;&lt;sys_mod_count&gt;6&lt;/sys_mod_count&gt;&lt;sys_name&gt;Smarter Update Sets&lt;/sys_name&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_properties_category_4cab4515370c370090b68cf6c3990ed9&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-03-06 17:40:02&lt;/sys_updated_on&gt;&lt;title&gt;&lt;![CDATA[&lt;p&gt;&lt;span style="font-size: 14pt;"&gt;Properties for the &amp;#34;&lt;strong&gt;Smarter Update Sets&lt;/strong&gt;&amp;#34; functionality.&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;span style="font-size: 10pt;"&gt;These properties control certain functionality for Update Sets, provided for free by &lt;a title="SN Pro Tips" href="http://snprotips.com" target="_blank" rel="noopener noreferrer nofollow"&gt;SN Pro Tips&lt;/a&gt;. More info on this functionality in &lt;a title="this article" href="http://smartsets.snc.guru/" target="_blank" rel="noopener noreferrer nofollow"&gt;this article&lt;/a&gt;. Other free tools from SN Pro Tips related to Update Sets, include the &lt;a title="Update Relocator" href="https://snprotips.com/update-relocator" target="_blank" rel="noopener noreferrer nofollow"&gt;Update Relocator&lt;/a&gt;, &lt;a title="Include in Update Set" href="https://snprotips.com/include-in-update-set-tool" target="_blank" rel="noopener noreferrer nofollow"&gt;Include in Update Set&lt;/a&gt;, and several others.&lt;/span&gt;&lt;/p&gt;
&lt;hr /&gt;]]&gt;&lt;/title&gt;&lt;/sys_properties_category&gt;&lt;sys_translated_text action="delete_multiple" query="documentkey=4cab4515370c370090b68cf6c3990ed9"/&gt;&lt;/record_update&gt;</payload>
<payload_hash>1727096545</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>af535fc63770f30090b68cf6c3990e26</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16954173d120000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>Smarter Update Sets</target_name>
<type>System Property Category</type>
<update_domain>global</update_domain>
<update_guid>d1edc555890c370055146a3360f3284b</update_guid>
<update_guid_history>d1edc555890c370055146a3360f3284b:1727096545,f02d8555160c37000e6c5e3c592de507:1990384108,bcecc555900c37006a00fc5492cdf943:1175680359,5fcc8555830c3700baa86adf951be40f:1336344533,57bc45559f0c3700e18dd1703f839dfd:1606158862,6f5c45153b0c37000c0fa56296940e27:-817866322,8bcbc515470c37003ce2a48be32c81fe:-1679941372</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_e3355f1537c0770090b68cf6c3990ee4</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Protect Default Update Set&lt;/strong&gt;&lt;br /&gt;&#13;
If set to true, then the "Default" Update Set will be protected. A list of fields to be protected can be found in the &lt;i&gt;sng.update_sets.protect_default_set_fields&lt;/i&gt; system property.&lt;br /&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: true</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>sng.update_sets.protect_default_set</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-07 03:31:22</sys_created_on><sys_id>e3355f1537c0770090b68cf6c3990ee4</sys_id><sys_mod_count>1</sys_mod_count><sys_name>sng.update_sets.protect_default_set</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_e3355f1537c0770090b68cf6c3990ee4</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-07 03:33:21</sys_updated_on><type>boolean</type><value>true</value><write_roles>admin</write_roles></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=e3355f1537c0770090b68cf6c3990ee4"/></record_update>]]></payload>
<payload_hash>1129756752</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>af535fc63770f30090b68cf6c3990e29</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169563672660000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.protect_default_set</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>74b59f1546c077001e164552493c3a41</update_guid>
<update_guid_history>74b59f1546c077001e164552493c3a41:1129756752,3f355f15f8c0770066d5888efe30ece7:465407277</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_2f2a2919374c370090b68cf6c3990ef5</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Prevent duplicate Update Set name&lt;/strong&gt;&lt;br /&gt;&#13;
If set to true, then whenever an Update Set's "Name" field is updated on the server, a script will run to check whether there are any Update Sets with duplicate names in the same scope. If there are any, the entire update  to the update set record will be aborted.&lt;br /&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: false</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>sng.update_sets.prevent_duplicate_name</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 19:43:37</sys_created_on><sys_id>2f2a2919374c370090b68cf6c3990ef5</sys_id><sys_mod_count>2</sys_mod_count><sys_name>sng.update_sets.prevent_duplicate_name</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_2f2a2919374c370090b68cf6c3990ef5</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-06 19:47:58</sys_updated_on><type>boolean</type><value>false</value><write_roles>admin</write_roles></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=2f2a2919374c370090b68cf6c3990ef5"/></record_update>]]></payload>
<payload_hash>-1794644945</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>e35313863770f30090b68cf6c3990e31</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169548c60210000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.prevent_duplicate_name</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>232ba95d744c3700bf42460c93bc605b</update_guid>
<update_guid_history>232ba95d744c3700bf42460c93bc605b:-1794644945,06ca615dbd4c37006a836fc8877cca05:-1423631749,443a2919344c3700093e203a155b84f9:-293152604</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_5666579537c0770090b68cf6c3990e35</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>700</order><property display_value="sng.update_sets.protect_default_set_fields" name="sng.update_sets.protect_default_set_fields">29e55b5537c0770090b68cf6c3990e06</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-07 03:36:29</sys_created_on><sys_id>5666579537c0770090b68cf6c3990e35</sys_id><sys_mod_count>1</sys_mod_count><sys_name>sng.update_sets.protect_default_set_fields.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_5666579537c0770090b68cf6c3990e35</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-07 03:36:54</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>1317399422</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>e3535fc63770f30090b68cf6c3990e28</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>1695639ad030000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.protect_default_set_fields.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>9086d71555c07700611f6a2fa1e6fbff</update_guid>
<update_guid_history>9086d71555c07700611f6a2fa1e6fbff:1317399422,5a66579571c0770000be762cadab5f37:-542608648</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_script_d1bac71d3780770090b68cf6c3990e7d</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update sys_domain="global" table="sys_script"&gt;&lt;sys_script action="INSERT_OR_UPDATE"&gt;&lt;abort_action&gt;false&lt;/abort_action&gt;&lt;access&gt;package_private&lt;/access&gt;&lt;action_delete&gt;false&lt;/action_delete&gt;&lt;action_insert&gt;true&lt;/action_insert&gt;&lt;action_query&gt;false&lt;/action_query&gt;&lt;action_update&gt;true&lt;/action_update&gt;&lt;active&gt;true&lt;/active&gt;&lt;add_message&gt;false&lt;/add_message&gt;&lt;advanced&gt;true&lt;/advanced&gt;&lt;change_fields&gt;false&lt;/change_fields&gt;&lt;client_callable&gt;false&lt;/client_callable&gt;&lt;collection&gt;sys_update_set&lt;/collection&gt;&lt;condition&gt;gs.getProperty('sng.update_sets.prevent_duplicate_name', 'true').toString() == 'true'&lt;/condition&gt;&lt;description/&gt;&lt;execute_function&gt;false&lt;/execute_function&gt;&lt;filter_condition table="sys_update_set"&gt;nameVALCHANGES^EQ&lt;item endquery="false" field="name" goto="false" newquery="false" operator="VALCHANGES" or="false" value=""/&gt;&lt;item endquery="true" field="" goto="false" newquery="false" operator="=" or="false" value=""/&gt;&lt;/filter_condition&gt;&lt;is_rest&gt;false&lt;/is_rest&gt;&lt;message/&gt;&lt;name&gt;Prevent duplicate Update Set name&lt;/name&gt;&lt;order&gt;100&lt;/order&gt;&lt;priority&gt;100&lt;/priority&gt;&lt;rest_method/&gt;&lt;rest_method_text/&gt;&lt;rest_service/&gt;&lt;rest_service_text/&gt;&lt;rest_variables/&gt;&lt;role_conditions/&gt;&lt;script&gt;&lt;![CDATA[(function executeRule(current, previous /*null when async*/) {
	
	var setID = current.getValue('sys_id');
	var setName = current.getValue('name');
	var setScope = current.getValue('sys_scope');
	
	var grUpdateSet = new GlideRecord('sys_update_set');
	
	grUpdateSet.addQuery('sys_id', '!=', setID);
	grUpdateSet.addQuery('name', setName);
	grUpdateSet.addQuery('sys_scope', setScope);
	grUpdateSet.setLimit(1);
	grUpdateSet.query();
	
	if (grUpdateSet.next()) {
		gs.addErrorMessage('There is already another Update Set with the name "' + current.getValue('name') + '". Aborting update.');
		current.setAbortAction(true);
		if (current.isNewRecord()) {
			gs.setRedirect(grUpdateSet.getLink());
		} else {
			gs.setRedirect(current.getLink());
		}
	} else {
		gs.setRedirect(current);
	}
	
})(current, previous);]]&gt;&lt;/script&gt;&lt;sys_class_name&gt;sys_script&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2019-03-07 02:51:13&lt;/sys_created_on&gt;&lt;sys_domain&gt;global&lt;/sys_domain&gt;&lt;sys_domain_path&gt;/&lt;/sys_domain_path&gt;&lt;sys_id&gt;d1bac71d3780770090b68cf6c3990e7d&lt;/sys_id&gt;&lt;sys_mod_count&gt;0&lt;/sys_mod_count&gt;&lt;sys_name&gt;Prevent duplicate Update Set name&lt;/sys_name&gt;&lt;sys_overrides/&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_script_d1bac71d3780770090b68cf6c3990e7d&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-03-07 02:51:13&lt;/sys_updated_on&gt;&lt;template/&gt;&lt;when&gt;before&lt;/when&gt;&lt;/sys_script&gt;&lt;sys_translated_text action="delete_multiple" query="documentkey=d1bac71d3780770090b68cf6c3990e7d"/&gt;&lt;/record_update&gt;</payload>
<payload_hash>-1597123210</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>e3535fc63770f30090b68cf6c3990e2b</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169560fdab00000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table>sys_update_set</table>
<target_name>Prevent duplicate Update Set name</target_name>
<type>Business Rule</type>
<update_domain>global</update_domain>
<update_guid>db0c4fd969807700c6ba1a21c85d2a3a</update_guid>
<update_guid_history>db0c4fd969807700c6ba1a21c85d2a3a:-1597123210</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_02e16155374c370090b68cf6c3990ec5</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Warn on duplicate Update Set name&lt;/strong&gt;&lt;br /&gt;&#13;
If set to true, then whenever an Update Set's "Name" field is updated client-side, a script will run to check whether there are any Update Sets with duplicate names in the same scope. If there are any, then it'll display a warning. &lt;br /&gt;&#13;
The warning does not prevent the user from saving the Update Set. To prevent duplicate Update Set names within the same scope, ensure that the "&lt;i&gt;sng.update_sets.prevent_duplicate_name&lt;/i&gt;" property is set to &lt;i&gt;true&lt;/i&gt;.&lt;br /&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: true</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>sng.update_sets.warn_on_duplicate_name</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 19:07:28</sys_created_on><sys_id>02e16155374c370090b68cf6c3990ec5</sys_id><sys_mod_count>7</sys_mod_count><sys_name>sng.update_sets.warn_on_duplicate_name</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_02e16155374c370090b68cf6c3990ec5</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:56:51</sys_updated_on><type>boolean</type><value>true</value><write_roles>admin</write_roles></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=02e16155374c370090b68cf6c3990ec5"/></record_update>]]></payload>
<payload_hash>129915928</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>e75313863770f30090b68cf6c3990e30</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a2225052c0000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.warn_on_duplicate_name</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>4251d346f570f300c08ecedd930f6fa4</update_guid>
<update_guid_history>4251d346f570f300c08ecedd930f6fa4:129915928,4d41db068670f3005a2f66fbf9df07dd:-1887212195,f16f43825e70f3007520e9f70e4e0d42:129915928,a35f83423d70f300d2d01c2beefb601a:1208817800,eb1bad5d434c3700866583f7513036de:129915928,5d83a9d51b4c3700187f78e011202b15:-1249081372,f7126595ed4c370096b84bed5109645b:-1895142486,6ae16155594c37002601c062efee98c8:-599744903</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_2fbf02dd37cc370090b68cf6c3990efa</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>300</order><property display_value="sng.update_sets.prevent_reopening_sets" name="sng.update_sets.prevent_reopening_sets">d25f4e1d37cc370090b68cf6c3990ea6</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 22:27:43</sys_created_on><sys_id>2fbf02dd37cc370090b68cf6c3990efa</sys_id><sys_mod_count>2</sys_mod_count><sys_name>sng.update_sets.prevent_reopening_sets.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_2fbf02dd37cc370090b68cf6c3990efa</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-06 23:04:36</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>-1603475897</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>e7535fc63770f30090b68cf6c3990e27</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169554062d40000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.prevent_reopening_sets.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>33285e55aa007700a5c26532becc0da0</update_guid>
<update_guid_history>33285e55aa007700a5c26532becc0da0:-1603475897,4e08d2118100770036dc4e83ba00cfa2:-342667770,23bf02dd63cc370017f62737fda091fd:918140357</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_script_9f340d5d37c8370090b68cf6c3990e43</name>
<payload>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&lt;record_update sys_domain="global" table="sys_script"&gt;&lt;sys_script action="INSERT_OR_UPDATE"&gt;&lt;abort_action&gt;false&lt;/abort_action&gt;&lt;access&gt;package_private&lt;/access&gt;&lt;action_delete&gt;false&lt;/action_delete&gt;&lt;action_insert&gt;false&lt;/action_insert&gt;&lt;action_query&gt;false&lt;/action_query&gt;&lt;action_update&gt;true&lt;/action_update&gt;&lt;active&gt;true&lt;/active&gt;&lt;add_message&gt;false&lt;/add_message&gt;&lt;advanced&gt;true&lt;/advanced&gt;&lt;change_fields&gt;false&lt;/change_fields&gt;&lt;client_callable&gt;false&lt;/client_callable&gt;&lt;collection&gt;sys_update_set&lt;/collection&gt;&lt;condition&gt;gs.getProperty('sng.update_sets.prevent_mixed_scope_sets', 'true').toString() == 'true'&lt;/condition&gt;&lt;description/&gt;&lt;execute_function&gt;false&lt;/execute_function&gt;&lt;filter_condition table="sys_update_set"&gt;stateCHANGESTOcomplete^EQ&lt;item endquery="false" field="state" goto="false" newquery="false" operator="CHANGESTO" or="false" value="complete"/&gt;&lt;item endquery="true" field="" goto="false" newquery="false" operator="=" or="false" value=""/&gt;&lt;/filter_condition&gt;&lt;is_rest&gt;false&lt;/is_rest&gt;&lt;message/&gt;&lt;name&gt;Prevent Mixed-scope Update Set Closure&lt;/name&gt;&lt;order&gt;100&lt;/order&gt;&lt;priority&gt;100&lt;/priority&gt;&lt;rest_method/&gt;&lt;rest_method_text/&gt;&lt;rest_service/&gt;&lt;rest_service_text/&gt;&lt;rest_variables/&gt;&lt;role_conditions/&gt;&lt;script&gt;&lt;![CDATA[(function executeRule(current, previous /*null when async*/) {
	
	var setUtil = new UpdateSetUtils(current);
	
	if (setUtil.hasMixedScope()) {
		gs.addErrorMessage('This Update Set cannot be closed, because it contains updates in multiple scopes. The state change has been reverted, but any other changes to this Update Set have been saved.');
		//If updates in a different scope from the set are found, disallow closure.
		
		//Revert state field, but do not reject other changes
		current.setValue('state', previous.getValue('state'));
	}
	
})(current, previous);]]&gt;&lt;/script&gt;&lt;sys_class_name&gt;sys_script&lt;/sys_class_name&gt;&lt;sys_created_by&gt;admin&lt;/sys_created_by&gt;&lt;sys_created_on&gt;2019-03-06 16:58:51&lt;/sys_created_on&gt;&lt;sys_domain&gt;global&lt;/sys_domain&gt;&lt;sys_domain_path&gt;/&lt;/sys_domain_path&gt;&lt;sys_id&gt;9f340d5d37c8370090b68cf6c3990e43&lt;/sys_id&gt;&lt;sys_mod_count&gt;2&lt;/sys_mod_count&gt;&lt;sys_name&gt;Prevent Mixed-scope Update Set Closure&lt;/sys_name&gt;&lt;sys_overrides/&gt;&lt;sys_package display_value="Global" source="global"&gt;global&lt;/sys_package&gt;&lt;sys_policy/&gt;&lt;sys_scope display_value="Global"&gt;global&lt;/sys_scope&gt;&lt;sys_update_name&gt;sys_script_9f340d5d37c8370090b68cf6c3990e43&lt;/sys_update_name&gt;&lt;sys_updated_by&gt;admin&lt;/sys_updated_by&gt;&lt;sys_updated_on&gt;2019-03-06 22:21:11&lt;/sys_updated_on&gt;&lt;template/&gt;&lt;when&gt;before&lt;/when&gt;&lt;/sys_script&gt;&lt;sys_translated_text action="delete_multiple" query="documentkey=9f340d5d37c8370090b68cf6c3990e43"/&gt;&lt;/record_update&gt;</payload>
<payload_hash>1514759604</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>e7535fc63770f30090b68cf6c3990e2a</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>1695518a34c0000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table>sys_update_set</table>
<target_name>Prevent Mixed-scope Update Set Closure</target_name>
<type>Business Rule</type>
<update_domain>global</update_domain>
<update_guid>f33e4e5943cc37002a3c6d44b1e61a41</update_guid>
<update_guid_history>f33e4e5943cc37002a3c6d44b1e61a41:1514759604,7a9f4d55e30c3700d07eb510138b4b2c:543745460,b174455dabc83700bef0a47c4ed0cd53:-660308468</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_c9750e5537cc370090b68cf6c3990e38</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Prevent Closing Update Sets with Checked-out Workflows&lt;/strong&gt;&lt;br /&gt;&#13;
If true, this will prevent anyone from closing an Update Set that contains a Workflow which is currently checked out. &lt;br /&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: true</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>sng.update_sets.prevent_closing_active_wf_sets</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 21:42:47</sys_created_on><sys_id>c9750e5537cc370090b68cf6c3990e38</sys_id><sys_mod_count>3</sys_mod_count><sys_name>sng.update_sets.prevent_closing_active_wf_sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_c9750e5537cc370090b68cf6c3990e38</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:56:43</sys_updated_on><type>boolean</type><value>true</value><write_roles>admin</write_roles></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=c9750e5537cc370090b68cf6c3990e38"/></record_update>]]></payload>
<payload_hash>-1916114389</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>eb535fc63770f30090b68cf6c3990e26</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a2224e5480000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.prevent_closing_active_wf_sets</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>845153464070f30090b620af85a94f26</update_guid>
<update_guid_history>845153464070f30090b620af85a94f26:-1916114389,4b315b069a70f300e2954804569ac152:59203190,20078e95abcc37009560813f12e3583d:-1916114389,25750e55f0cc3700595a59cf11a20d3c:-1775372438</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_d25f4e1d37cc370090b68cf6c3990ea6</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties"><sys_properties action="INSERT_OR_UPDATE"><choices/><description>&lt;strong&gt;Prevent Reopening Closed Update Sets&lt;/strong&gt;&lt;br /&gt;&#13;
If true, this will prevent anyone from re-opening an Update Set that has previously been closed. &lt;br /&gt;&#13;
This will prevent issues with deployment and Update Set retrieval. &lt;br /&gt;&#13;
&lt;strong&gt;Default&lt;/strong&gt;: true</description><ignore_cache>false</ignore_cache><is_private>false</is_private><name>sng.update_sets.prevent_reopening_sets</name><read_roles/><suffix/><sys_class_name>sys_properties</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 22:26:00</sys_created_on><sys_id>d25f4e1d37cc370090b68cf6c3990ea6</sys_id><sys_mod_count>3</sys_mod_count><sys_name>sng.update_sets.prevent_reopening_sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_d25f4e1d37cc370090b68cf6c3990ea6</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:56:38</sys_updated_on><type>boolean</type><value>true</value><write_roles>admin</write_roles></sys_properties><sys_translated_text action="delete_multiple" query="documentkey=d25f4e1d37cc370090b68cf6c3990ea6"/></record_update>]]></payload>
<payload_hash>-1417109786</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>eb535fc63770f30090b68cf6c3990e29</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a2224d3d80000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>sng.update_sets.prevent_reopening_sets</target_name>
<type>System Property</type>
<update_domain>global</update_domain>
<update_guid>36419f06a970f300b67589c5680a6b43</update_guid>
<update_guid_history>36419f06a970f300b67589c5680a6b43:-1417109786,94415b062c70f300d0f69e735c658c5b:1875662463,2ac05211cc007700a6c45b3d2b94979e:-1417109786,725fca5d63cc3700558dd50d868b1acd:1191818515</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_app_module_5a4bc19d37c8370090b68cf6c3990ea5</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update sys_domain="global" table="sys_app_module"><sys_app_module action="INSERT_OR_UPDATE"><active>true</active><application display_value="System Update Sets">a02b3c250a0a0b50000cc3543c6e463a</application><assessment/><content_page/><device_type/><filter/><hint>Properties relating to the "Smarter Update Sets" functionality</hint><homepage/><image/><link_type>DIRECT</link_type><map_page/><mobile_title>Include in Update Set Properties</mobile_title><mobile_view_name>Mobile</mobile_view_name><name/><order>700</order><override_menu_roles>false</override_menu_roles><query>system_properties_ui.do?sysparm_title=Smarter%20Update%20Sets&amp;sysparm_category=Smarter%20Update%20Sets</query><report/><roles>admin</roles><sys_class_name>sys_app_module</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-03-06 17:28:38</sys_created_on><sys_domain>global</sys_domain><sys_domain_path>/</sys_domain_path><sys_id>5a4bc19d37c8370090b68cf6c3990ea5</sys_id><sys_mod_count>1</sys_mod_count><sys_name>Smarter Update Sets Properties</sys_name><sys_overrides/><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_app_module_5a4bc19d37c8370090b68cf6c3990ea5</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-03-06 17:45:34</sys_updated_on><timeline_page/><title>Smarter Update Sets Properties</title><uncancelable>false</uncancelable><view_name/><window_name/></sys_app_module></record_update>]]></payload>
<payload_hash>-963297172</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>ef5313863770f30090b68cf6c3990e2f</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>169541c4d480000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>Smarter Update Sets Properties</target_name>
<type>Module</type>
<update_domain>global</update_domain>
<update_guid>962f8595e50c370020fdec002c2def85</update_guid>
<update_guid_history>962f8595e50c370020fdec002c2def85:-963297172,1a4bc19d4dc83700cc75a56a64b906a7:840623564</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
<sys_update_xml action="INSERT_OR_UPDATE">
<action>INSERT_OR_UPDATE</action>
<application display_value="Global">global</application>
<category>customer</category>
<comments/>
<name>sys_properties_category_m2m_afeccb8e3730f30090b68cf6c3990eb6</name>
<payload><![CDATA[<?xml version="1.0" encoding="UTF-8"?><record_update table="sys_properties_category_m2m"><sys_properties_category_m2m action="INSERT_OR_UPDATE"><category display_value="Smarter Update Sets">4cab4515370c370090b68cf6c3990ed9</category><order>900</order><property display_value="alert_on_default_set.determine_default_by" name="alert_on_default_set.determine_default_by">761e8c06370dab0090b68cf6c3990ece</property><sys_class_name>sys_properties_category_m2m</sys_class_name><sys_created_by>admin</sys_created_by><sys_created_on>2019-04-15 17:37:35</sys_created_on><sys_id>afeccb8e3730f30090b68cf6c3990eb6</sys_id><sys_mod_count>1</sys_mod_count><sys_name>alert_on_default_set.determine_default_by.Smarter Update Sets</sys_name><sys_package display_value="Global" source="global">global</sys_package><sys_policy/><sys_scope display_value="Global">global</sys_scope><sys_update_name>sys_properties_category_m2m_afeccb8e3730f30090b68cf6c3990eb6</sys_update_name><sys_updated_by>admin</sys_updated_by><sys_updated_on>2019-04-15 17:38:33</sys_updated_on></sys_properties_category_m2m></record_update>]]></payload>
<payload_hash>-1308556679</payload_hash>
<remote_update_set display_value="SNG-Smarter Update Sets-v1.3">ab5313863770f30090b68cf6c3990e2f</remote_update_set>
<replace_on_upgrade>false</replace_on_upgrade>
<sys_created_by>admin</sys_created_by>
<sys_created_on>2019-04-15 18:05:43</sys_created_on>
<sys_id>ef535fc63770f30090b68cf6c3990e28</sys_id>
<sys_mod_count>0</sys_mod_count>
<sys_recorded_at>16a22143fad0000001</sys_recorded_at>
<sys_updated_by>admin</sys_updated_by>
<sys_updated_on>2019-04-15 18:05:43</sys_updated_on>
<table/>
<target_name>alert_on_default_set.determine_default_by.Smarter Update Sets</target_name>
<type>Category Property</type>
<update_domain>global</update_domain>
<update_guid>612dcb8e6530f300e65deca5dd8f7796</update_guid>
<update_guid_history>612dcb8e6530f300e65deca5dd8f7796:-1308556679,6feccb8ea330f30054010075b6c835b8:692583297</update_guid_history>
<update_set display_value=""/>
<view/>
</sys_update_xml>
</unload>
