【Defold】Azure PlayFabを使ってアカウントを作成しログインしてみる

Defold

Defoldでアプリのバックエンド部分を構築する手段のひとつとしてAzure PlayFabが使えるらしいので試してみました。

PlayFabとは

単一のプラットフォームでライブ ゲームを構築して運用できます。PlayFab には、ゲーム サービス、データ分析、LiveOps ツールなど、ローンチまでの時間を短縮し、ゲームの寿命を伸ばして、コストを削減するために必要なものがすべて揃っています。

PlayFab | Microsoft Azure

要するに、自分でDBサーバーやAPIサーバーを用意する必要がなく、ゲームアプリのバックエンド部分を構築できる代物。クライアントの開発に集中できて、サーバー周りのラーニングコストも下げることが出来るため、この様なサービスは積極的に利用していきたいですね。

Defoldで利用する方法

Defold で PlayFab を利用する方法は 折りたたみ用の Lua クイックスタート – PlayFab | Microsoft Docs に詳細が書かれていますが、日本語約がおかしいのかレイアウトが崩れていて読み辛いので、もう少し分かりやすく、ログイン出来るところまで進めます。

前提条件

  • PlayFab のアカウント登録が済ませてあること
  • Defold バージョンは1.2.160
  • 動作は Windows10 で確認

PlayFabプラグインのインポート

前提条件を満たしていれば、次にPlayFabを操作するためのプラグインをGitHubから取得します。

AssetにPlayFabプラグインが取り込まれていればOK。

PlayFab動作確認用のシーンを作成

動作確認用のテキストノードだけが存在する画面を作成します。

  1. main フォルダ以下にguiファイルと gui_script ファイルを作成します。名前はそれぞれ PlayFabGettingStarted.gui, PlayFabGettingStarted. gui_script としています。
  2. PlayFabGettingStarted.gui に PlayFabGettingStarted.gui_script スクリプトを割り当てる。
  3. Nodesにテキストをひとつ追加する。名前はplayfab_textとした。

main.collectionには PlayFabGettingStarted.gui を配置しておきます。

最低限のUIを配置しました。

サーバーへログインする

PlayFabGettingStarted.gui_script を開いてスクリプトを書きます。

local PlayFabClientApi = require("PlayFab.PlayFabClientApi")
local IPlayFabHttps = require("PlayFab.IPlayFabHttps")
local PlayFabHttps_Defold = require("PlayFab.PlayFabHttps_Defold")

-- タイトルID あなたのゲームに合わせて設定してください。
PlayFabClientApi.settings.titleId = "144"
IPlayFabHttps.SetHttp(PlayFabHttps_Defold)


function init(self)
	
	local loginRequest = {
		TitleId = PlayFabClientApi.settings.titleId,
		CustomId = "GettingStartedGuide",
		CreateAccount = true
	}
	
	PlayFabClientApi.LoginWithCustomID(loginRequest, OnLoginSuccess, OnLoginFailed)
end

function OnLoginSuccess(result)
	local pfTestOutput = gui.get_node("playfab_text")
	gui.set_text(pfTestOutput, "Congratulations, you made your first successful API call!")
end

function OnLoginFailed(error)
	local pfTestOutput = gui.get_node("playfab_text")
	local message = "Something went wrong with your first API call.\n"
	local message = message .. "Here's some debug information:\n"
	local message = message .. error.GenerateErrorReport()
	gui.set_text(pfTestOutput, message)
end

コードを実行すると、PlayFabに初めから用意されたサンプルのタイトルIDで動作確認が取れます。「Congratulations, you made your first successful API call!」と表示されれば問題なく動作しています。

タイトルIDの確認

PlayFabClientApi.settings.titleId = "144"

置き換えるタイトルIDはPlayFabのダッシュボードのURLから確認できます。

https://developer.playfab.com/ja-JP/TitleID/dashboard

リクエストするパラメータ

TitleIdを設定した後、CustomIdを割り振ります。CustomIdに設定する値はuuidなどユニークなものを設定する様にします。とりあえずテストするだけなら”1″など放り込んでおけば良いです。

local loginRequest = {
	TitleId = PlayFabClientApi.settings.titleId,
	CustomId = "1",
	CreateAccount = true
}

再度実行してみて、ダッシュボードにユーザーデータが記録されていれば成功です。

お知らせ