日本語 | 英語 |
---|
毎週月曜日にオフィスを掃除しますが、掃除当番グループが決まっており、グループは毎週順番に回していきます。 今回作ったのは、今週どのグループが担当なのかを毎週時間になると slack に通知するボットを作成しました。
- Google Account
- Git
- Node/npm
- Google サービス
- Google Apps Script
- Google スプレッドシート
- Google カレンダー
- Slack APIs
- ローカル開発環境
- Google スプレッドシートにマスタデータが格納してあります。
- データを取得して今週アサインされるグループに所属するユーザの slackID を取得します。
- Google calendar API 本日が祝日かどうか調べます。Google が「日本の祝日」を公開しているのでそれを利用しています。
- 本日が月曜日かつ祝日でない場合は、取得したユーザに対してメンションをつけたメッセージをチャンネルへ送信します。
- 最後に、スプレッドシートにデータを保存して処理を終了します。
clasp とは、ローカル環境で Google Apps Script を実行できるプラットフォームです。
公式ドキュメント はこちらをご参照下さい。
# npm パッケージをグローバルインストールします。
$ npm install @google/clasp -g
# ログイン
$ clasp login
# ブラウザが開きどの Google アカウントで認証するか聞かれるので利用するアカウントを選択します。
# 認証に成功したら `~/.clasprc.json` にログイン情報が保存されます。
# ログアウト
$ clasp logout
# プロジェクトを作成
$ clasp create <project name> --rootDir ./src
Create new script https://script.google.com/d/xxxxxxxxxxxxxxxxxxxx
Cloned 1 file.
└─ appsscript.json
# 作成したプロジェクトのエディタをブラウザで開きます。
$ clasp open