イベント
Understand how the Scheduler service and Unity Gaming Services produce events that Triggers service processes.
読み終わるまでの所要時間 3 分最終更新 23日前
Scheduler サービスと Unity Gaming Services ではイベントが生成されます。イベントは、Triggers サービスに送信されます。そこでイベントは設定と照合され、対応する Cloud Code スクリプトまたはモジュールが実行されます。
発行されるイベント
Scheduler サービスと Unity Gaming Services は、トリガーを関連付けるイベントを発行します。発行元 | カスタマイズ可能 | イベントペイロード | 発行対象 | ユースケース |
|---|---|---|---|---|
| Unity Gaming Services | いいえ | イベント固有のペイロードとバージョン管理で事前定義 | プレイヤーまたはゲーム状態の変更 | ゲーム内またはプレイヤーの状態変更に反応して、Cloud Code スクリプトまたはモジュールをトリガーする際に UGS によって発行されるイベントを使用します。 |
| Scheduler サービス | はい | スケジュール設定でユーザーが作成 | ユーザー定義の設定時刻または反復的な瞬間 | Cloud Code スクリプトまたはモジュールがいつトリガーされるかを制御する場合に Scheduler サービスによって発行されるイベントを使用します。 |
配信セマンティクス
デフォルトでは、イベントは at-least-once 配信セマンティクスを持ちます。これは、すべてのイベントが 1 回処理されることが保証されるものの、ネットワークの問題発生時に複数回処理される可能性があることを意味します。これを回避するための推奨されるベストプラクティスは、冪等性のある Cloud Code スクリプトおよびモジュールを作成することです。イベントの構造
すべてのイベントには、イベントタイプ、ペイロードバージョンが含まれ、ペイロードを搬送します。フィールド | 説明 | 例 |
|---|---|---|
| イベントタイプは、発行サービス、イベント名、およびペイロードバージョンを含む文字列です。イベントタイプは、アソシエーションを作成するトリガー設定でも使用されます。 | |
| ペイロードバージョンは、ペイロードのバージョンを示す整数です。 | 1 |
| ペイロードは、イベントデータを含む文字列です。Cloud Code にスクリプトまたはモジュールパラメーターとして渡されます。 | |
イベントタイプ | 発行元 | ペイロードバージョン | ペイロード |
|---|---|---|---|
| Scheduler サービス | 1 | ユーザー定義 |
| 認証サービス | 1 | 事前定義 |
| 認証サービス | 1 | 事前定義 |
| Cloud Save サービス | 1 | 事前定義 |
| Leaderboards サービス | 1 | 事前定義 |
| Leaderboards サービス | 1 | 事前定義 |
ペイロードバージョン管理
ペイロードバージョン管理は、破壊的変更の回避に役立ちます。すべてのイベントに、イベントペイロードのペイロードバージョン管理が含まれます。 例えば、com.unity.services.player-auth.signed-up.v11スケジュールされたイベントのペイロード
Scheduler サービスによって発行されたイベントには、カスタマイズ可能なペイロードがあります。ペイロードは、スケジュール設定で定義されます。 例えば、スケジュールされたイベントのペイロードに新しいフィールドを追加する場合は、ペイロードの新しいバージョンを作成し、ペイロードの新しいバージョンを使用するようにトリガーを作成できます。 スケジュール設定では以下のようになります。上記のサンプルの結果は{"name" : "recurring-schedule","eventName": "example-event","type": "recurring","schedule": "0 0 * * *","payloadVersion": 1,"payload": "{\"someBoolean\": true, \"someString\": \"something\"}"}
com.unity.services.scheduler.example-event.v1イベントのペイロードに新しいフィールドを追加する場合は、ペイロードの新しいバージョンを作成し、ペイロードの新しいバージョンを使用するようにトリガーを作成できます。{"name" : "example-trigger","eventType" : "com.unity.services.scheduler.example-event.v1","actionUrn" : "urn:ugs:cloud-code:my-script","actionType" : "cloud-code"}
この結果は{"name" : "recurring-schedule","eventName": "example-event","type": "recurring","schedule": "0 0 * * *","payloadVersion": 2,"payload": "{\"someBoolean\": true, \"someString\": \"something\", \"someNewField\": \"something else\"}"}
com.unity.services.scheduler.example-event.v2スケジュールされたイベント
スケジュールされたイベントを発行するには、スケジュール設定を作成する必要があります。詳細については、イベントのスケジュール を参照してください。 スケジュール設定をデプロイすることにより、設定した時刻または反復的な瞬間に発行されるイベントを作成できます。 以下は、スケジュール設定のサンプルです。{"name" : "example-schedule","eventName": "example-event","type": "recurring","schedule": "0 0 * * *","payloadVersion": 1,"payload": "{\"someBoolean\": true, \"someString\": \"something\"}"}
- : スケジュールの名前。プロジェクトごとに一意である必要があります。
name - : イベントのプロジェクトスコープ名。トリガーのイベントタイプを構成するために使用されます。
eventName - : スケジュールのタイプ。
typeまたはone-timeである必要があります。recurring - : イベントがいつ発生する必要があるかを指定します。
scheduleフィールドに応じて、タイムスタンプまたは cron 式である必要があります。type - : ペイロードのバージョンを示す整数。トリガーのイベントタイプを構成するために使用されます。
payloadVersion - : パラメーターを Cloud Code スクリプトまたはモジュールに転送するためにイベントペイロードとして使用される
payloadオブジェクト。JSON
1 回限りのスケジュール
1 回限りのスケジュールは、特定の時刻に実行される単一のイベントです。以下のようになります。{"name" : "one-time-schedule","eventName": "example-event","type": "one-time","schedule": "2020-01-01T00:00:00Z","payloadVersion": 1,"payload": "{\"someBoolean\": true, \"someString\": \"something\"}"}
schedule反復的なスケジュール
反復的なスケジュールは、特定の時間間隔で実行される一連のイベントです。以下のようになります。{"name" : "recurring-schedule","eventName": "example-event","type": "recurring","schedule": "0 0 * * *","payloadVersion": 1,"payload": "{\"someBoolean\": true, \"someString\": \"something\"}"}
schedule