BackEnd

GoogleAppsScriptを使ってmBaaSの定期実行処理を実装する

投稿日:2017年11月2日 更新日:

はじめに

最近では主に、Railsでのバックエンドの開発とiOSアプリ開発を行っています。
私はこれまでにmBaaSを利用する機会がありませんでしたが、先日、mBaaSを利用する必要がありましたので調査しました。

簡単な状況説明

今回利用したのはニフティクラウドmobile backendです。
使用したサービスは下記の通りです。

  • データストア
  • ファイルストア
  • スクリプト

どのようなサービスかは名前から察しがつくと思いますが簡単に説明しますと、
データストアはキーバリュー型のNoSQL。
ファイルストアは一般的なストレージ。
スクリプトはJavaScriptをアップロードし、コントロールパネルおよび外部から実行できます。

定期実行を行う方法

mobile backendにはcronのような定期実行機能がありません。
Google Apps Scriptと連携することで任意の処理を定期的に実行することができます。

作業は公式ブログを参考に行いました。
しかし、Google Apps Scriptからmobile backendのJavaScriptSDKがそのまま使えるわけではありません。
mobile backendやGoogle Apps Scriptを初めて触る人にはわかりにくいと思いますので、もう少し噛み砕いて説明します。

実装

実装の流れ

実装の流れは大体下記のようになると思います。

  • 実行したい処理をJavaScriptで実装する
  • 実装したスクリプトをmobile backendのスクリプトにアップロードする
  • コントロールパネルからスクリプトを実行してテストする
  • Google Apps Scriptで実装したスクリプトを実行する処理を実装する
  • Google Apps Scriptから実行してテストする
  • Google Apps Scriptの定期実行を設定する

JavaScriptの実装

公式のドキュメントを参考に実装してください。
ローカルマシンにNode.jsの環境を構築すれば、アップロードしなくてもスクリプトをテストすることができます。
やり方はこちらの中段に記載されています。

スクリプトをアップロードする

コントロールパネルの左のメニューにあるスクリプトからアップロードできます。
ファイルを選択したらメソッドを指定し、ファイルの状態の実行可能にチェックを入れ、新しくパーミッションを作成し、アップロードします。

その後、実行したいスクリプトを選択し、実行タブからテストすることができます。
(アップロードした直後だとデプロイが完了していない旨のエラーが出る場合があります)

Google Apps Scriptからスクリプトを実行する

JavaScriptの実装が完了したら、Google Apps Scriptから実行するようにします。

まず、Googleドライブに新しいスプレッドシートを作成します。
次にスプレッドシートの「ツール」→「スクリプト エディタ」をクリックしてエディタを開きます。
(名前を変更していない場合は、名前を変更するダイアログが表示されます)
mobile backendのスクリプトを実行するためにはライブラリの追加が必要ですので、「リソース」→「ライブラリ」を開きライブラリを追加のテキストボックスに「1yWnb7GfYsBCR-MZvi6r-TOYv_y-AV4le5P7kaG5B3iZ5VNnSk9Q55pSJ」を入力して追加ボタンをおし、バージョンを指定して保存します。

ライブラリを追加したらmobile backendのスクリプトを実行するためのコードを書いて行きます。
例えば、hoge.jsをGETで呼び出すには下記のように記述します。

定期実行の設定を行う

Google Apps Scriptから手動で実行できるようになったら、定期実行の設定を行います。

時計のマークのアイコンをクリックし、表示されたダイアログのリンクをクリックします。
タイマーを設定したら保存をクリックします。
これで定期実行の設定は完了です。

さいごに

mBaaSを初めて使いましたが、コントロールパネルの機能も充実しており、かなり便利だと思いました。
サーバの設定は面倒なので、あまりサーバ側でデータを更新しないアプリなら十分に使えそうです。

blog-page_footer_336




blog-page_footer_336




-BackEnd

執筆者:


comment

メールアドレスが公開されることはありません。

CAPTCHA


関連記事

rails

deviseを使ってユーザ登録フォームを作る

1 はじめに1.1 前提条件2 deviseについて2.1 deviseとは2.2 deviseでできること3 登録処理の実装3.1 Gemのインストール3.2 deviseのインストール3.3 デフ ...

rails

Railsの低レベルキャッシュを使ってみた

1 はじめに1.1 環境2 ドキュメント3 準備3.1 configの確認3.2 キャッシュストア4 使ってみる4.1 #read、#write、#delete4.2 #fetch4.3 オプション4 ...

rails

Railsでの非同期処理とDelayed Job

1 はじめに2 Active Job2.1 Active Jobの役割2.2 ジョブを作成する2.3 ジョブをキューに登録する2.4 コールバック2.5 例外3 Delayed Job3.1 設定3. ...

rails

関連するモデルのレコードを一緒に作成する方法

1 はじめに1.1 前提条件2 実装2.1 モデルの作成2.2 コントローラの作成2.3 Viewの作成3 さいごに はじめに フォームからレコードを作成する際に、関連するモデルのレコードを一緒に作成 ...

Rubyを使ってDialogflowのお勉強

1 はじめに1.1 環境2 とりあえずAPIで叩いてみる2.1 テスト用のIntentを作成2.2 Gemの設定3 Eventについて3.1 WELCOMEイベント3.2 パラメータ付きで叩く3.3 ...

フォロー

follow us in feedly

blog-page_side_responsive

2017年11月
 1234
567891011
12131415161718
19202122232425
2627282930 

アプリ情報

私たちは無料アプリもリリースしています、ぜひご覧ください。 下記のアイコンから無料でダウンロードできます。