Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationEventAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
5
Help us understand the problem. What is going on with this article?

More than 3 years have passed since last update.

@bvlion

Google HomeからWunderlistに音声でタスクを登録する

最近とてもGoogle Homeにハマってます!
家ではRaspberry Piがサーバー代わりに動いているので

  • Google Home自身でYoutubeの音楽を再生するを参考にさせていただき、家で使っているSlackと連携させて音楽を流させたり
  • 音声でエアコンやこたつを操作したり
  • ごはんの記録を取ったり
  • 朝は時報代わりに5分おきに時間を言わせたり
  • 翌日の天気を言わせたり
  • 朝の電車の遅延情報を言わせたり

しています♪

これまでSlackに遅延情報を流したり、エアコンやこたつは自作アプリで操作したりしていましたが、やっぱスマホを手に取るって家では手間なんですよね…
音声でできるってとても素晴らしいです(`・ω・´)

はじめに

前置きが長くなりましたが、今回はタスクを音声で登録したいと思います。
有料でよければRemember The Milk等でもできますが、できたら無料で、かつ上記で紹介したようなサーバーを用いず行いたいと思います。

そこで使うタスクツールはWunderlistです。
Wunderlist自体はまだIFTTTにありませんが、メールでタスクを登録でき、メールアドレスもエイリアス(test@gmail.comがメインアドレスならtest+01@gmail.comとか)で複数登録できるため、この機能を使って自作してみます。
個人的には元々タスク管理にGoogle Keepのリストを使っていたのですが、使い勝手もそれに近い感じがしていてお気に入りです(・∀・)

Wunderlist作業

新しいメールアドレスの追加

まずは以下からエイリアスのメールアドレスを登録します。
https://www.wunderlist.com/account/emails
1アドレスにつき1タスクで関連付けされるので、必要な分だけ登録しましょう。
エイリアスなので、普段使っているGmailに確認メールが届くハズです。
認証して完了です。

タスクとメールアドレスの関連付け

次に登録したメールアドレスとタスクを紐付けます。
https://www.wunderlist.com/account/mailtowunderlist
「行き先…」を変える度にPOSTされるのは仕方ないんかな…

Gmail作業

Gmailにエイリアスを登録

リファレンスにある通り、登録してあれば別のアドレスからGASを使って送信可能になるため、以下の設定を行います。
エイリアスだともしかしたら不要な作業かもしれませんが、試していません。

  1. Gmailの右上、歯車アイコンを押下
  2. 「アカウントとインポート」というタブを選択
  3. 「他のメール アドレスを追加」を押下
  4. 「メール アドレス」の欄にエイリアスのアドレスを入力して「次のステップ」ボタン押下

これで登録完了になります。

SpreadSheet作業

SpreadSheetでは

  1. シートを新規作成
  2. GAS登録
  3. トリガー設定

を行います。

シート作成

何でもいいんですが、IFTTTに登録する際にフォルダと名前が必要になるため
今回は

  • シート名 -> タスク登録
  • フォルダ -> test

として話を進めます。

GAS作成

作ったスプレッドシートに以下のスクリプトを登録します。
スクリプトは「ツール -> スクリプトエディタ…」で開けます。
ツール

コード.gs
var sheet = SpreadsheetApp.getActiveSheet();

function exec() {
  var from = getData(1);
  var task = getData(2);
  mailSend(from, task);
}

function getData(col) {
  var lastrow = sheet.getLastRow();
  return sheet.getRange(lastrow, col).getValue();
}

function mailSend(strFrom, strTitle) {
  var strTo = 'me@wunderlist.com';
  var strSender = 'GAS';
  var strBody = 'GASより登録';

  GmailApp.sendEmail(
    strTo,
    strTitle.replace(/ /g, ''),
    strBody,
    {
      from: strFrom,
      name: strSender
    }
  );
}

ちなみにMailApp.sendEmailという関数もありますが、これではfromが設定できないそうです。
細かいエラーチェックとかはしてないので、そのあたりは適宜お願いします。
あとreplaceですが、Google Homeで送信される値は程よく半角スペースが入るようで、私は気持ち悪いので削除しています。

トリガー設定

このような感じでexecをスプレッドシートの値が変わったら実行されるようにします。
トリガー

IFTTT作業

最後にIFTTTと連携させれば完成です。
今回はサンプルなので、このように登録しましたが、内容は自由でいいと思います。
IFTTT

Formatted rowにあるように、左にタスクと関連付けしたメールアドレスを記入するのがポイントです。
このような感じで、音声でSpreadSheetに行追加するレシピを作ります。
そうすることで上記で登録したスクリプトが値の変更によって発火し、スクリプトがメールを送信してタスクが登録される…という動きをしてくれます。
これをタスク分(メールアドレスと紐付けた分)登録していけば、音声でそれぞれ好きなタスクに登録できるようになります!

余談

ちなみにWunderlist、エンジニアにも優しい設計(?)で、APIがサクッと作れます。
ドキュメントもしっかり整備されているのは好印象ですね。
これを使えばプログラムを組む必要はありますが、まだGoogle Homeに実装されていない音声でのリマインダー登録も可能で、我が家ではとても便利に使っています。

家では恥ずかしがらず、大きな声で「OK、Google」と言って楽をしましょう(*・ω・)ノ

5
Help us understand the problem. What is going on with this article?
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
5
Help us understand the problem. What is going on with this article?