ユーザーデータと Cognito Sync を同期する - AWS Mobile SDK

AWSの Mobile SDK for Xamarin が、AWS SDK for .NETに含まれるようになりました。このガイドでは、Mobile SDK for Xamarin のアーカイブバージョンについて説明します。

ユーザーデータと Cognito Sync を同期する

Amazon Cognito Sync を使用すると、アプリケーションの設定やゲームの状態などのモバイルユーザーデータを AWS クラウドに簡単に保存できます。バックエンドコードの記述やインフラストラクチャの管理は必要ありません。ユーザーのデバイスにローカルでデータを保存すれば、デバイスがオフラインの場合でもアプリケーションを使用することができます。また、ユーザーのデバイス間でデータを同期して、使用するデバイスを問わずアプリのエクスペリエンスに整合性を持たせることもできます。

以下のチュートリアルでは、Sync をアプリに統合する方法について説明します。

プロジェクトのセットアップ

前提条件

このチュートリアルを開始する前に、必ず「AWS Mobile SDK for .NET and Xamarin をセットアップする」の手順をすべて完了する必要があります。

Cognito Sync リソースにアクセス権限を付与する

セットアップ時に作成した未認証および承認済みのロールに関連付けられているデフォルトポリシーを使用して、アプリケーションから Cognito Sync にアクセスできるようにします。必要な設定はこれだけです。

Cognito Sync の NuGet パッケージをプロジェクトに追加する

AWS Mobile SDK for .NET and Xamarin をセットアップする」のステップ 4 に従って、Cognito SyncManager の NuGet パッケージをプロジェクトに追加します。

CognitoSyncManager を初期化する

初期化した Amazon Cognito 認証情報プロバイダーを CognitoSyncManager コンストラクタに渡します。

CognitoSyncManager syncManager = new CognitoSyncManager ( credentials, new AmazonCognitoSyncConfig { RegionEndpoint = RegionEndpoint.USEast1 // Region } );

ユーザーデータを同期する

未認証のユーザーデータを同期するには、以下のように行います。

  1. データセットを作成します。

  2. ユーザーデータをデータセットに追加します。

  3. データセットをクラウドと同期します。

データセットを作成する

Dataset のインスタンスを作成します。openOrCreateDataset メソッドは、新しいデータセットを作成するか、デバイスにローカルで保存されている既存のデータセットのインスタンスを開くために使用されます。

Dataset dataset = syncManager.OpenOrCreateDataset("myDataset");

ユーザーデータをデータセットに追加する

ユーザーデータは、キーと値のペアの形式で追加されます。

dataset.OnSyncSuccess += SyncSuccessCallback; dataset.Put("myKey", "myValue");

Cognito データセット関数は、キーによってアクセス可能な値を持つディクショナリとして機能します。

string myValue = dataset.Get("myKey");

データセットを同期する

データセットを同期するには、その同期メソッドを呼び出します。

dataset.SynchronizeAsync(); void SyncSuccessCallback(object sender, SyncSuccessEventArgs e) { // Your handler code here }

データセットに書き込まれたデータはすべて、データセットが同期されるまでローカルに保存されます。このセクションのコードでは、未認証の Cognito ID を使用していることを前提としているため、ユーザーデータをクラウドと同期する際はデバイスごとに保存されます。デバイスには、デバイス ID が関連付けられています。クラウドと同期されると、ユーザーデータは、そのデバイス ID に関連付けられます。

Cognito Sync の詳細については、「Amazon Cognito Sync」を参照してください。