/// <summary>
        /// Initialises a new instance of the request with the given description.
        /// </summary>
        ///
        /// <param name="desc">The description.</param>
        /// <param name="metricsAccessToken">MetricsAccessToken as returned from a Player login call.</param>
        /// <param name="serverUrl">The server url for this call.</param>
        public AddEventRequest(AddEventRequestDesc desc, string metricsAccessToken, string serverUrl)
        {
            ReleaseAssert.IsNotNull(desc, "A description object cannot be null.");

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

            ReleaseAssert.IsNotNull(metricsAccessToken, "Metrics Access Token cannot be null.");

            Type = desc.Type;
            if (desc.Parameters != null)
            {
                Parameters = Mutability.ToImmutable(desc.Parameters);
            }
            Count = desc.Count;
            MetricsAccessToken = metricsAccessToken;
            Date = DateTime.Now;

            Url = serverUrl + "/1.0/events/add";
            HttpRequestMethod = HttpRequestMethod.Post;
        }
示例#2
0
        /// <summary>
        /// Records a custom metrics event that occured within the context of a session. The
        /// behaviour of this method is identical to AddEvents method, with the exception
        /// that the request format accepts a single Event json object rather than an array.
        /// </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 AddEvent(AddEventRequestDesc desc, Action <AddEventRequest> successCallback, Action <AddEventRequest, AddEventError> errorCallback)
        {
            m_logging.LogVerboseMessage("Sending Add Event request.");

            var metricsAccessToken = m_dataStore.GetString("MetricsAccessToken");
            var request            = new AddEventRequest(desc, metricsAccessToken);

            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)
                {
                    NotifyAddEventSuccess(serverResponse, request, successCallback);
                }
                else
                {
                    NotifyAddEventError(serverResponse, request, errorCallback);
                }
            });
        }
示例#3
0
        /// <summary>
        /// Initialises a new instance of the request with the given description.
        /// </summary>
        ///
        /// <param name="desc">The description.</param>
        /// <param name="metricsAccessToken">MetricsAccessToken as returned from a call to SessionStart.</param>
        public AddEventRequest(AddEventRequestDesc desc, string metricsAccessToken)
        {
            ReleaseAssert.IsNotNull(desc, "A description object cannot be null.");

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

            ReleaseAssert.IsNotNull(metricsAccessToken, "Metrics Access Token cannot be null.");

            Type      = desc.Type;
            UserGrade = desc.UserGrade;
            TestGroup = desc.TestGroup;
            if (desc.Parameters != null)
            {
                Parameters = Mutability.ToImmutable(desc.Parameters);
            }
            Count = desc.Count;
            MetricsAccessToken = metricsAccessToken;
            Date = DateTime.Now;

            Url = "https://metrics.chilliconnect.com/1.0/events/add";
            HttpRequestMethod = HttpRequestMethod.Post;
        }