This repository has been archived by the owner on Jul 22, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathCONCEPT_NumValueChk_GW_Automation.json
1 lines (1 loc) · 60.3 KB
/
CONCEPT_NumValueChk_GW_Automation.json
1
[{"name":"Concept: Workflow with Conditional Execution using \"Numeric Value Check GW Automation\"","description":"This is a concept runbook that delivers and uses the GW_NumericValChk automation.","steps":[{"number":1,"description":"\n<p dir=\"ltr\">This is a sample runbook provided to show the concept of reacting on some incident by executing some action (via SCRIPT) on an arbitrary number of endpoint systems.</p>\n\n<p dir=\"ltr\">This runbook shows how to <strong>conditionally execute automations </strong>in a step.<br>\n<br>\n<img src=\"\" width=\"683\" height=\"249\"><br>\n<br>\nAs runbook steps this is translated to::</p>\n\n<table dir=\"ltr\" style=\"border-collapse: collapse; border-color: rgb(105, 105, 105);\" width=\"747\" height=\"211\" border=\"1\">\n\t<tbody>\n\t\t<tr>\n\t\t\t<td style=\"border-color: rgb(105, 105, 105);\"><strong><span style=\"font-size:24px;\">•</span> (Start)</strong></td>\n\t\t\t<td style=\" border-color : #696969;\">Step 2</td>\n\t\t\t<td style=\" border-color : #696969;\">Find affected Systems</td>\n\t\t</tr>\n\t\t<tr>\n\t\t\t<td style=\"border-color: rgb(105, 105, 105);\"><strong>→</strong></td>\n\t\t\t<td style=\" border-color : #696969;\">Step 3</td>\n\t\t\t<td style=\" border-color : #696969;\">Calculate how many system</td>\n\t\t</tr>\n\t\t<tr>\n\t\t\t<td style=\"border-color: rgb(105, 105, 105);\"><strong>→</strong></td>\n\t\t\t<td style=\" border-color : #696969;\">Step 4</td>\n\t\t\t<td style=\" border-color : #696969;\">Get list of hostname with \"Linux\" systems affected.</td>\n\t\t</tr>\n\t\t<tr>\n\t\t\t<td style=\"border-color: rgb(105, 105, 105);\"><strong><span style=\"font-size:24px;\">♦ </span>(Condition)</strong></td>\n\t\t\t<td style=\" border-color : #696969;\">Step 5</td>\n\t\t\t<td style=\" border-color : #696969;\">Use GW Automation<strong> as condition</strong> to create target list with [0..n] hostnames.<br>\n\t\t\t<strong>Use as Input results calculated in Step 3 and Step 4</strong></td>\n\t\t</tr>\n\t\t<tr>\n\t\t\t<td style=\"border-color: rgb(105, 105, 105);\"><strong>→ (Conditional)</strong></td>\n\t\t\t<td style=\" border-color : #696969;\">Step 6</td>\n\t\t\t<td style=\" border-color : #696969;\">Sample automation that runs on all systems prepared in step 5<br>\n\t\t\t<strong>Use (0..n) target(s) calculated in Step 5</strong></td>\n\t\t</tr>\n\t\t<tr>\n\t\t\t<td style=\"border-color: rgb(105, 105, 105);\"><strong><span style=\"font-size:20px;\">× </span>(End)</strong></td>\n\t\t\t<td style=\" border-color : #696969;\"> </td>\n\t\t\t<td style=\" border-color : #696969;\"> </td>\n\t\t</tr>\n\t</tbody>\n</table>\n\n<p dir=\"ltr\"> </p>\n\n"},{"number":2,"description":"\n<p dir=\"ltr\">This first step typically uses <strong>an automation that checks a certain condition </strong>highlighted by the incident. It finds target systems to be changed/ fixed by a following automation.</p>\n\n<p dir=\"ltr\">This automation simply prints a list of <strong><OS> <HOSTNAME> <A_COMPONENT> </strong>out.<br>\n<strong>It is just for demo purposes to show the concept.</strong> If you want to use this runbook and run in you environment than you have to edit this automation and add a list of real HOSTNAMES to be printed instead.<br>\n<br>\n<strong><span style=\"color:#0000FF;\">Notice</span>: </strong>Do not skip execution of this automation - the result of this automation is being used as input for the automations in Step 3 and Step 4..</p>\n\n<p dir=\"ltr\"><span style=\"color:#0000FF;\"><strong>Remember: </strong></span>The systems represented by the HOSTNAMES must be be prepared with the SSH Key required for script automation.</p>\n\n<p dir=\"ltr\"><span class=\"span-grp rba-autom\" data-automationid=\"§§exportedAutomation_1_§§\" data-mappingid=\"6\" contenteditable=\"false\">Handle Incident</span></p>\n\n"},{"number":3,"description":"\n<p dir=\"ltr\">This step uses the output of previous step to create a Key=Value list for the GW Automation in next step.<br>\nIf the Automation in previous step is already able to provide this Key=Value list then this automation can be omitted.</p>\n\n<p dir=\"ltr\"><strong><span style=\"color:#0000FF;\">Notice</span>: </strong>Do not skip execution of this automation - the result of this automation is being used as one input of the Gateway Automation in step 5.</p>\n\n<p dir=\"ltr\"><span class=\"span-grp rba-autom\" data-automationid=\"§§exportedAutomation_2_§§\" data-mappingid=\"7\" contenteditable=\"false\">Calc Patch Systems by OS</span></p>\n\n"},{"number":4,"description":"\n<p dir=\"ltr\">Now, in this step compile the list of <strong>Linux</strong> systems to be checked<br>\n<strong><span style=\"color:#0000FF;\">Notice</span>: </strong>Do not skip execution of this automation - the result of this automation is being used as one input of the Gateway Automation in step 5.<br>\n </p>\n\n<p dir=\"ltr\"><span class=\"span-grp rba-autom\" data-automationid=\"§§exportedAutomation_3_§§\" data-mappingid=\"8\" contenteditable=\"false\">Get System Names by OS</span></p>\n\n<p dir=\"ltr\"> </p>\n\n"},{"number":5,"description":"\n<p dir=\"ltr\">This step calls the Automation to create a list of targets that can be used by following \"Multi-Target-Automations\".<br>\n<br>\n<span style=\"color:#0000FF;\"><strong>Notice</strong></span>: The concept of an automation that calculates a target list (which can be even empty) is called <strong>\"Gateway Automation\".</strong><br>\nSince Gateway Automation decides to either return a filled or an empty list of target - you can use it for <strong>conditional execution</strong> of automations in following steps.</p>\n\n<p dir=\"ltr\"><span class=\"span-grp rba-autom\" data-automationid=\"§§exportedAutomation_0_§§\" data-mappingid=\"4\" contenteditable=\"false\">GW_NumericValChk</span></p>\n\n"},{"number":6,"description":"\n<p dir=\"ltr\">Run the following automation to check for installed package <span class=\"span-grp rba-param\" contenteditable=\"false\">PACKAGENAME</span> on the target list, which is calculated in step before<br>\n<br>\n<span style=\"color:#0000FF;\"><strong>Notice</strong></span>: The following script automation is being called with a list of targets calculated in previous steps.<br>\nThis concept is called <strong>\"Multi Target Automation\".</strong></p>\n\n<p dir=\"ltr\">Therefore the script in this automation will be executed in parallel on all the specified targets.<br>\nIn case where the list of target calculated by the automation in step before is empty - the automation will not be executed on any system, but still end with status \"successfull\"</p>\n\n<p dir=\"ltr\"><span class=\"span-grp rba-autom\" data-automationid=\"§§exportedAutomation_4_§§\" data-mappingid=\"5\" contenteditable=\"false\">Display Package Info</span></p>\n\n<p dir=\"ltr\"> </p>\n\n<p dir=\"ltr\"> </p>\n"}],"parameters":[{"name":"PACKAGENAME","description":"This is the package name to be checked with yum","defaultValue":"bash.x86_64"}],"tags":["concept","gw-automation"],"automationMappings":[{"mappingId":"4","parameterMappings":[{"automationParameterName":"target","parameterMappingType":"fixed","parameterValue":"localhost"},{"automationParameterName":"user","parameterMappingType":"fixed","parameterValue":"root"},{"automationParameterName":"$INPUT","parameterMappingType":"automationOutput","parameterValue":"3"},{"automationParameterName":"$KEY","parameterMappingType":"fixed","parameterValue":"Linux"},{"automationParameterName":"$OPER","parameterMappingType":"fixed","parameterValue":">"},{"automationParameterName":"$VALUE","parameterMappingType":"fixed","parameterValue":"0"},{"automationParameterName":"$EPS","parameterMappingType":"automationOutput","parameterValue":"4"}]},{"mappingId":"5","parameterMappings":[{"automationParameterName":"target","parameterMappingType":"automationOutput","parameterValue":"5"},{"automationParameterName":"user","parameterMappingType":"fixed","parameterValue":"root"},{"automationParameterName":"$PACKAGE","parameterMappingType":"parameter","parameterValue":"PACKAGENAME"}]},{"mappingId":"6","parameterMappings":[{"automationParameterName":"target","parameterMappingType":"fixed","parameterValue":"localhost"},{"automationParameterName":"user","parameterMappingType":"fixed","parameterValue":"root"},{"automationParameterName":"$PACKAGE","parameterMappingType":"parameter","parameterValue":"PACKAGENAME"}]},{"mappingId":"7","parameterMappings":[{"automationParameterName":"target","parameterMappingType":"fixed","parameterValue":"localhost"},{"automationParameterName":"user","parameterMappingType":"fixed","parameterValue":"root"}]},{"mappingId":"8","parameterMappings":[{"automationParameterName":"target","parameterMappingType":"fixed","parameterValue":"localhost"},{"automationParameterName":"user","parameterMappingType":"fixed","parameterValue":"root"},{"automationParameterName":"$OSSYSINFOARRAY","parameterMappingType":"automationOutput","parameterValue":"2"},{"automationParameterName":"$OSNAME","parameterMappingType":"fixed","parameterValue":"Linux"}]}],"automations":{"§§exportedAutomation_0_§§":{"name":"GW_NumericValChk","type":"SCRIPT","description":"This gateway automation can be called with an array of arbitrary length in the form of <key>=<value>:<key2>=<value2>:<key3>=<value3>: ...\nFor example INPUT=\"tomatoes=12:apples=23:strawberries=18:peach=33\"\n\nThe input of this form can be checked for a specified <key> <operand> <value>\nFor example KEY=\"apples\" OPER=\">\" VALUE=\"15\"\n\nIn addition a comma-separated list of target systems (endpoints / EPS) can be specified \nFor example EPS=\"linuxprod001,linuxprod002,windowsprod010,aixprod111\"\n\nIf the check evaluates to \"true\" the specified list of EPS is returned as array suitable as target for a following automation.\nIn the above example the number of apples is bigger then 15, which results in following array to be written to the standard output:\n[linuxprod001,linuxprod002,windowsprod010,aixprod111]\n\nIf an unknown KEY is specified or the combination of OPER and VALUE evaluated to \"false\" an empty array is written to the standard output\nsuch as \"[]","parameters":[{"name":"target","description":"Target system where the script will be executed"},{"name":"user","description":"User ID that is used to run the script"},{"name":"$INPUT","description":"This is the array of <key>=<value> separated by \":\" to be checked"},{"name":"$KEY","description":"This is the KEY to be checked in the INPUT array"},{"name":"$OPER","description":"This is the operator to be used in the value check","defaultValue":"="},{"name":"$VALUE","description":"This is the value to be used in the value check"},{"name":"$EPS","description":"This is the comma-separated list of endpoint systems to be returned as array when this GW automation evaluated to TRUE"}],"fields":[{"name":"script_ssh","description":"script content","encoding":"base64","value":"IyEvYmluL3NoCgpJRlM9JzonCgp2YWxzPSRJTlBVVApmb3IgeCBpbiAkdmFscwpkbwogICAgaWYgW1sgJHggPT0gJEtFWSogXV0gOwogICAgdGhlbgogICAgICBjb21wYXJlPSR4CiAgICAgIGN2YWw9JHtjb21wYXJlIyo9fQogICAgZmkKZG9uZQoKaWYgW1sgISAteiAkY29tcGFyZSBdXQp0aGVuCiAgaWYgKChleHByICRjdmFsICRPUEVSICRWQUxVRSk+L2Rldi9udWxsKTsgdGhlbgogICAgZWNobyAtbiBbJEVQU10KICBlbHNlCiAgICBlY2hvIC1uIFtdCiAgZmkKZWxzZQogIGVjaG8gLW4gW10KZmk="}]},"§§exportedAutomation_1_§§":{"name":"Handle Incident","type":"SCRIPT","description":"This is an automation that shows a Linux package to be change, since a some problem has been identified with it.","parameters":[{"name":"target","description":"Target system where the script will be executed"},{"name":"user","description":"User ID that is used to run the script"},{"name":"$PACKAGE","description":"This is the package to be Fixed"}],"fields":[{"name":"script_ssh","description":"script content","encoding":"base64","value":"ZWNobyBMaW51eCByYmFkY2xueC0xICRQQUNLQUdFIAplY2hvIExpbnV4IHJiYWRjbG54LTIgJFBBQ0tBR0UgCmVjaG8gQUlYICAgcmJhZGNhaXgwMDEgeGNsb2NrICAKZWNobyBBSVggICByYmFkY2FpeDAwMyB4dGVybSAgIAplY2hvIExpbnV4IHJiYWRjbG54LTMgJFBBQ0tBR0UKZWNobyBMaW51eCByYmFkY2xueC00ICRQQUNLQUdFCmVjaG8gV0lOICAgcHJvZHdpbjAwMSBXZWJzcGhlcmUKZWNobyBXSU4gICBwcm9kd2luMDAyIFdlYlNwaGVyZQplY2hvIFdJTiAgIHByb2R3aW4wMDMgRWNsaXBzZQ=="}]},"§§exportedAutomation_2_§§":{"name":"Calc Patch Systems by OS","type":"SCRIPT","description":"This returns the number of systems to be pathched by OS","parameters":[{"name":"target","description":"Target system where the script will be executed"},{"name":"user","description":"User ID that is used to run the script"}],"fields":[{"name":"script_ssh","description":"script content","encoding":"base64","value":"ZWNobyAtbiBMaW51eD00OkFJWD0yOldJTj0z"}]},"§§exportedAutomation_3_§§":{"name":"Get System Names by OS","type":"SCRIPT","description":"Get a list of Systems of a specific OS. Input is an array with line \"<OS> <SYSName> <INFO>\"","parameters":[{"name":"target","description":"Target system where the script will be executed"},{"name":"user","description":"User ID that is used to run the script"},{"name":"$OSSYSINFOARRAY"},{"name":"$OSNAME"}],"fields":[{"name":"script_ssh","description":"script content","encoding":"base64","value":"SUZTPSQnCicKZm9yIHggaW4gJE9TU1lTSU5GT0FSUkFZCmRvCiAgaWYgW1sgJHggPT0gJE9TTkFNRSogXV0KICB0aGVuCiAgICBJRlM9JyAnCiAgICB5PSgkeCkKICAgIGlmIFtbIC16ICIkbGlzdCIgXV0KICAgIHRoZW4KICAgICAgbGlzdD0ke3lbMV19CiAgICBlbHNlCiAgICAgIGxpc3Q9JGxpc3QsJHt5WzFdfQogICAgZmkKICBmaQpkb25lCgplY2hvIC1uICRsaXN0"}]},"§§exportedAutomation_4_§§":{"name":"Display Package Info","type":"SCRIPT","description":"This automation simply uses \"yum\" to display the information of the package which has been specified by parameter.","parameters":[{"name":"target","description":"Target system where the script will be executed"},{"name":"user","description":"User ID that is used to run the script"},{"name":"$PACKAGE","description":"The name of the package to be checked"}],"fields":[{"name":"script_ssh","description":"script content","encoding":"base64","value":"IyEvYmluL3NoCnNldCAteAoKeXVtIGluZm8gJFBBQ0tBR0U="}]}}}]