/// <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; }
/// <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); } }); }
/// <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; }