Configuring web hooks

Web hooks allow you to post changeset information to a specific URL. For each commit indexed by Fisheye, the changeset data will be sent in JSON format to all configured URLs using a POST request.

You can use this feature to build integration with applications such as issue trackers, continuous integration solutions or notification systems.

Be aware that web hooks can expose private commit information. For example, using a public service could expose your code. Any user with administrative privileges in Fisheye can create a web hook for any repository.

Adding web hooks

Web Hooks can be added or edited from the configuration page accessible from the Administration interface.

Go to the Admin area and click Web Hooks, under 'Repository Settings'.

Click Add to create a new Web Hook. Choose a repository and enter your URL. Click Test and Save to verify and store your configuration. Web Hooks also support basic authentication, which can be configured in the Advanced Options:

Disabling web hooks

To disable Web Hooks, go to the Administration > Manage apps.

Show System apps and navigate to the Fisheye/Crucible Web Hooks Plugin and click Disable.

Web hook data

Web hooks will send changeset data in the following JSON representation:

{
    "repository": { 
        "name" : <repository name>,
        "displayName" : <repository display name>,
    },
    "changeset" : {
        "csid" : <changeset id>,
        "displayId" : <changeset id>,
        "author" : <committer>,
        "comment" : <commit message>,
        "date" : <commit date>,
        "branches" : [ 
            <list of commit branches>
        ],
        "tags" : [ 
            <list of commit tags>
        ],
        "parents" : [
            <list of parents>
        ] 
    }
}


Sample web hook scripts

The following script examples show you how to set up web hooks in various languages.

python

This example requires the simplejson library.

import simplejson as json
import pprint
from BaseHTTPServer import BaseHTTPRequestHandler, HTTPServer


class postRequestHandler(BaseHTTPRequestHandler):
def do_POST(self):
                content_length = self.headers.getheader('content-length')
                if content_length:
                         content_length = int(content_length)
                if self.path.endswith('webhook'):
                        self.send_response(200)
                        self.end_headers()
                        body = self.rfile.read(content_length)
                        post_data = json.loads(body)
                        print 'Commit added with comment: %s' % post_data["changeset"]["comment"]

                else:
                        self.send_error(404, 'File Not Found %s' % self.path)
                
                return
                
                
def run():
        server = HTTPServer(('', 8081), postRequestHandler)
        print 'Server started'
        server.serve_forever()
                
if __name__ == '__main__':
        run()

Ruby and Sinatra

The example below will display the changeset information in the logs of the Sinatra server.

require 'rubygems'
require 'sinatra'
require 'json'

post '/' do
 changeset = JSON.parse(request.body.read)
 puts changeset.inspect 
end
最終更新日: 2024 年 12 月 22 日

この内容はお役に立ちましたか?

はい
いいえ
この記事についてのフィードバックを送信する
Powered by Confluence and Scroll Viewport.