Redmineのチケットの更新時などにMattermostへ書き出すプラグインを日本語化したので使い方を説明する。
スクリーンショットはこんな感じ
Messengerプラグイン
Messenger plugin for Redmine
https://github.com/AlphaNodes/redmine_messenger
AlphaNodesというドイツの会社が作っているらしい、というのがMattermost 3.10のWhat's newに出ていた。Mattermostだけでなく、SlackやRocket.Chatにも書き出せるらしい(そちらは試していない)。既に多言語対応していたのでロケールファイルを日本語化してマージしてもらった。
前提環境
Redmine 3.4.2.stable
Mattermost Team Edition 4.0.0 (4.0.2)
どちらも既に日本語で動いているとする。Mattermostのバージョン表記が4.0.0なのか4.0.2なのかよくわからないが、GitLabに付属してたやつだからだろうか。3.10以降であれば動くと思う(たぶん)。
インストール方法
インストールはいつもの通りコマンドで
cd $REDMINE_ROOT
git clone git://github.com/alphanodes/redmine_messenger.git plugins/redmine_messenger
bundle exec rake redmine:plugins:migrate RAILS_ENV=production
とした後でRedmineを再起動すると有効化される。以下のように[管理]->[プラグイン]にRedmine Messengerが見えていればOK。
設定方法
まずMattermost側の内向きのウェブフックを有効化する。
[システムコンソール]->[カスタム統合機能]の[内向きのウェブフックを有効にする]のところで[有効]を選択して保存する。
次に内向きのウェブフックを作成する。書き出したいチャンネルがあるチームのメニューから[統合機能]->[内向きのウェブフック]をクリックする。
表示名はなんでもよいので適当につける。説明は不要。[チャンネル]で書き出し先のチャンネルを選択し[保存する]
[セットアップが成功しました]と表示されたら[完了]。これでMattermost側の設定は終わり。
続いてRedmine側の設定を行う。
[管理]->[プラグイン]->[Redmine Messenger]の[設定]からデフォルトの設定を入れる。
[メッセンジャーのURL]に先ほど作成した内向きのウェブフックのURLを入れ、[チャンネル]に書き出し先のチャンネルを入れる。([SSL証明書の検証]は環境によっては外す)
(もしdockerなどを使っていて、同じマシンの違うコンテナでRedmineとMattermostが動いている場合、localhostの所はコンテナ名を使うこと。localhostを指定するとコンテナ内の7080番ポートに接続してしまう。)
Mattermost側でチャンネル名が日本語になっている場合でも[チャンネル]は英数字で指定する。該当のチャンネルの[チャンネル情報]を見ると指定すべき文字列が.../channels/の後に見えている。この場合はtest。
ここでデフォルトの設定を入れると、全てのプロジェクトの変更が指定されたチャンネルに書き出される。プロジェクト毎に書き出し先チャンネルを変更したい場合はプロジェクトの設定に[メッセンジャー]タブが増えているのでそこから設定する。(以下参照)
デフォルトの書き出し先を指定せず、かつプロジェクトの設定でも書き出し先を指定しない場合はどこにも書き出されない。この辺りの運用は現場に合わせて調整して欲しい。
動作例
デフォルトではチケットが作成/更新された際にチャンネルへ書き出すようになっている。例えば、下記のようなチケットを作成すると
Mattermost側に以下のように書き出される。
その他(余談など)
Mattermostのウェブフックの説明は下記にある。動作しない場合、下記ページにあるようにcurl
で直接webhookを叩くなどすると問題の切り分けができると思う。上でも書いたがコンテナを使っていると微妙に引っかかりやすい場合もあるので注意。
Incoming Webhooks
https://docs.mattermost.com/developer/webhooks-incoming.html
訳語はIncoming webhookを「内向きのウェブフック」とするなど、MattermostとRedmineの既存の日本語訳に合わせた。Incomingを内向きと訳すのは・・・どうなんだろうか?ちょっと分かりにくい気もするのだがそういうわけなのでご了承されたい。その他でわかりにくい所などあればコメントいただけると修正できるかもしれない。