/// <summary>
        ///
        /// <example>
        ///  <code>
        /// var result = CreditTransactionFactory.AddTransaction(handler : handler,  creditTransaction :  creditTransaction,  code :  code,  responseFields :  responseFields,  expectedCode: expectedCode, successCode: successCode);
        /// var optionalCasting = ConvertClass<CreditTransaction/>(result);
        /// return optionalCasting;
        ///  </code>
        /// </example>
        /// </summary>
        public static Mozu.Api.Contracts.Customer.Credit.CreditTransaction AddTransaction(ServiceClientMessageHandler handler,
                                                                                          Mozu.Api.Contracts.Customer.Credit.CreditTransaction creditTransaction, string code, string responseFields = null,
                                                                                          HttpStatusCode expectedCode = HttpStatusCode.Created, HttpStatusCode successCode = HttpStatusCode.Created)
        {
            SetSdKparameters();
            var currentClassName  = System.Reflection.MethodInfo.GetCurrentMethod().DeclaringType.Name;
            var currentMethodName = System.Reflection.MethodBase.GetCurrentMethod().Name;

            Debug.WriteLine(currentMethodName + '.' + currentMethodName);
            var apiClient = Mozu.Api.Clients.Commerce.Customer.Credits.CreditTransactionClient.AddTransactionClient(
                creditTransaction:  creditTransaction, code:  code, responseFields:  responseFields);

            try
            {
                apiClient.WithContext(handler.ApiContext).ExecuteAsync(default(CancellationToken)).Wait();
            }
            catch (ApiException ex)
            {
                // Custom error handling for test cases can be placed here
                Exception customException = TestFailException.GetCustomTestException(ex, currentClassName, currentMethodName, expectedCode);
                if (customException != null)
                {
                    throw customException;
                }
                return(null);
            }
            return(ResponseMessageFactory.CheckResponseCodes(apiClient.HttpResponse.StatusCode, expectedCode, successCode)
                                         ? (apiClient.Result())
                                         : null);
        }
        /// <summary>
        /// Creates a new transaction and updates the amount of a store credit or gift card.
        /// </summary>
        /// <param name="code">User-defined code that uniqely identifies the channel group.</param>
        /// <param name="responseFields">Use this field to include those fields which are not included by default.</param>
        /// <param name="creditTransaction">Properties of a transaction performed for a customer credit that update the remaining balance of the credit.</param>
        /// <returns>
        ///  <see cref="Mozu.Api.MozuClient" />{<see cref="Mozu.Api.Contracts.Customer.Credit.CreditTransaction"/>}
        /// </returns>
        /// <example>
        /// <code>
        ///   var mozuClient=AddTransaction( creditTransaction,  code,  responseFields);
        ///   var creditTransactionClient = mozuClient.WithBaseAddress(url).Execute().Result();
        /// </code>
        /// </example>
        public static MozuClient <Mozu.Api.Contracts.Customer.Credit.CreditTransaction> AddTransactionClient(Mozu.Api.Contracts.Customer.Credit.CreditTransaction creditTransaction, string code, string responseFields = null)
        {
            var          url        = Mozu.Api.Urls.Commerce.Customer.Credits.CreditTransactionUrl.AddTransactionUrl(code, responseFields);
            const string verb       = "POST";
            var          mozuClient = new MozuClient <Mozu.Api.Contracts.Customer.Credit.CreditTransaction>()
                                      .WithVerb(verb).WithResourceUrl(url)
                                      .WithBody <Mozu.Api.Contracts.Customer.Credit.CreditTransaction>(creditTransaction);

            return(mozuClient);
        }
        /// <summary>
        ///
        /// </summary>
        /// <param name="code">User-defined code that uniqely identifies the channel group.</param>
        /// <param name="responseFields">Filtering syntax appended to an API call to increase or decrease the amount of data returned inside a JSON object. This parameter should only be used to retrieve data. Attempting to update data using this parameter may cause data loss.</param>
        /// <param name="creditTransaction">Properties of a transaction performed for a customer credit that update the remaining balance of the credit.</param>
        /// <returns>
        /// <see cref="Mozu.Api.Contracts.Customer.Credit.CreditTransaction"/>
        /// </returns>
        /// <example>
        /// <code>
        ///   var credittransaction = new CreditTransaction();
        ///   var creditTransaction = await credittransaction.AddTransactionAsync( creditTransaction,  code,  responseFields);
        /// </code>
        /// </example>
        public virtual async Task <Mozu.Api.Contracts.Customer.Credit.CreditTransaction> AddTransactionAsync(Mozu.Api.Contracts.Customer.Credit.CreditTransaction creditTransaction, string code, string responseFields = null, CancellationToken ct = default(CancellationToken))
        {
            MozuClient <Mozu.Api.Contracts.Customer.Credit.CreditTransaction> response;
            var client = Mozu.Api.Clients.Commerce.Customer.Credits.CreditTransactionClient.AddTransactionClient(creditTransaction, code, responseFields);

            client.WithContext(_apiContext);
            response = await client.ExecuteAsync(ct).ConfigureAwait(false);

            return(await response.ResultAsync());
        }
        /// <summary>
        /// Creates a new transaction and updates the amount of a store credit or gift card.
        /// </summary>
        /// <param name="code">User-defined code that uniqely identifies the channel group.</param>
        /// <param name="responseFields">Use this field to include those fields which are not included by default.</param>
        /// <param name="creditTransaction">Properties of a transaction performed for a customer credit that update the remaining balance of the credit.</param>
        /// <returns>
        /// <see cref="Mozu.Api.Contracts.Customer.Credit.CreditTransaction"/>
        /// </returns>
        /// <example>
        /// <code>
        ///   var credittransaction = new CreditTransaction();
        ///   var creditTransaction = await credittransaction.AddTransactionAsync( creditTransaction,  code,  responseFields);
        /// </code>
        /// </example>
        public virtual async Task <Mozu.Api.Contracts.Customer.Credit.CreditTransaction> AddTransactionAsync(Mozu.Api.Contracts.Customer.Credit.CreditTransaction creditTransaction, string code, string responseFields = null)
        {
            MozuClient <Mozu.Api.Contracts.Customer.Credit.CreditTransaction> response;
            var client = Mozu.Api.Clients.Commerce.Customer.Credits.CreditTransactionClient.AddTransactionClient(creditTransaction, code, responseFields);

            client.WithContext(_apiContext);
            response = await client.ExecuteAsync();

            return(await response.ResultAsync());
        }