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


関連記事

laravel logo

Laradock環境にPHPStormからXdebugする

1 はじめに2 Laradock側の設定変更2.1 xdebug.iniファイル2.2 .env2.3 コンテナの再構築3 PHPStormの設定3.1 Preferences3.1.1 Build, ...

Stripe Connectでダイレクト支払い導入編

1 はじめに2 事前準備3 StripeConnectの導入3.1 stripeパッケージの導入3.2 envの実装4 店舗アカウントの登録4.1 Stripe Connectの設定4.2 Oauth ...

Go言語

Goのfmt.print系関数のまとめ

1 はじめに2 print関数の命名規則3 各print関数の説明3.1 Print(標準出力へ出力)系関数3.2 Sprint(文字列を出力)系関数3.3 Fprint(ファイルへ出力)系関数4 書 ...

rails

configに追記したのに、rails runnerが起動しない?

1 はじめに1.1 環境2 rails runnerを使用してみる2.1 バッチファイルの作成2.2 configにパスを追記2.3 実行3 ところが…3.1 解決方法4 おまけ(runnerコマンド ...

laravel logo

LaravelでHTTP通信

1 はじめに2 インストール3 基本的な使い方3.1 GETでリクエストを投げる3.2 リクエストヘッダーを指定3.3 クエリパラメータを指定3.4 timeout時間を指定3.5 POSTでリクエス ...

フォロー

blog-page_side_responsive

2017年11月
 1234
567891011
12131415161718
19202122232425
2627282930  

アプリ情報

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