2016-04-07 15:03:22 +02:00
|
|
|
#!/usr/bin/env python
|
2013-02-15 23:01:55 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
2014-02-04 20:15:02 +01:00
|
|
|
# Copyright © 2014 Zulip, Inc.
|
2013-02-15 23:01:55 +01:00
|
|
|
#
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
|
|
# in the Software without restriction, including without limitation the rights
|
|
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
|
|
# furnished to do so, subject to the following conditions:
|
|
|
|
#
|
|
|
|
# The above copyright notice and this permission notice shall be included in
|
|
|
|
# all copies or substantial portions of the Software.
|
|
|
|
#
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
# THE SOFTWARE.
|
|
|
|
|
|
|
|
|
|
|
|
# Change these values to configure authentication for the plugin
|
2013-08-07 18:26:11 +02:00
|
|
|
ZULIP_USER = "git-bot@example.com"
|
|
|
|
ZULIP_API_KEY = "0123456789abcdef0123456789abcdef"
|
2013-02-15 23:01:55 +01:00
|
|
|
|
|
|
|
# commit_notice_destination() lets you customize where commit notices
|
|
|
|
# are sent to with the full power of a Python function.
|
|
|
|
#
|
|
|
|
# It takes the following arguments:
|
|
|
|
# * repo = the name of the git repository
|
|
|
|
# * branch = the name of the branch that was pushed to
|
|
|
|
# * commit = the commit id
|
|
|
|
#
|
|
|
|
# Returns a dictionary encoding the stream and subject to send the
|
|
|
|
# notification to (or None to send no notification).
|
|
|
|
#
|
|
|
|
# The default code below will send every commit pushed to "master" to
|
|
|
|
# * stream "commits"
|
2013-12-11 17:41:54 +01:00
|
|
|
# * topic "master"
|
2013-02-15 23:01:55 +01:00
|
|
|
# And similarly for branch "test-post-receive" (for use when testing).
|
|
|
|
def commit_notice_destination(repo, branch, commit):
|
|
|
|
if branch in ["master", "test-post-receive"]:
|
|
|
|
return dict(stream = "commits",
|
2013-12-11 17:41:54 +01:00
|
|
|
subject = u"%s" % (branch,))
|
2013-02-15 23:01:55 +01:00
|
|
|
|
|
|
|
# Return None for cases where you don't want a notice sent
|
|
|
|
return None
|
|
|
|
|
2013-10-08 20:45:05 +02:00
|
|
|
# Modify this function to change how commits are displayed; the most
|
|
|
|
# common customization is to include a link to the commit in your
|
|
|
|
# graphical repository viewer, e.g.
|
|
|
|
#
|
2013-11-20 19:10:43 +01:00
|
|
|
# return '!avatar(%s) [%s](https://example.com/commits/%s)\n' % (author, subject, commit_id)
|
2013-10-08 20:45:05 +02:00
|
|
|
def format_commit_message(author, subject, commit_id):
|
2013-11-20 19:10:43 +01:00
|
|
|
return '!avatar(%s) %s\n' % (author, subject)
|
2013-10-08 20:45:05 +02:00
|
|
|
|
2013-08-06 21:32:15 +02:00
|
|
|
## If properly installed, the Zulip API should be in your import
|
2013-02-15 23:01:55 +01:00
|
|
|
## path, but if not, set a custom path below
|
2013-08-07 18:26:11 +02:00
|
|
|
ZULIP_API_PATH = None
|
2013-02-15 23:01:55 +01:00
|
|
|
|
2015-08-21 18:34:54 +02:00
|
|
|
# Set this to your Zulip server's API URI
|
2013-08-07 18:26:11 +02:00
|
|
|
ZULIP_SITE = "https://api.zulip.com"
|