Add custom code to your Splunk SOAR (Cloud) playbook with the code block
Add custom Python code to a Code block. Code blocks enable you to expand the kinds of processing performed in a playbook, such as adding custom input parameters and output variables.
Add a code block to your playbook
Perform the following steps to add a Code block to a playbook.
- Drag and drop the half-circle icon attached to any existing block in the editor. Select a Code block from the menu that appears.
- Configure input parameters and output variables. See Add input parameters to a code block and Add output variables to a code block.
- Click the Python Playbook Editor to open it and add your custom code. See Use the Python Playbook Editor to add custom code.
- Click Done.
Add input parameters to a code block
Input parameters represent a datapath. You can set a datapath from any valid blocks upstream, artifact data, and container data.
To create or remove an input parameter, perform the following steps:
- Click the + Input Parameter icon to add an input parameter. The index of parameters starts at zero.
- Click in the Select Parameter box to set the datapath for the input parameter. For details on specifying datapaths, see Specify data in your playbook.
- (Optional) Create a custom datapath if the datapath you need isn't available. For details on creating a custom datapath, see Custom datapaths in the Specify data in your playbook article.
Add output variables to a code block
Output variables are usable as inputs in other downstream blocks, such as Action, Utility, Filter, Decision, Format and Prompt blocks. The name of an output variable becomes <block_name>__<variable_name> in the auto-generated section of the playbook code. Give your output variables clear and meaningful names in your custom code so that you can distinguish them from one another. 
Follow these steps to add an output variable:
- Click + Output Variable to add an output variable.
- Type a name to set the name for, or rename the output variable.
The following example shows both custom code and how outputs are saved:
def format_login(action=None, success=None, notable=None, results=None, handle=None, filtered_artifacts=None, filtered_results=None, **kwargs):
    oar.debug("format_login() called")
    format_login__login_table = None
    ################################################################################
    ## Custom Code Start
    ################################################################################
    # format the output into JIRA's markup language for rendering a table
    format_login__login_table = "|| output of '/usr/bin/last -a' ||\n"
    last_lines = get_user_1_result_item_0[0].split('\n')
	    for line in last_lines:
    	          format_login__login_table += "| {} |\n".format(line)
        
	oar.debug("table of logins for jira:")
	oar.debug(format_login__login_table)
    ################################################################################
    ## Custom Code End
    ################################################################################
    oar.save_run_data(key="format_login:login_table", value=json.dumps(format_login__login_table))
    return
Use custom names to easily identify and arrange your code blocks
You might want to set a custom name for a block to help you distinguish between blocks.
To set a custom name for the Code block, follow these steps:
- Click the Info tab from the configuration panel of the Code block.
- Enter a name in the Custom Name box.
- As a best practice, do not use personally identifiable information in the names of code blocks.
- Custom names can use uppercase and lowercase letters A-Z, numbers 0-9, and underscores.
- Custom names can be up to 50 characters long.
- Setting or changing a custom name changes that custom name in all data paths that use it, including any generated and custom code.
 
- Enter a Description in the Description (code comment) box to act as a description of your code.
- Enter a note in the Notes (block tooltip) box to act as a tooltip for the Code block.
You can also configure Advanced settings for a Code block. You can use Join Settings and Scope, in a Code block. For more information on these settings, see Advanced settings.
Use the Python Playbook Editor to add custom code
You can use the Python Playbook Editor to add custom code to any existing block types.
To add custom code to a block, follow these steps:
- Select or create a block to open the configuration panel.
- Select Python Playbook Editor.
- Enter your custom code.
If you add or edit code outside of the Custom Code Start and Custom Code End sections, the configuration panel for that block is not usable.
Waiting within a playbook
 You might need your playbook to wait for a specified amount of time, for example, to do this. In cases like this, use the no op action from the Splunk-maintained Phantom app, available on Splunkbase. 
sleep function in your playbook code. Doing so can lock up all of your playbook runners and reduce your automation throughput to zero.Splunk SOAR (Cloud) APIs in custom code
You can include calls to the Splunk SOAR (Cloud) APIs within the custom code. For example, you can include one or more Vault APIs to add or access files in the Vault. For information on Splunk SOAR (Cloud) APIs, see Python Playbook API Reference for Splunk SOAR (Cloud).
Update Python version for existing custom code
how to update to the latest supported version of Python
Check that your custom code is using the latest Python version supported by Splunk SOAR to ensure full compatibility with Splunk SOAR.
To find and update playbooks that have code that must be updated, follow these steps:
- 
                From the Home menu, select Playbooks. 
- 
                At the top of the Playbooks list, select Python update required. 
- Select a playbook to open.
- 
                In the playbook, open the Playbooks Settings panel. In the Python version box, select the most recent version of Python. Read the message that appears and confirm that you want to make this change.Note: Updating the Python version might break some automation.
- The Python validation process starts automatically. - If your code validates successfully, your playbook updates to the latest Python version supported by Splunk SOAR. Save your playbook. Repeat these steps for additional playbooks. 
- If your code does not validate successfully, the validation process produces notes, warnings, and errors, directing you to potential issues with updating to the most recent, version of Python supported in Splunk SOAR. Continue with the following step. 
 
- 
                Hover over each message to learn more and then address each of the messages. At a minimum, you must address all error-type messages in order to update to the selected Python version. 
- 
                Repeat the previous steps, starting with changing the Python version in Step 4. Continue until the version change works and you save the playbook. 
- 
                Repeat these steps for each playbook that requires a Python update. 
For more information about Python versions in Splunk SOAR, see How SOAR (Cloud) uses Python