Qiita Team API と Google Spread Sheet でチーム日報を生成する


チーム日報を活用する

MarketOne 開発チームでは複数拠点に分かれての開発を行っています。リモート開発が中心となると口頭でのコミュニケーションに限界があるため、テキストベースのコミュニケーションの比重が高い状態にあります。

チケットシステムやソースコード管理ツール上の議論はもちろんおこなっているのですが、日報や議事メモによるインフォーマルな情報共有についても日々の進捗や課題の可視化に役立つため、 Qiita Team にそれらの文章を公開してもらうようにしています。Qiita Team では Markdown 形式でリッチな HTML をプレビューしながら書くことができます。

これらの文章は個々に探していけば読めるのではあるのですが、前日に行われた MarketOne チーム全体の進捗を俯瞰で共有しながら朝会を行うために、「チーム日報」という形でまとめることを考えました。チーム日報をまとめるために毎回手動でコピペしてくるのも面倒ですし、非生産的です。Qiita Team にはAPIが公開されているため、こちらを利用して個々の日報を取得するようにしてみました。

Qiita Team API を利用する

Qiita Team APIの仕様はこちらに公開されています(※現在はv2まで公開)。

まずは「設定」 → 「アプリケーション」からアクセストークンを生成します。OAuth認証などの仕組みも用意されているため、作成するアプリケーションに応じて適切な認証が利用できます。

Google Spread Sheet でプログラミング

今回はGoogle Spread Sheet 上に Markdown 形式でチーム日報を生成するようにします。Google Spread Sheet には Google App Script と呼ばれるサーバーサイドの JavaScript が用意されており、APIから取得した結果を成形しながらスプレッドシートに反映することができます。

Google Spread Sheet 上の「ツール」→「スクリプトエディタ」から Google App Script を起動します。

Google Spread Sheet で Qiita API を使ってみる

まずは API を利用するための関数を作成しましょう。

http ヘッダに Authorization  Bearer {api_token}をセットすることで認証を行い、指定したリソースにクエリを発行してレスポンスを取得します。

チームの日報を取得する関数を作成

いよいよ Qiita Team からMarketOneに関係する日報を取得します。Qiitaチームでエントリを取得するには以下のリクエストを行います。

{api_endpoind}/items?query={検索条件}&sort={ソート項目}

今回ほしい条件は、 MarketOneチームのメンバー AND タグに「日報」を設定 AND 1日前のエントリ です。これをクエリストリングで表現すると以下の通りとなります。

user:{ユーザー名1} tag:日報 created:>-1d OR user:{ユーザー名2} tag:日報 created:>-1d

()による優先順位制御が行えれば、 tag:日報 と created:>-1d は一回でよいのですが、Qiita Team API では優先順位制御が行えないため、すべてのユーザーに対してこれらのAND条件を付与しています。またグループメンバーを取得するAPIもないため、get_group_members は単純な該当するユーザー名配列をそのまま返すようにしています。

検索条件では前日の日報を絞り込みこめなかったため、タイトルの正規表現でさらにフィルタしたJSONを生成します。

JSON を Google Spread Sheet に反映

つづいて指定したカラム名の配列で Markedown 形式でテーブルを表現する文字列を生成する関数を実装します。

そして、生成した JSON から以下のように任意の情報を取得して成形することで前日分の日報をサマリしたチーム日報を生成することができます。

 

さらに本文からMarkedownの「本日の作業内容」段落を取得します