29
27

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

ゴミ出しをGASとLINE Botで定期通知し母親に親孝行する

Last updated at Posted at 2020-11-06

問題定義

ゴミ出しは第n水曜日などと分かりにくい曜日設定であり、
かつ、ゴミの種類によりゴミの置き場などが異なる。
これにより、ゴミ出しの役割が母親に属人化しがちである。

一方、母親は家事や子育てや仕事で忙しい。
そして、ゴミ出しを覚えてなければならないストレス
忘れたときのストレスなど精神的な負担も大きい。

大学生のボクは、母親に最初で最後の親孝行をすることにした。

解決策

こうした負担を減らすために、ゴミ捨ての日時と置き場所を
家族のグループLINEに自動的に通知し、ゴミ捨て役割の分担を促すような
LINE Botの仕組み作りをする。

使用技術

・Google Apps Script
・LINE Messaging API

期待できる効果

・ゴミ捨てのユーザー体験が改善され、母親の負担が減り、家庭がより明るくなる
・LINE Messaging APIの仕様について学べる
・Google Apps Scriptの定期実行の仕組みを学べる
・現実世界の向上にテクノロジーが役立つことを実感できる

手順

1.LINE公式アカウントの作成

LNE公式アカウントの未認証アカウントを開設する
https://www.linebiz.com/jp/entry/

LINE Official Account Managerにログイン
https://manager.line.biz/

2.LINE Messaging APIの初期化

まず、LINE Official Account Managerの右上の「設定」を押します

次にMessaging APIの項目に移動します 「Messaging APIを利用する」を押して初期化完了。

3.LINE Botの応答のデフォルト設定の変更

次にLINE Official Account Managerで以下を無効にする。
・友達追加メッセージ
・応答メッセージ
これで家族グループにデフォルトメッセージが行かないようになる

また、「設定」→「アカウント設定」→「チャット」より、グループチャットへの参加を有効化する。

これを設定しないと、グループにLINE Botを招待しても参加ない。

4.LINE Botと家族を入れるグループの作成

家族とLINE Botが入ったLINEグループを作成

5.グループIDの特定

LINE Messaging APIではグループにメッセージを送るコードを書く前に、
全てのグループに一意に紐づけられているグループIDを特定する作業が必要。

以下のサイトの手順でするのが最も簡単。
(理由は、最後の「付録」のセクションで後述)
https://cyuraharuto.com/gas-line-gid-get/
Google Sheetsでシートを作成し、
「ツール」→「スクリプトエディタ」
からGASのプロジェクトを作成し、上記のWEBサイトに従う。
ここでのポイントは、Google Drive経由で作成するのではなく、Google Sheets経由で作成する点。

5-Tips1 グループID確認用のGASプロジェクトの初期化

webhook用URLの作成時に注意する点を補足する。
上記のWEBサイトに従い、グループID確認用のプロジェクトを作成した後は
「公開」→"Anyone, even anonymous"により権限を設定。

次に"Deploy"し、次の画面で出るURLをコピーする。
これがwebhookでの設定で用いるURLである。

ちなみにwebhookの関わるGASのプロジェクトを編集する場合は
GASのコードの更新ごとにバージョンをNewにする作業を毎回行う。

そうしなければ、LINE Botに変更が反映されない!

5-Tips2 webhookの設定

LINE Developers Consoleで、LINE公式アカウントのwebhookを有効にする。

この時点で該当するライングループにメッセージを送信すると
瞬時に、Google SheetにグループIDが表示される。これをコピペする。

6.メッセージ自動送信用のGASプロジェクトの実装

メッセージ自動送信用のGASのプロジェクトを以下に従い作成。

以下では、個人情報保護の観点から一部内容を変更している箇所有り!


// 与えられたDateオブジェクトのインスタンスの時刻が第n何曜日であるかを返す
function getDayCount(date) {
    return Math.floor((date.getDate() - 1) / 7) + 1;
}
// -> http://snowsunny.hatenablog.com/entry/2014/01/18/214751
// を参考にさせていただいました

// 指定のごみ収集曜日の前日の通知のためにトリガーする関数
function notifyTheNightBefore() {
    // LINE Messaging APIの利用のための下準備
    var ACCESS_TOKEN = 'ここにアクセストークンを入力';
    var url = 'https://api.line.me/v2/bot/message/push';
    var groupID = 'ここにグループIDを入力';
    // メッセージ本文を格納する変数
    var body = '';

    // Dateオブジェクト関連の処理の準備
    var date = new Date();
    // 特定の曜日の前日に通知するために、Dateオブジェクトのインスタンスdateの日時を1日早める
    date.setDate(date.getDate() + 1);
    var dayIndex = date.getDay()
    var day = ["", "", "", "", "", "", ""][dayIndex];


    //--ゴミ出しの曜日のパターンと前日に送信するメッセージの定義--//
    //   火曜日・金曜日 ペットボトル
    if (day == '') {
        body += '明日金曜日はペットボトルの収集日です。準備はOKですか?'
    } else if (day == '') {
        body += '明日火曜日はペットボトルの収集日です。準備はOKですか?'
    }
    //   月曜日 缶・びん
    if (day == '') {
        body += '明日月曜日は缶・びんの収集日です。準備はOKですか?';
    }
    //   1・3回目木曜日 プラ容器包装
    var is1stThur = (day == '') && (getDayCount(date) == 1)
    var is3rdThur = (day == '') && (getDayCount(date) == 3)
    if (is1stThur || is3rdThur) {
        body += '明日はプラ容器包装の収集日です。準備はOKですか?'
    }
    //   2・4回目木曜日 生活ゴミ
    var is2ndThur = (day == '') && (getDayCount(date) == 2)
    var is4thThur = (day == '') && (getDayCount(date) == 4)
    if (is2ndThur || is4thThur) {
        body += '明日は生活ゴミの収集日です。準備はOKですか?'
    }


    //LINE Messaging APIでの実際のグループへのメッセージ送信処理
    //現在時刻から見た明日が、何もゴミ出し日に該当しなければ、メッセージは送信されない。
    if ((day == '') || (day == '') || is1stThur || is3rdThur || is2ndThur || is4thThur) {

        UrlFetchApp.fetch(url, {
            'headers': {
                'Content-Type': 'application/json; charset=UTF-8',
                'Authorization': 'Bearer ' + ACCESS_TOKEN,
            },
            'method': 'POST',
            'payload': JSON.stringify({
                'to': groupID,
                'messages': [{
                    'type': 'text',
                    'text': body,
                }]
            })
        })
    }
}


送信部分は以下を参照しました
https://cyuraharuto.com/gas-line-sendmessage/

7.GASでの関数の定期実行を設定する

上述のコードのnotifyTheNightBefore()は
前日に明日がゴミ出しの日であればメッセージを送信する関数。
この内部には実行時の時点の翌日の曜日判定が既に含まれている。
なので、この関数を毎日夜の8時に実行すれば、所望の機能が実現できる。

まず、以下の定期実行の設定ボタンをクリック。

「トリガーを追加」を押し、以下のトリガーを設定する。

実際の運用報告

あるゴミ出しの前日にGASが自動的に家族グループに送った内容はこちらです。
母からは「もちろん」との返信が帰ってきました。
Screenshot_20201106-073740_1.jpg

母の感想

収集日を覚えていなければならないというストレスから解消された
おかげでゴミ出しを忘れることはなくなるだろう
と今晩の夕食では語っていました。

今後の展望

母は最近膝を一時的に痛めているので、ゴミ出しは結構な負担です。
また、リハビリをする必要があるので、ゴミ出しを初めいろいろな家事に時間がかけられません。

今回のシステムでは次のようないい循環が生まれるのではないかと予測しています。
家族グループでゴミ出し情報が共有されることで
他の家族メンバーがゴミ出しをするきっかけにもつながりうる

さて、このシステムを、例えば、ゴミ出しだけでなく、他の定期的に必要な家事労働にも応用し、
家事の負担や実行時間を家族全員で最適化することで、家族は幸せになることができるのではないでしょうか。
このため、いろいろな方法を模索していこうと思います。

付録

webhookが絡むGASプロジェクトでコンソールを使うのは面倒

グループIDの出力をLogger.log or console.logを用いて行おうとしたが
思うようなデバッグができなかった。

結論から言うと、webhookで呼ばれる関数のログは上述の簡単に確認できない

「表示」→「ログ」や「表示」→Stackdriver Loggingなどでログが見れると思ったが、
・GASのログはウェブアプリからのログを表示できない
・Stackdriver Loggingはウェブアプリの場合、ログの詳細を簡単に確認できない
Google Cloud Platformのプロジェクト設定が面倒
ということが判明しました。
(StackOverFlow: https://stackoverflow.com/questions/60140757/why-cant-i-view-stackdriver-logs-for-web-apps-in-google-apps-script )

ですので、本記事で取得したグループIDを見るために、Google Sheetsを使っていたのは
このような手間を省いて、なるべく簡単にグループIDを手に入れるためだったというわけです。

29
27
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
29
27

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?