/// <summary> /// Use link_session_to_user to associate specific session to a user. Generally used only in anonymous checkout workflows. /// </summary> /// <exception cref="ai.thirdwatch.Client.ApiException">Thrown when fails to make API call</exception> /// <param name="JSON">Pass session and user to thirdwatch for link. Only `_userID` is required field. But this should contain session and user info.</param> /// <returns>Task of ApiResponse (EventResponse)</returns> public async System.Threading.Tasks.Task <ApiResponse <EventResponse> > LinkSessionToUserAsyncWithHttpInfo(LinkSessionToUser JSON) { // verify the required parameter 'JSON' is set if (JSON == null) { throw new ApiException(400, "Missing required parameter 'JSON' when calling LinkSessionToUserApi->LinkSessionToUser"); } var localVarPath = "/v1/link_session_to_user"; var localVarPathParams = new Dictionary <String, String>(); var localVarQueryParams = new List <KeyValuePair <String, String> >(); var localVarHeaderParams = new Dictionary <String, String>(Configuration.DefaultHeader); var localVarFormParams = new Dictionary <String, String>(); var localVarFileParams = new Dictionary <String, FileParameter>(); Object localVarPostBody = null; // to determine the Content-Type header String[] localVarHttpContentTypes = new String[] { "application/json" }; String localVarHttpContentType = Configuration.ApiClient.SelectHeaderContentType(localVarHttpContentTypes); // to determine the Accept header String[] localVarHttpHeaderAccepts = new String[] { "application/json" }; String localVarHttpHeaderAccept = Configuration.ApiClient.SelectHeaderAccept(localVarHttpHeaderAccepts); if (localVarHttpHeaderAccept != null) { localVarHeaderParams.Add("Accept", localVarHttpHeaderAccept); } if (JSON != null && JSON.GetType() != typeof(byte[])) { localVarPostBody = Configuration.ApiClient.Serialize(JSON); // http body (model) parameter } else { localVarPostBody = JSON; // byte array } // authentication (api_key) required if (!String.IsNullOrEmpty(Configuration.GetApiKeyWithPrefix("X-THIRDWATCH-API-KEY"))) { localVarHeaderParams["X-THIRDWATCH-API-KEY"] = Configuration.GetApiKeyWithPrefix("X-THIRDWATCH-API-KEY"); } // make the HTTP request IRestResponse localVarResponse = (IRestResponse)await Configuration.ApiClient.CallApiAsync(localVarPath, Method.POST, localVarQueryParams, localVarPostBody, localVarHeaderParams, localVarFormParams, localVarFileParams, localVarPathParams, localVarHttpContentType); int localVarStatusCode = (int)localVarResponse.StatusCode; if (ExceptionFactory != null) { Exception exception = ExceptionFactory("LinkSessionToUser", localVarResponse); if (exception != null) { throw exception; } } return(new ApiResponse <EventResponse>(localVarStatusCode, localVarResponse.Headers.ToDictionary(x => x.Name, x => x.Value.ToString()), (EventResponse)Configuration.ApiClient.Deserialize(localVarResponse, typeof(EventResponse)))); }