/// <summary>
        /// Initialises a new instance of the request with the given description.
        /// </summary>
        ///
        /// <param name="desc">The description.</param>
        /// <param name="connectAccessToken">A valid session ConnectAccessToken obtained through one of the login endpoints.</param>
        /// <param name="serverUrl">The server url for this call.</param>
        public ValidateGoogleIapRequest(ValidateGoogleIapRequestDesc desc, string connectAccessToken, string serverUrl)
        {
            ReleaseAssert.IsNotNull(desc, "A description object cannot be null.");

            ReleaseAssert.IsNotNull(desc.PurchaseData, "PurchaseData cannot be null.");
            ReleaseAssert.IsNotNull(desc.PurchaseDataSignature, "PurchaseDataSignature cannot be null.");

            ReleaseAssert.IsNotNull(connectAccessToken, "Connect Access Token cannot be null.");

            PurchaseData          = desc.PurchaseData;
            PurchaseDataSignature = desc.PurchaseDataSignature;
            LocalCost             = desc.LocalCost;
            LocalCurrency         = desc.LocalCurrency;
            ConnectAccessToken    = connectAccessToken;

            Url = serverUrl + "/1.0/iap/validate/google";
            HttpRequestMethod = HttpRequestMethod.Post;
        }
Example #2
0
        /// <summary>
        /// Validate a Receipt from a successful purchase on a Google device. If the option
        /// to automatically record IAPs is enabled both <code>LocalCost</code> and
        /// <code>LocalCurrency</code> are regarded as required.
        /// </summary>
        ///
        /// <param name="desc">The request description.</param>
        /// <param name="successCallback">The delegate which is called if the request was successful.</param>
        /// <param name="errorCallback">The delegate which is called if the request was unsuccessful. Provides
        /// a container with information on what went wrong.</param>
        public void ValidateGoogleIap(ValidateGoogleIapRequestDesc desc, Action <ValidateGoogleIapRequest, ValidateGoogleIapResponse> successCallback, Action <ValidateGoogleIapRequest, ValidateGoogleIapError> errorCallback)
        {
            m_logging.LogVerboseMessage("Sending Validate Google Iap request.");

            var serverUrl          = m_dataStore.GetString("ConnectUrl");
            var connectAccessToken = m_dataStore.GetString("UserAccessToken");
            var request            = new ValidateGoogleIapRequest(desc, connectAccessToken, serverUrl);

            m_serverRequestSystem.SendImmediateRequest(request, (IImmediateServerRequest sentRequest, ServerResponse serverResponse) =>
            {
                ReleaseAssert.IsTrue(request == sentRequest, "Received request is not the same as the one sent!");

                if (serverResponse.Result == HttpResult.Success && serverResponse.HttpResponseCode == SuccessHttpResponseCode)
                {
                    NotifyValidateGoogleIapSuccess(serverResponse, request, successCallback);
                }
                else
                {
                    NotifyValidateGoogleIapError(serverResponse, request, errorCallback);
                }
            });
        }