我对Slack很陌生。我创建了一个团队,并添加了与我们的 SVN 存储库的集成。我已经设置了一个“提交后”脚本,并且在预期的 Slack 频道中收到了通知。就目前而言,一切都很好。
我想自定义松弛频道中的通知,但我失败了。
提交后脚本是基于 Perl 的;有许多模板可用。我使用了一个并添加了一行来包含因此更改的文件:
my $files = `/usr/bin/svnlook changed -r $ARGV[1] $ARGV[0]`;
my $date = `/usr/bin/svnlook date -r $ARGV[1] $ARGV[0]`;
my $log = `/usr/bin/svnlook log -r $ARGV[1] $ARGV[0]`;
my $who = `/usr/bin/svnlook author -r $ARGV[1] $ARGV[0]`;
chomp $who;
my $payload = {
'revision' => $ARGV[1],
'date' => $date,
'author' => $who,
'log' => $log,
'files' => $files,
};
my $ua = LWP::UserAgent->new;
$ua->timeout(15);
my $req = POST( "https://${opt_domain}/services/hooks/subversion?token=${opt_token}", ['payload' => encode_json($payload)] );
我在 Slack 频道中收到的唯一消息是以下形式:
<rev number>:<author>-<log message>
我不知道为什么我没有得到日期,并且更改的文件列表出现在 Slack 消息中。相关的 svnlook 命令在服务器上手动运行时会产生预期的结果。如果我将脚本的相关位更改为:
my $payload = {
'wibble' => $ARGV[1],
'date' => $date,
'author' => $who,
'log' => $log,
'files' => $files,
};
然后手动调用钩子
post-commit /var/svn/repo 5966
(例如)我得到的输出包括:
payload=%7B%22wibble%22%3A%225966%22
(如我所料/希望的那样),但后来
Response:
HTTP/1.1 500 Server Error
Connection: close
...
X-Cache: Error from cloudfront
X-Frame-Options: SAMEORIGIN
invalid_payload
我天真地期望有效负载指定消息,因此您可以制作如下消息:
revision: 5696
date: 2016/03/14 12:00:00
author: ...
log: <log text>
files: myfile.c, myfile.h
在上面的例子中,我想知道我是否会得到
wibble: 5696
所以,我不得不得出结论,Slack 端的某些东西只需要接收到的JSON中的某些字段,然后根据某些规则将它们格式化为通道消息。我发现不知道哪些字段是可接受的,以及如何对格式进行一些控制。例如,我没有收到有关无效负载的错误的事实表明日期和文件字段名称是有效的,但是如何让它们出现在 Slack 消息中?