2020-04-02 09:59:28 -04:00
|
|
|
#!/usr/bin/env python3
|
2020-03-23 00:55:21 -04:00
|
|
|
|
2013-12-05 14:54:17 -05:00
|
|
|
'''Zulip notification change-commit hook.
|
|
|
|
|
|
|
|
In Perforce, The "change-commit" trigger is fired after a metadata has been
|
2017-01-12 02:29:40 -05:00
|
|
|
created, files have been transferred, and the changelist committed to the depot
|
2013-12-05 14:54:17 -05:00
|
|
|
database.
|
|
|
|
|
|
|
|
This specific trigger expects command-line arguments in the form:
|
|
|
|
%change% %changeroot%
|
|
|
|
|
|
|
|
For example:
|
|
|
|
1234 //depot/security/src/
|
|
|
|
|
|
|
|
'''
|
|
|
|
|
|
|
|
import os
|
|
|
|
import os.path
|
2021-05-28 05:00:04 -04:00
|
|
|
import sys
|
2013-12-05 14:54:17 -05:00
|
|
|
|
|
|
|
import git_p4
|
|
|
|
|
2013-12-06 17:51:32 -05:00
|
|
|
__version__ = "0.1"
|
|
|
|
|
2013-12-05 14:54:17 -05:00
|
|
|
sys.path.insert(0, os.path.dirname(__file__))
|
2020-04-18 19:00:35 -04:00
|
|
|
from typing import Any, Dict, Optional
|
2021-05-28 05:00:04 -04:00
|
|
|
|
2013-12-05 14:54:17 -05:00
|
|
|
import zulip_perforce_config as config
|
|
|
|
|
|
|
|
if config.ZULIP_API_PATH is not None:
|
|
|
|
sys.path.append(config.ZULIP_API_PATH)
|
|
|
|
|
|
|
|
import zulip
|
2021-05-28 05:00:04 -04:00
|
|
|
|
2013-12-05 14:54:17 -05:00
|
|
|
client = zulip.Client(
|
|
|
|
email=config.ZULIP_USER,
|
|
|
|
site=config.ZULIP_SITE,
|
2013-12-06 17:50:55 -05:00
|
|
|
api_key=config.ZULIP_API_KEY,
|
2021-05-28 05:03:46 -04:00
|
|
|
client="ZulipPerforce/" + __version__,
|
|
|
|
) # type: zulip.Client
|
2013-12-05 14:54:17 -05:00
|
|
|
|
|
|
|
try:
|
2016-12-29 06:34:27 -05:00
|
|
|
changelist = int(sys.argv[1]) # type: int
|
|
|
|
changeroot = sys.argv[2] # type: str
|
2013-12-05 14:54:17 -05:00
|
|
|
except IndexError:
|
2015-11-01 11:11:06 -05:00
|
|
|
print("Wrong number of arguments.\n\n", end=' ', file=sys.stderr)
|
|
|
|
print(__doc__, file=sys.stderr)
|
2013-12-05 14:54:17 -05:00
|
|
|
sys.exit(-1)
|
|
|
|
except ValueError:
|
2015-11-01 11:11:06 -05:00
|
|
|
print("First argument must be an integer.\n\n", end=' ', file=sys.stderr)
|
|
|
|
print(__doc__, file=sys.stderr)
|
2013-12-05 14:54:17 -05:00
|
|
|
sys.exit(-1)
|
|
|
|
|
2016-12-29 06:34:27 -05:00
|
|
|
metadata = git_p4.p4_describe(changelist) # type: Dict[str, str]
|
2013-12-05 14:54:17 -05:00
|
|
|
|
2021-05-28 05:03:46 -04:00
|
|
|
destination = config.commit_notice_destination(
|
|
|
|
changeroot, changelist
|
|
|
|
) # type: Optional[Dict[str, str]]
|
2017-06-19 07:39:13 -04:00
|
|
|
|
2013-12-05 14:54:17 -05:00
|
|
|
if destination is None:
|
|
|
|
# Don't forward the notice anywhere
|
|
|
|
sys.exit(0)
|
|
|
|
|
2017-06-19 07:39:13 -04:00
|
|
|
ignore_missing_stream = None
|
|
|
|
if hasattr(config, "ZULIP_IGNORE_MISSING_STREAM"):
|
|
|
|
ignore_missing_stream = config.ZULIP_IGNORE_MISSING_STREAM
|
|
|
|
|
|
|
|
if ignore_missing_stream:
|
|
|
|
# Check if the destination stream exists yet
|
|
|
|
stream_state = client.get_stream_id(destination["stream"])
|
|
|
|
if stream_state["result"] == "error":
|
|
|
|
# Silently discard the message
|
|
|
|
sys.exit(0)
|
|
|
|
|
2017-06-19 07:39:07 -04:00
|
|
|
change = metadata["change"]
|
|
|
|
p4web = None
|
|
|
|
if hasattr(config, "P4_WEB"):
|
|
|
|
p4web = config.P4_WEB
|
|
|
|
|
|
|
|
if p4web is not None:
|
|
|
|
# linkify the change number
|
|
|
|
change = '[{change}]({p4web}/{change}?ac=10)'.format(p4web=p4web, change=change)
|
|
|
|
|
2017-06-19 07:38:49 -04:00
|
|
|
message = """**{user}** committed revision @{change} to `{path}`.
|
|
|
|
|
|
|
|
```quote
|
|
|
|
{desc}
|
|
|
|
```
|
|
|
|
""".format(
|
2021-05-28 05:03:46 -04:00
|
|
|
user=metadata["user"], change=change, path=changeroot, desc=metadata["desc"]
|
|
|
|
) # type: str
|
2013-12-05 14:54:17 -05:00
|
|
|
|
|
|
|
message_data = {
|
|
|
|
"type": "stream",
|
|
|
|
"to": destination["stream"],
|
|
|
|
"subject": destination["subject"],
|
|
|
|
"content": message,
|
2016-12-29 06:34:27 -05:00
|
|
|
} # type: Dict[str, Any]
|
2013-12-05 14:54:17 -05:00
|
|
|
client.send_message(message_data)
|