Skip to content

A collection of TeamCity WebHook Templates for the tcWebHooks plugin

License

Notifications You must be signed in to change notification settings

Nachiket26/tcWebHooksTemplates

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

tcWebHooksTemplates - A collection of TeamCity WebHook Templates for the tcWebHooks plugin

The tcWebHooks plugin is a TeamCity plugin which adds outgoing webhook support to TeamCity. One of the features of tcWebHooks is WebHook Template support.

This GitHub repository is a place to share and discover WebHook Templates. This allows the following benefits:

  • The person/team with the access to the end system can develop and test a template and share it with the community
  • Templates can be easily shared via a pull request
  • Template updates to happen at a different cadence to the tcWebHooks plugin releases
  • The community can iterate quickly on template development together
  • Once we have a good stable template developed, it can become a candidate for inclusion in the tcWebHooks release

There are templates for:

Have a browse of the webhook-templates area, and see if there are any templates you'd like to install.

If there is a template missing, please consider creating it, and raising a pull request to add it. For more information on editing templates in the TeamCity UI, see the WebHook-Templates-:-Web-UI section on the tcWebHooks wiki.

Importing a WebHook Template from this repository

This is the process of taking a webhook-template.json file, and uploading it into TeamCity. This is achieved using the tcWebHook REST API. If the tcWebHook REST API plugin is not installed in TeamCity, you will need to do that first. See the tcWebHook Installation instructions.

Obtaining the templates

Just Git clone this repository, or download the repository and unzip it. The templates are located under the webhook-templates folder.

Importing a WebHook Template using the import-template.sh script

Note: The script does not need to be run on the same computer as the TeamCity server

Requirements:

  1. A unix based computer, eg a Mac, or Linux or other Unix based OS, or a Windows computer with one of the many posix shells installed (eg, cygwin, git-bash, etc).
  2. Standard unix tools, including bash, curl, grep, tr
  3. http or https access to TeamCity
Run the import script

The import script takes three arguments. If they are not present on the commndline, the script will prompt for them.

A template's templateId, is shown near the top of the page when viewing a template in the webUI. Go to /webhooks/templates.html in TeamCity and click view on a template to see the template details.

  • -u username:password : This a teamcity account with admin privileges. Username and password are colon separated as per usual cURL syntax.
  • -s teamcity-server-url : The server address for TeamCity. Please don't include the trailing slash.
  • -t templateId : The templateId of the template to upload. The script will look for it in a directory (folder) of the same name under webhook-templates. The script also checks that the ID inside the template JSON file matches the name of the directory (folder).
./tcWebHooksTemplates/bin/import-template.sh -u netwolfuk:xxxxxxxx -s http://teamcity:8111 -t stride_simple
INFO:   Checking template in: ./tcWebHooksTemplates/bin/../webhook-templates/stride_simple
INFO:   Template file is present and matches stride_simple
INFO:   URL: http://teamcity:8111/app/rest/webhooks/templates/id:stride_simple
INFO:   Template with that ID already exists in TeamCity. Using PUT to update it.
INFO:   Template successfully updated with ID: stride_simple

Importing a WebHook Template manually via the REST API

Creating a new template with POST

To create a new template, POST to /app/rest/webhooks/templates

curl -X POST -k \
    -u "netwolfuk:xxxxxxxx" \
    -H "Content-Type: application/json" \ 
    -d @tcWebHooksTemplates/webhook-templates/stride_simple/webhook-template.json \
    http://teamcity:8111/app/rest/webhooks/templates

The response will contain the new template (in XML format unless you request json with -H "Accept: application/json") The -k disables SSL validation, in case curl does not trust the CA that signed the TeamCity SSL certificate (if relevant).

Updating an existing template with PUT

To replace an existing template, PUT to /app/rest/webhooks/templates/id:templateId

curl -X PUT -k \
     -u "netwolfuk:xxxxxxxx" \
     -H "Content-Type: application/json" \
     -d @tcWebHooksTemplates/webhook-templates/stride_simple/webhook-template.json \
     http://teamcity:8111/app/rest/webhooks/templates/id:stride_simple

The response will contain the updated template (in XML format unless you request json with -H "Accept: application/json"). The -k disables SSL validation, in case curl does not trust the CA that signed the TeamCity SSL certificate (if relevant).

Modifying a template in TeamCity

Once a template is imported, it's possible to make changes to it from within TeamCity to further refine it. For information about editing WebHook Templates, please see the WebHook-Templates-:-Web-UI section on the tcWebHooks wiki.

It would be great to share any templates with the wider community. See below on how to export a template to share.

Exporting a WebHook Template from TeamCity

This is the process of downloading a webhook-template.json from TeamCity. This is achieved using the tcWebHook REST API. If the tcWebHook REST API plugin is not installed in TeamCity, you will need to do that first. See the tcWebHook Installation instructions.

Exporting a WebHook Template using the export-template.sh script

Note: The script does not need to be run on the same computer as the TeamCity server

Requirements:

  1. A unix based computer, eg a Mac, or Linux or other Unix based OS, or a Windows computer with one of the many posix shells installed (eg, cygwin, git-bash, etc).
  2. Standard unix tools, including bash, curl, grep, tr
  3. http or https access to TeamCity
Run the export script

The export script takes three arguments. If they are not present on the commndline, the script will prompt for them.

A template's templateId, is shown near the top of the page when viewing a template in the webUI. Go to /webhooks/templates.html in TeamCity and click view on a template to see the template details.

  • -u username:password : This a teamcity account with admin privileges. Username and password are colon separated as per usual cURL syntax.
  • -s teamcity-server-url : The server address for TeamCity. Please don't include the trailing slash.
  • -t templateId : The templateId of the template to download. The script will create a directory (folder) of the same name under webhook-templates. The script copies a readme.md into that directory in case you want to share the template.
./tcWebHooksTemplates/bin/export-template.sh -u netwolfuk:xxxxxxxx -s http://teamcity:8111 -t stride_simple
INFO:   Template will be downloaded into: ./tcWebHooksTemplates/bin/../webhook-templates/stride_simple
INFO:   URL: http://teamcity:8111/app/rest/webhooks/templates/id:stride_simple
INFO:   Success: The template has been downloaded into: ./tcWebHooksTemplates/bin/../webhook-templates/stride_simple
INFO:   Generating readme.md file in ./tcWebHooksTemplates/bin/../webhook-templates/stride_simple

Exporting a WebHook Template manually via the REST API

The following is an example using cURL.

 curl -k -H "Accept: application/json" \
      -u "netwolfuk:xxxxxxxx" \
      -o webhook-template.json \
      http://teamcity:8111/app/rest/webhooks/templates/id:stride_simple?fields=\$long,content

Don't forget to escape the $ with a \ otherwise the shell will try to interpret it. The -k disables SSL validation, in case curl does not trust the CA that signed the TeamCity SSL certificate (if relevant).

About

A collection of TeamCity WebHook Templates for the tcWebHooks plugin

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 100.0%