Google Apps Scriptがβ版としてv8対応しています。v8版にすると、実行速度が向上するほか、constやasync/awaitといったモダンなJavaScriptで書けるようになります。
しかし、従来のGoogle Apps Script SDKは動作しなくなります。 ReferenceError: User is not defined
というエラーメッセージが出るようになります。対応を試みたのですが、うまくいきませんでした。
そこで、よりモダンな書き方でv8対応版としてGoogle Apps Script SDKを作り直しています。今回はプッシュ通知の作成方法について解説します。なお、今回のコードは旧版でも利用できます。
コードについて
コードはNCMBMania/ncmb_gas: Google Apps Script(v8対応版)のコードです。にアップロードしてあります。TypeScriptで書かれています。
コードは google/clasp: 🔗 Command Line Apps Script Projects を使ってGoogle Apps Script用のコードに変換しています。
使い方
スクリプトのIDは 1Z8Lezd0OS6qm9W0EVQxBGx1gztqD14kXPfQxycr_rc2atOfKujiWZe7I
になります。基本的に最新版を使うようにしてください。
初期化
以下はプリフィックスをNCMBとした場合のコードです。
const ncmb = NCMB.init('APPLICATION_KEY', 'CLIENT_KEY');
プッシュ通知の作成法
プッシュ通知を作成する際には new ncmb.Push
を使ってください。後はJavaScript SDKと変わらず利用できます。
const push = new ncmb.Push(); push .set("immediateDeliveryFlag", true) .set("message", "Hello, World!") .set("target", ["ios", "android"]) .save();
プッシュ通知の検索
プッシュ通知を検索する場合は ncmb.Push.query()
でクエリオブジェクトが返ってきます。それを使ってデータストア同様に条件の指定が可能です。
const query = ncmb.Push.query(); const pushes = query.fetchAll(); Logger.log(pushes);
まとめ
まだ機能は多くありませんが、旧版程度の機能まではすぐに実装していきます。v8版はJavaScriptがより書きやすくなっていますので、ぜひ移行してみてください。
プッシュ通知の作成ができれば、Googleスプレッドシートでデータを管理しながら配信も簡単にできます。ぜひ試してみてください。