FJCT_ニフクラ mobile backend(mBaaS)お役立ちブログ

スマホアプリ開発にニフクラ mobile backend(mBaaS)。アプリ開発に役立つ情報をおとどけ!

GAS SDKでプッシュ通知を作成する

f:id:mbaasdevrel:20200408172048p:plain

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スプレッドシートでデータを管理しながら配信も簡単にできます。ぜひ試してみてください。

中津川 篤司

中津川 篤司

NCMBエヴァンジェリスト。プログラマ、エンジニアとしていくつかの企業で働き、28歳のときに独立。 2004年、まだ情報が少なかったオープンソースソフトの技術ブログ「MOONGIFT」を開設し、毎日情報を発信している。2013年に法人化、ビジネスとエンジニアを結ぶDXエージェンシー「DevRel」活動をスタート。