Пример #1
0
        /// <summary>
        /// Retrieve scores and ranks for a provided list of ChilliConnectIDs. For each
        /// player that has a score in the provided leaderboard, their global rank will be
        /// returned along with their local ranking within the returned scores.
        /// </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 GetScoresForChilliConnectIds(GetScoresForChilliConnectIdsRequestDesc desc, Action <GetScoresForChilliConnectIdsRequest, GetScoresForChilliConnectIdsResponse> successCallback, Action <GetScoresForChilliConnectIdsRequest, GetScoresForChilliConnectIdsError> errorCallback)
        {
            m_logging.LogVerboseMessage("Sending Get Scores For Chilli Connect Ids request.");

            var connectAccessToken = m_dataStore.GetString("UserAccessToken");
            var request            = new GetScoresForChilliConnectIdsRequest(desc, connectAccessToken);

            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)
                {
                    NotifyGetScoresForChilliConnectIdsSuccess(serverResponse, request, successCallback);
                }
                else
                {
                    NotifyGetScoresForChilliConnectIdsError(serverResponse, request, errorCallback);
                }
            });
        }
Пример #2
0
        /// <summary>
        /// Notifies the user that a Get Scores For Chilli Connect Ids request has failed.
        /// </summary>
        ///
        /// <param name="serverResponse">A container for information on the response from the server. Only
        /// failed responses can be passed into this method.</param>
        /// <param name="request"> The request that was sent to the server.</param>
        /// <param name="callback">The error callback.</param>
        private void NotifyGetScoresForChilliConnectIdsError(ServerResponse serverResponse, GetScoresForChilliConnectIdsRequest request, Action <GetScoresForChilliConnectIdsRequest, GetScoresForChilliConnectIdsError> errorCallback)
        {
            ReleaseAssert.IsTrue(serverResponse.Result != HttpResult.Success || serverResponse.HttpResponseCode != SuccessHttpResponseCode, "Input server request must describe an error.");

            switch (serverResponse.Result)
            {
            case HttpResult.Success:
                m_logging.LogVerboseMessage("Get Scores For Chilli Connect Ids request failed with http response code: " + serverResponse.HttpResponseCode);
                break;

            case HttpResult.CouldNotConnect:
                m_logging.LogVerboseMessage("Get Scores For Chilli Connect Ids request failed becuase a connection could be established.");
                break;

            default:
                m_logging.LogVerboseMessage("Get Scores For Chilli Connect Ids request failed for an unknown reason.");
                throw new ArgumentException("Invalid value for server response result.");
            }

            GetScoresForChilliConnectIdsError error = new GetScoresForChilliConnectIdsError(serverResponse);

            m_taskScheduler.ScheduleMainThreadTask(() =>
            {
                errorCallback(request, error);
            });
        }
Пример #3
0
        /// <summary>
        /// Notifies the user that a Get Scores For Chilli Connect Ids request was successful.
        /// </summary>
        ///
        /// <param name="serverResponse">A container for information on the response from the server. Only
        /// successful responses can be passed into this method.</param>
        /// <param name="request"> The request that was sent to the server.</param>
        /// <param name="callback">The success callback.</param>
        private void NotifyGetScoresForChilliConnectIdsSuccess(ServerResponse serverResponse, GetScoresForChilliConnectIdsRequest request, Action <GetScoresForChilliConnectIdsRequest, GetScoresForChilliConnectIdsResponse> successCallback)
        {
            ReleaseAssert.IsTrue(serverResponse.Result == HttpResult.Success && serverResponse.HttpResponseCode == SuccessHttpResponseCode, "Input server request must describe a success.");

            m_logging.LogVerboseMessage("GetScoresForChilliConnectIds request succeeded.");

            GetScoresForChilliConnectIdsResponse outputResponse = new GetScoresForChilliConnectIdsResponse(serverResponse.Body);

            m_taskScheduler.ScheduleMainThreadTask(() =>
            {
                successCallback(request, outputResponse);
            });
        }