2013-12-05 14:54:17 -05:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
2014-02-04 14:15:02 -05:00
|
|
|
# Copyright © 2014 Zulip, Inc.
|
2013-12-05 14:54:17 -05: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
|
|
|
|
ZULIP_USER = "p4-bot@example.com"
|
|
|
|
ZULIP_API_KEY = "0123456789abcdef0123456789abcdef"
|
2016-11-03 17:51:21 -04:00
|
|
|
ZULIP_SITE = "https://zulip.example.com"
|
2013-12-05 14:54:17 -05:00
|
|
|
|
2017-06-19 07:39:07 -04:00
|
|
|
# Set this to point at a p4web installation to get changelist IDs as links
|
|
|
|
# P4_WEB = "https://p4web.example.com"
|
|
|
|
P4_WEB = None
|
|
|
|
|
2013-12-05 14:54:17 -05: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:
|
|
|
|
# * path = the path to the Perforce depot on the server
|
|
|
|
# * changelist = the changelist id
|
|
|
|
#
|
|
|
|
# Returns a dictionary encoding the stream and topic to send the
|
|
|
|
# notification to (or None to send no notification).
|
|
|
|
#
|
|
|
|
# The default code below will send every commit except for ones in the
|
|
|
|
# "master-plan" and "secret" subdirectories of //depot/ to:
|
|
|
|
# * stream "depot_subdirectory-commits"
|
|
|
|
# * subject "change_root"
|
|
|
|
def commit_notice_destination(path, changelist):
|
|
|
|
dirs = path.split('/')
|
|
|
|
if len(dirs) >= 4 and dirs[3] not in ("*", "..."):
|
|
|
|
directory = dirs[3]
|
|
|
|
else:
|
|
|
|
# No subdirectory, so just use "depot"
|
|
|
|
directory = dirs[2]
|
|
|
|
|
|
|
|
if directory not in ["evil-master-plan", "my-super-secret-repository"]:
|
|
|
|
return dict(stream = "%s-commits" % (directory,),
|
|
|
|
subject = path)
|
|
|
|
|
|
|
|
# Return None for cases where you don't want a notice sent
|
|
|
|
return None
|
|
|
|
|
|
|
|
## If properly installed, the Zulip API should be in your import
|
|
|
|
## path, but if not, set a custom path below
|
|
|
|
ZULIP_API_PATH = None
|