モチベーション
オンラインミーティングをGoogle Meetでやっているのですが、気づいたら開始時間を過ぎていることがあります(本当によくない) 通知が来たときに開始までに少し時間があるので別な作業をしてしまうパターンが多いです。
時間になったらMeetの画面を自動で開いて、強制的に作業を中断すればそんなことがなくなる気がします。
方針
Googleカレンダーから予定を取得して、時間になったらそのMeetのURLをブラウザで開くようにしたいと思います。
やり方はいろいろあると思います。 Chrome拡張でカレンダーにアクセスする、Calendar APIでスケジュール一覧を取得する、…
今回は諸般の事情でCalendar APIを直接使えなかったため、以下の方針にしました。 OSはMacです。
- Google Apps Script(GAS) でカレンダーから一日のスケジュールをJSONで取得する
- このGASをWebアプリとして公開して、HTTP GETで取得できるようにする
- スケジュールの時刻に
at
コマンドをセットして、open <MeetのURL>
を実行する
ターミナルで at
をセットするのは今のところ手で朝に実行しています。
もっといいやり方がある気はしますが、とりあえずこれでやりたいことは出来ました。 以下、各手順となります。
スケジュール取得GASを作成する
https://script.google.com/home から新しいスクリプトを作成する
GASのCalendar APIを有効化
標準の CalendarApp では取れる情報が少なくMeetのURLがとれないため、Calendar API を使用する
GASのエディタ > サービス > Calendar を有効化
dayjs を使えるようにする
標準の Utilities.formatDate でも日付フォーマットはできるが、もう少し日付をうまく扱うためにライブラリを入れる。 Moment.jsは開発が止まっているので、dayjsを使う。
GASのエディタ > ライブラリを追加 > dayjs のスクリプトID 1ShsRhHc8tgPy5wGOzUvgEhOedJUQD53m-gd8lG2MOgs-dXC_aCZn9lFB
を入力
余談
ライブラリのスクリプトIDを検索する方法がわからない… 仕方なく個人ブログやQiitaから情報を得たけど、公式情報じゃないので気持ち悪い
スクリプトIDのエディタのURLを開くと、たしかにdayjsのコードのよう https://script.google.com/home/projects/1ShsRhHc8tgPy5wGOzUvgEhOedJUQD53m-gd8lG2MOgs-dXC_aCZn9lFB/edit
カレンダーから予定を取得してJSONで返却する実装
Webアプリとして使えるようにするため、doGet
関数をエントリーポイントに実装する
Webアプリとして公開
デプロイ > 新しいデプロイ > 説明を入力してデプロイ > WebアプリのURLを取得
atコマンドを有効化
Macのatコマンドはデフォルトでは無効になっているので有効化する。
Macでatコマンドが実行できないときの対処法 - Qiita MacOS で at コマンドを有効化して使ってみる - Neo’s World
/usr/libexec/atrun
にフルディスクアクセスをつける
ターミナルで予定一覧を取得して、atコマンドで設定
まとめ
毎朝手動でatコマンドを仕込むようにしていて、そこだけは手間だがいまのところこれのおかげで時間になったら作業を止めることができている。
atコマンドはデフォルトで無効になっていて、Macでスケジュール実行のコマンドはlaunchdを使ったほうがいいのではという気がしている。