Skip to content

GitHub CLI extension to create a report of organizational webhooks and re-create webhooks under a new org.

License

Notifications You must be signed in to change notification settings

katiem0/gh-organization-webhooks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gh-organization-webhooks

A GitHub gh CLI extension to create a report containing Webhooks defined at an Organization level, as well as create webhooks from a file or source-org under a new organization.

The csv report includes:

Field Name Description
Type Indicates that the Webhook was created at the Organization level.
ID Associated id for the webhook.
Name Must be passed as web if created from the API. Name can only be set to web or email.
Active If notifications are sent when the webhook is triggered. Set to true to send notifications.
Events What events the hook is triggered for. Set to ["*"] to receive all possible events. The default is ["push"]. Output delimited by ; when specific events selected. (i.e. code_scanning_alert;discussion;push)
Config_ContentType The media type used to serialize the payloads. Supported values include json and form. The default is form.
Config_InsecureSSL Whether the SSL certificate of the host for url is verified when delivering payloads. Supported values include 0 (verification is performed) and 1 (verification is not performed). The default is 0.
Config_Secret If a secret was present when the Webhook was created, the report will return ********.
Config_URL The URL to which the payloads are delivered.
Updated_At Date that the webhook was last updated.
Created_At Date that the webhook was created.

Note This extension does NOT retrieve the value of the webhook secret, and only identifies that one was created.

Installation

  1. Install the gh CLI - see the installation instructions.

  2. Install the extension:

    gh extension install katiem0/gh-organization-webhooks

For more information: gh extension install.

Usage

This extension supports listing and creating webhooks between GitHub.com and GitHub Enterprise Server, through the use of --hostname and --source-hostname.

$ gh organization-webhooks -h 
List and create organization level webhooks.

Usage:
  organization-webhooks [command]

Available Commands:
  create      Create organization level webhooks
  list        List organization level webhooks

Flags:
  -h, --help   help for organization-webhooks

Use "organization-webhooks [command] --help" for more information about a command.

List Webhooks

This extension will create a csv report of Organizational webhooks with the ability to specify the --host-name and --token associated to a Server instance.

$ gh organization-webhooks list -h
List organization level webhooks

Usage:
  organization-webhooks list <source organization> [flags]

Flags:
  -d, --debug                To debug logging
  -h, --help                 help for list
      --hostname string      GitHub Enterprise Server hostname (default "github.com")
  -o, --output-file string   Name of file to write CSV list to (default "WebhookReport-20230411160920.csv")
  -t, --token string         GitHub personal access token for reading source organization (default "gh auth token")

Create Webhooks

Organization Webhooks can be created from a csv file using --from-file following the format outlined in gh-organization-webhooks.

  • If specifying Webhooks --from-file, be sure to update the csv to replace the Config_Secret with the appropriate value. (Default value in file set to value of ********).

  • If specifying a Source Organization (--source-organization) to retrieve secrets and create under a new Org, the --source-token is required.

    • Webhooks that previously were created with a secret will be required to input a new secret value in the command prompt:
      $ gh organization-webhooks create Avocado-Extra-Charge  -o testing-webhooks
       Please enter the new secret to be created with webhook http://testwebhook.com: 
      
$ gh organization-webhooks create -h
Create organization level webhooks

Usage:
  organization-webhooks create <target organization> [flags]

Flags:
  -d, --debug                        To debug logging
  -f, --from-file string             Path and Name of CSV file to create webhooks from
  -h, --help                         help for create
      --hostname string              GitHub Enterprise Server hostname (default "github.com")
      --source-hostname string       GitHub Enterprise Server hostname where webhooks are copied from (default "github.com")
  -o, --source-organization string   Name of the Source Organization to copy webhooks from (Requires --source-token)
  -s, --source-token string          GitHub personal access token for Source Organization (Required for --source-organization)
  -t, --token string                 GitHub personal access token for organization to write to (default "gh auth token")

About

GitHub CLI extension to create a report of organizational webhooks and re-create webhooks under a new org.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages