デジタル配信ソリューション
概要
デジタル配信ソリューション — ゲーム開発者と、ゲーム、仮想アイテム、仮想通貨及びバンドルの配信のための独自のプラットフォームやエコシステムを持つ複数の配信パートナーとをつなぐソリューションです。
配信パートナー — ゲームとゲーム内アイテムを配信し、独自のストアフロントと請求を行うことができるデジタルプラットフォームまたはエコシステム。エクソーラの販売パートナーの例:
- 複数のサービスをバンドルするスーパーアプリ
- バンキングアプリケーション
- 通信&インターネットサービスプロバイダー
- キャッシュキオスク
- キャッシュバックおよびリワードプログラムプロバイダー
- ECマーケットプレイス
ゲーム開発者側のメリット:
- 急成長している配信パートナーと直結し、ゲームのオーディエンスを拡大します。
- ユニークなユーザー層を持つ新たな配信チャンネルにゲームを追加することで、収益を拡大します。
- 広告やバナーを通じて、サードパーティプラットフォームにおけるオーガニックな発見力を高めます。
配信パートナー側のメリット:
- ゲームコンテンツへのアクセス拡大によるユーザーのロイヤリティ向上します。ユーザーは、アプリやサービスから直接ゲームキー、仮想アイテム、仮想通貨及びバンドルを購入することができるようになります。
- ゲーム業界の人気の高まりを通じて、現在のユーザーを維持し、新しいユーザーを引き付けています。
- ゲーム産業市場の大手パブリッシャーからのゲームキー、仮想アイテム、仮想通貨の販売手数料による収入を増加します。
どのように動作するか
ゲームキー購入時のユーザーフロー
仮想アイテムや仮想通貨を購入する際のユーザーフロー
統合フロー
- ゲーム開発者は、パブリッシャーアカウントでプロジェクトを作成し、ゲームキー、仮想アイテム、仮想通貨、およびバンドルをアップロードします。
- 配信パートナーは次のユーザーデータをリクエストします:
- ゲームを販売する場合 — キーとレシートが送信されるユーザーのメールアドレス
- ゲーム内アイテムを販売する場合 — ゲーム内IDアイテムが追加されるユーザー、および領収書の送信先となるユーザーのメールアドレス
- ユーザーは、配信パートナーインターフェイスに次のデータを入力します:
- ゲーム購入の場合 — キーと領収書を受け取るためのメールアドレス
- ゲーム内アイテムの購入の場合 — アイテムをインベントリに追加するためのゲーム内IDと領収書を受け取るためのメールアドレス
- 配信パートナーはユーザートークンを作成するメソッドを呼び出し、メールアドレス(必須)とユーザーID(仮想アイテム、仮想通貨、バンドルの販売時に必須です)をパラメータとして渡します。
- エクソーラは、ゲーム開発者がウェブフックを設定している場合、ユーザーがゲーム内に存在するかどうかをチェックします。ウェブフックの設定は、仮想アイテムや仮想通貨の販売では必須ですが、ゲームキーでは任意です。
- エクソーラはユーザーデータでトークンを作成し、そのトークンを配信パートナーに送信します。
- 配信パートナーは、ゲームカタログまたはゲーム内アイテムカタログをリクエストします。
- エクソーラは、要求されたカタログを応答で返します。
- 配信パートナーはカタログを受け取り、ユーザーに表示します。
- ユーザーが購入を行います。配信パートナーはカートを作成します。
- 配信パートナーは、ユーザーのカートを送信して注文を作成します。
- エクソーラは、注文IDと割引や税金を含むカート価格を返します。
- 配信パートナーは、カートの合計金額をユーザーに表示します。
- ユーザーが支払いを続行した場合、配信パートナーはユーザーの資金を引き落とし、決済ステータスのページを表示します。
- 販売パートナーはエクソーラに注文の支払いが完了したことを通知し、決済情報を送信します。
- エクソーラはゲーム開発者に購入を通知します。
- ゲームを購入したユーザーは、購入の詳細が記載された電子メールを受信し、ゲームキーを有効にすることができます。ユーザーが仮想アイテムや仮想通貨を購入した場合、それはインベントリに追加されます。
ゲーム開発者側での統合
デジタル配信ソリューションの接続方法
配信チャネルを通じてゲームを宣伝するには:
- パブリッシャーアカウントでストアを接続して以下のことをダウンロードします:
- ウェブフックをセットアップします。
- プロジェクトのデジタル配信ソリューションをアクティブ化するには、カスタマーサクセスマネージャーに連絡するか、csm@xsolla.comにメールを送信てください。
ウェブフックをセットアップする方法
以下の場合、ウェブフックのセットアップは必須です:
- ユーザーを検証し、ゲーム内のユーザーIDによってカタログをパーソナライズする
- ユーザーを検証し、購入したゲーム内アイテムをインベントリに追加する
- エクソーラ側のトランザクションIDとゲーム開発者側のシステムのトランザクションIDをリンクする
- 注文で追加ユーザーパラメータを渡す
- 購入通知を受信する
ウェブフックを設定にするには:
- パブリッシャーアカウントでプロジェクトを開きます。
- プロジェクト設定 > ウェブフックセクションに移動します。
- ウェブフックトグルをオンにします。
- ウェブフックURLを指定します。
- プロジェクトのウェブフックに署名するための秘密鍵は、デフォルトで生成されます。新しい秘密鍵を生成する場合は、更新アイコンをクリックします。
- 「設定を保存」をクリックします。
ユーザー検証
エクソーラはユーザー検証ウェブフックを送信し、ユーザーがゲーム内に存在することを検証します。ユーザー検証では、以下のことが可能です:
- 応答にユーザー属性を渡すと、そのユーザー用にパーソナライズされたカタログを表示する。
- 購入後、ユーザーのインベントリにアイテムを追加する。
ウェブフックの受信を確認するには、サーバーは以下の情報を返す必要があります:
- ゲーム内にユーザーが存在する場合、メッセージボディのないHTTPコード204が表示されます。
- 指定されたユーザーが見つからないか、無効な署名が渡された場合、問題を説明するHTTPコード400が表示されます。
ウェブフックの全リストと仕組みは、例を含めてAPIリファレンスで詳しく説明されています。
応答として、custom_parameters
オブジェクトで追加の取引パラメータを渡すことができます。
- json
1{
2"$schema": "http://json-schema.org/draft-04/schema#",
3"type": "object",
4"additionalProperties": false,
5"properties": {
6 "user_attributes": {
7 "type": "object",
8 "required": false,
9 "minProperties": 1,
10 "maxProperties": 100,
11 "patternProperties": {
12 "^[\\w-_.]{1,255}$": {
13 "oneOf": [
14 {
15 "type": "integer"
16 },
17 {
18 "type": "string",
19 "minLength": 1,
20 "maxLength": 255
21 },
22 {
23 "type": "array",
24 "items": {
25 "type": "string",
26 "maxLength": 255
27 },
28 "minItems": 1,
29 "maxItems": 1000
30 }
31 ]
32 }
33 },
34 "additionalProperties": false
35 }
36}
37}
応答の例:
- json
1{
2 "user_attributes": {
3 "age": 18,
4 "level": 1,
5 "game": "WoW",
6 "is_baned": false,
7 "registration_date": "2022-01-01"
8 }
9}
トランザクションのID連携
external ID(システム上のトランザクションID)を使用していて、エクソーラ側でトランザクションIDと関連付けたり、追加のトランザクションパラメータを渡したい場合は、以下のウェブフック処理を実装します:- json
1{
2 "$schema": "http://json-schema.org/draft-07/schema#",
3 "type": "object",
4 "additionalProperties": false,
5 "properties": {
6 "notification_type": {
7 "type": "string"
8 },
9 "order_id": {
10 "type": "integer"
11 },
12 "project_id": {
13 "type": "integer"
14 },
15 "user": {
16 "type": "object",
17 "properties": {
18 "external_id": {
19 "type": "string"
20 },
21 "email": {
22 "type": "string"
23 }
24 }
25 },
26 "items": {
27 "type": "array",
28 "items": {
29 "type": "object",
30 "properties": {
31 "item_id": {
32 "type": "integer"
33 },
34 "sku": {
35 "type": "string"
36 },
37 "quantity": {
38 "type": "integer"
39 },
40 "type": {
41 "type": "string"
42 }
43 }
44 }
45 }
46 }
47}
リクエストの例:
- json
1{
2 "notification_type": "create_external_transaction",
3 "order_id": 1,
4 "project_id": 51336,
5 "user": {
6 "external_id": "user_id",
7 "email": "public_email@test.com"
8 },
9 "items": [
10 {
11 "item_id": 101,
12 "sku": "mithril_dagger",
13 "quantity": 2,
14 "type": "virtual_good"
15 }
16 ]
17}
応答として、custom_parameters
オブジェクトで追加の取引パラメータを渡すことができます。
予期された応答:
- json
1{
2 "id": "validation_transaction_info_response.json",
3 "$schema": "http://json-schema.org/draft-07/schema#",
4 "description": "DDH Project Transaction Info Response",
5 "type": "object",
6 "additionalProperties": true,
7 "properties": {
8 "id": {
9 "type": "string",
10 "minLength": 1
11 },
12 "custom_parameters": {
13 "type": "object",
14 "additionalProperties": true,
15 "minProperties": 1,
16 "maxProperties": 200
17 }
18 }
19}
応答の例:
- json
1{
2 "id":"123"
3}
トランザクションIDを連携するためのウェブフックパラメータのリスト:
パラメータ | 種類 | 説明文 |
---|---|---|
notification_type | string | 通知の種類。 |
order_id | integer | 注文ID。 |
project_id | integer | ゲームキー、ゲームキーバンドル、ゲーム内アイテム、ゲーム内アイテムバンドルがロードされるプロジェクトのID。 |
user.external_id | string | ゲーム開発者側のユーザーID。 |
items | string | ユーザーが購入したアイテムのリスト。 |
items.sku | string | アイテムの一意の識別子。 |
items.quantity | integer | アイテムの数量。 |
items.type | string | アイテムタイプ。virtual_good 、virtual_currency 、physical_good 、unit の値を受け付けます。unit タイプはゲームに使用されます。 |
items.unit_items | array | ゲームデータの配列。 |
items.unit_items.type | string | ゲームキーパッケージのアイテムタイプ。game_key の値を受け取ります。 |
items.unit_items.sku | string | ゲームキーパッケージの一意の識別子。特定のプラットフォームのゲームの場合、値はsku_drm 形式となります。Steamのsku 110101のゲームの例:“sku”: “110101_steam” 。 |
購入通知
ユーザーが購入代金を支払った後、以下のことを取得します:- 決済情報を含む決済ウェブフック。
- インベントリに追加されるアイテムに関する情報が含まれているカートのコンテンツウェブフック。
配信パートナー側での統合
統合マネージャー(psbusiness@xsolla.com)までメールでお問い合わせいただき、デジタル配信ソリューション APIと連携するために必要なパラメータを取得します:
エクソーラとの統合中に、支払い完了や支払いキャンセルの通知を送信する必要があります(ステップ9)。エクソーラ側で通知を正しく処理するために、通知を送信するサーバーのIPアドレスをマネージャーにお知らせください。IPアドレスが変更された場合は、できるだけ早くマネージャーにお知らせください。
- 以下の入力フォームを表示します:
- ユーザーのメールアドレス — ゲームを販売する場合。
- ユーザーのメールアドレスとゲーム内ID — ゲーム内アイテムを販売する場合。
- ユーザーIDは、仮想アイテムや仮想通貨、アイテムや通貨とのバンドルなどを販売するプロジェクトで使用されます。この場合、ユーザーがゲームに登録する際に受け取ったIDを入力するためのヒントを表示する必要もあります。
- 例:

- 以下の受信したユーザーデータを渡します:
- ユーザーのメールアドレス。常に必須です。
- ユーザーのゲーム内ID。ゲーム内アイテムを販売する際に必要です。
- このデータは、ゲーム内でユーザーの存在を確認し、認証トークンを受け取るために使用されます。
- ユーザートークンを作成するメソッドを使用します。リクエストで以下のパラメータを渡します:
パラメータ | 種類 | 説明文 |
---|---|---|
project_id | integer | ゲームキー、ゲームキーバンドル、ゲーム内アイテム、ゲーム内アイテムバンドルがロードされるプロジェクトのID。 |
user.email | string | ユーザーのメールアドレス。 |
user.id | string or null | ゲーム内で一意のユーザー識別子。 |
- ユーザーデータを含む認証トークンが応答で返されます。
- インポート:
- ゲームカタログ。ゲームリストを取得するメソッドを使用します。
- 仮想アイテムカタログ、仮想アイテムを取得するリストメソッドを使用する。
- 仮想通貨カタログ。仮想通貨リストを取得するメソッドを使用します。
- ゲームまたはゲーム内アイテムカタログのバンドル。バンドルリストを取得するメソッドを使用します。
- リクエストには、手順2で受け取ったトークンと、以下のパラメータを渡します:
パラメータ | 種類 | 説明文 |
---|---|---|
project_id | integer | ゲームキー、ゲームキーバンドル、ゲーム内アイテム、ゲーム内アイテムバンドルがロードされるプロジェクトのID。 |
- ゲームとゲーム内アイテムのカタログをストアフロントに表示します。インターフェースでは、選択する機能を実装しています:
- ゲームキーとゲーム配信プラットフォームの数量。
- 仮想アイテムの数量。
- 固定金額の仮想通貨または仮想通貨パッケージの数量。
- バンドルの数量。
- カートを使用する場合は、ユーザーのカートでアイテムの数量を指定することができます。カートを使用しない場合、アイテムの数量の選択はカタログに実装することができます。
- カート内のアイテム数量を指定する例:

- カタログ内のアイテム数量を指定する例:

- カートを使用しない場合は、ステップ6に進み、指定されたアイテムで注文を作成するメソッドを使用します。
- カートにアイテムを入れるには、カートにアイテムを入れるメソッドを使用します。
- ユーザーは、1つの注文でアイテムを追加および削除したり、数量を変更したりできます。以下のメソッドを使ってカートを更新することができます:
- ユーザーがカートの中身を変更するたびにはカートにアイテムを入れるメソッド
- カートを更新する、商品を削除するメソッド:
- この場合、カートを更新した後に現在のユーザーのカートを取得するを使用します。
- カートの入力および更新方法のリクエストで、次のパラメータを渡します:
パラメータ | 種類 | 説明文 |
---|---|---|
project_id | integer | ゲームキー、ゲームキーバンドル、ゲーム内アイテム、ゲーム内アイテムバンドルがロードされるプロジェクトのID。 |
items.sku | string | ゲーム開発者がドメインページで指定した一意のアイテム識別子。 |
items.quantity | integer | アイテムの数量。 |
items.type | string | アイテムタイプ。virtual_good 、virtual_currency 、physical_good 、unit の値を受け付けます。unit タイプはゲームに使用されます。 |
items.unit_items | array | ゲームデータの配列。 |
items.unit_items.type | string | ゲームキーパッケージのアイテムタイプ。game_key の値を受け取ります。 |
items.unit_items.sku | string | ゲーム開発者がドメインページで指定したゲームキーパッケージの一意の識別子。特定のプラットフォームのゲームの場合、値はsku_drm 形式となります。Steamのsku 110101のゲームの例:“sku”: “110101_steam” 。 |
- カートにアイテムを入れるまたは現在のユーザーのカートを取得するを呼び出した後、レスポンスは選択されたアイテムに関する最新の情報(割引前と割引後の価格、ボーナスアイテム)を返します。
- 注文を作成し、カート内のアイテムの代金を支払うには、現在のカートの全アイテムを含む注文を作成するメソッドを使用します。リクエストには、以下のパラメータを渡します:
パラメータ | 種類 | 説明文 |
---|---|---|
project_id | integer | ゲームキー、ゲームキーバンドル、ゲーム内アイテム、ゲーム内アイテムバンドルがロードされるプロジェクトのID。 |
| number | エクソーラ側の配信者パートナーID。 |
| string | 注文の通貨。仮想通貨はSKU、現実の通貨は3文字のISO 4217コードを使用します。 |
- 応答には、注文IDと税込みカート価格が返されます。
- カートの合計金額をユーザーに表示します。
- プラットフォームからユーザーの資金を引き落とします。ユーザーに決済状況を表示します。
- 支払い通知を送信します。支払いが返金された、または完了しなかった場合は、決済キャンセルに関する通知を送信します。
- エクソーラ側で通知を正しく処理するために、通知を送信するサーバーのIPアドレスをエクソーラマネージャーにお知らせください。IPアドレスが変更された場合は、できるだけ早くマネージャーにお知らせください。
誤字脱字などのテキストエラーを見つけましたか? テキストを選択し、Ctrl+Enterを押します。