Skip to content

A Github action that will return the status of the Itential automation

License

Notifications You must be signed in to change notification settings

itential/itential-automation-get-status

Use this GitHub action with your project
Add this Action to an existing workflow or create a new one
View on Marketplace

Repository files navigation

Itential Automation Get Status

Github Action to monitor Itential automation status and return output variables.

Table of Contents

Prerequisites

An Itential account is required to get credentials needed to configure the Github Actions. In order to utilize this action, you would need to have an active Itential Automation Platform (IAP) / Itential Cloud instance.
If you are an existing customer, please contact your Itential account team for additional details. For new customers interested in an Itential trial, please click here to request one.

Supported Itential Automation Platform Versions

  • 2023.1
  • 2022.1
  • 2021.2
  • 2021.1

Getting Started

  1. Search for the Action on Github Marketplace.

  2. Select the "Use the Latest Version" option on the top right of the screen.

  3. Click the clipboard icon to copy the provided data.

    Sample

    - name: itential-automation-start
    uses: itential/[email protected]
    
  4. Navigate to the '.github/workflows' folder in the target repository (where you intend on using the action).

  5. Paste the copied data in the correlating fields of your workflow file.

  6. Configure the required inputs and optional inputs. (See Note and Configurations)

  7. Save the file with a (.yml) extension.

For a sample workflow file, see Example Usage.

Note: Users may manually enter required input parameters or use Github Secrets if they want to hide certain parameters. If you choose to use Github Secrets, please reference the instructions provided below.

  1. Select the settings tab on your target repository.
  2. Select the secrets and variables tab under security options.
  3. Click the "new repository secret"option on the top right of the screen.
  4. Enter the required fields. For YOUR_SECRET_NAME enter a required input. For SECRET enter your desired variable.
  5. Click "Add Secret"

For more information about Github Action secrets, see Github Secrets

For more information about Github Actions variables, see variables

Configurations

See action.yml for metadata that defines the inputs, outputs, and runs configurations for this action._

For more information about connecting to private network, see Connecting to a private network

Required Input Parameters

The following table defines the required parameters to monitor Itential Automation Status using a Github workflow.

Parameter Description
itential_host_url URL to the Itential Instance
automation_id Automation ID to check status of the automation

Required Authentication Parameters

There are three methods for authenticating API requests to the Itential instance.The following tables describe the required parameters for each authentication method.Based on the available credentials input the appropriate parameters. By default, all the authentication parameters are set to empty string.

Static Token

The provided Static token will be used in all subsequent API calls to the Itential instance

Parameter Description
auth_token Itential Authentication Token

Basic Token

The provided username and password is used to request a token that will be used in all subsequent API calls to the Itential instance .

Parameter Description
auth_username Itential Authentication Username
auth_password Itential Authentication Password

Oauth2 Client Credentials

The provided client credentials are used to request a token that will be used in all subsequent API calls to the Itential instance .

Parameter Description
auth_client_id Itential Authentication Client ID
auth_client_secret Itential Authentication Client Secret

Optional Input Parameters

The following table defines parameters considered optional.

Parameter Description Default
time_interval Time interval to check the automation status (in seconds) 15
no_of_attempts No of attempts to check the automation status 10

Output

The following table defines parameters that are returned. The output is returned as an object with two keys - automation_status and automation_output.

Parameter Description
results Automation Status output variables

Sample Output

  { 
    "automation_status": "running",
    "automation_output": null
  }

Example Usage

The example below displays how to configure a workflow that runs when issues or pull requests are opened or labeled in your repository. This workflow runs when new pull request is opened as defined in the on variable of the workflow.

This action is defined in job1 of the workflow by the step id step1. The output of this step is defined as output1 of the workflow and is extracted using the output variable of this action i.e. results as defined in the output.

You have the option to configure any filters you may want to add, such as only triggering workflow with a specific branch.

For more information about workflows, see Using workflows.

Github Workflow example

# This is a basic workflow to help you get started with Actions
name: Get Automation Status on pull request
# Controls when the workflow will run
on:
  pull_request:
    types: [opened]

jobs:
  job1:
    runs-on: ubuntu-latest
    outputs:
      output1: ${{ steps.step1.outputs.results }}
    name: Automation Status
    steps:
      # To use this repository's private action,
      # you must check out the repository
      - name: Checkout
        uses: actions/checkout@v3
      - name: Get Automation status action step
        id: step1
        uses: itential/itential-automation-get-status@replace_with_latest_version
        with:
          #github_token: ${{secrets.GITHUB_TOKEN}} # include only if user requires a GitHub Token
          itential_host_url: ${{secrets.ITENTIAL_HOST_URL}}
          auth_token: ${{secrets.AUTH_TOKEN}}
          auth_username: ${{secrets.AUTH_USERNAME}}
          auth_password: ${{secrets.AUTH_PASSWORD}}
          auth_client_id: ${{secrets.AUTH_CLIENT_ID}}
          auth_client_secret: ${{secrets.AUTH_CLIENT_SECRET}}
          automation_id: ${{secrets.AUTOMATION_ID}}
          no_of_attempts: 10
          time_interval: 15
      - name: Get output
        run: echo "${{steps.step1.outputs.results}}"

About

A Github action that will return the status of the Itential automation

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •