/// <summary>
        /// Consulta de operaciones Obtiene las operaciones generadas a partir de peticiones de pago CODI® de forma paginada, pudiendo aplicar filtros.
        /// </summary>
        /// <exception cref="MX.Wire4.Client.ApiException">Thrown when fails to make API call</exception>
        /// <param name="authorization">Header para token</param>
        /// <param name="body">Filtros de busqueda (optional)</param>
        /// <param name="companyId">Es el identificador de empresa CODI®. (optional)</param>
        /// <param name="page">Es el número de pago. (optional)</param>
        /// <param name="salesPointId">Es el identificador del punto de venta. (optional)</param>
        /// <param name="size">Es el tamaño de página. (optional)</param>
        /// <returns>Task of PagerResponseDto</returns>
        public async System.Threading.Tasks.Task <PagerResponseDto> ConsultCodiOperationsAsync(string authorization, CodiOperationsFiltersRequestDTO body = null, string companyId = null, string page = null, string salesPointId = null, string size = null)
        {
            ApiResponse <PagerResponseDto> localVarResponse = await ConsultCodiOperationsAsyncWithHttpInfo(authorization, body, companyId, page, salesPointId, size);

            return(localVarResponse.Data);
        }
        /// <summary>
        /// Consulta de operaciones Obtiene las operaciones generadas a partir de peticiones de pago CODI® de forma paginada, pudiendo aplicar filtros.
        /// </summary>
        /// <exception cref="MX.Wire4.Client.ApiException">Thrown when fails to make API call</exception>
        /// <param name="authorization">Header para token</param>
        /// <param name="body">Filtros de busqueda (optional)</param>
        /// <param name="companyId">Es el identificador de empresa CODI®. (optional)</param>
        /// <param name="page">Es el número de pago. (optional)</param>
        /// <param name="salesPointId">Es el identificador del punto de venta. (optional)</param>
        /// <param name="size">Es el tamaño de página. (optional)</param>
        /// <returns>Task of ApiResponse (PagerResponseDto)</returns>
        public async System.Threading.Tasks.Task <ApiResponse <PagerResponseDto> > ConsultCodiOperationsAsyncWithHttpInfo(string authorization, CodiOperationsFiltersRequestDTO body = null, string companyId = null, string page = null, string salesPointId = null, string size = null)
        {
            // verify the required parameter 'authorization' is set
            if (authorization == null)
            {
                throw new ApiException(400, "Missing required parameter 'authorization' when calling OperacionesCoDiApi->ConsultCodiOperations");
            }

            var    localVarPath         = "/codi/charges";
            var    localVarPathParams   = new Dictionary <String, String>();
            var    localVarQueryParams  = new List <KeyValuePair <String, String> >();
            var    localVarHeaderParams = new Dictionary <String, String>(this.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 = this.Configuration.ApiClient.SelectHeaderContentType(localVarHttpContentTypes);

            // to determine the Accept header
            String[] localVarHttpHeaderAccepts = new String[] {
                "application/json"
            };
            String localVarHttpHeaderAccept = this.Configuration.ApiClient.SelectHeaderAccept(localVarHttpHeaderAccepts);

            if (localVarHttpHeaderAccept != null)
            {
                localVarHeaderParams.Add("Accept", localVarHttpHeaderAccept);
            }

            if (companyId != null)
            {
                localVarQueryParams.AddRange(this.Configuration.ApiClient.ParameterToKeyValuePairs("", "company_id", companyId));                    // query parameter
            }
            if (page != null)
            {
                localVarQueryParams.AddRange(this.Configuration.ApiClient.ParameterToKeyValuePairs("", "page", page));               // query parameter
            }
            if (salesPointId != null)
            {
                localVarQueryParams.AddRange(this.Configuration.ApiClient.ParameterToKeyValuePairs("", "sales_point_id", salesPointId));                       // query parameter
            }
            if (size != null)
            {
                localVarQueryParams.AddRange(this.Configuration.ApiClient.ParameterToKeyValuePairs("", "size", size));               // query parameter
            }
            if (authorization != null)
            {
                localVarHeaderParams.Add("Authorization", this.Configuration.ApiClient.ParameterToString(authorization));                        // header parameter
            }
            if (body != null && body.GetType() != typeof(byte[]))
            {
                localVarPostBody = this.Configuration.ApiClient.Serialize(body); // http body (model) parameter
            }
            else
            {
                localVarPostBody = body; // byte array
            }

            // make the HTTP request
            IRestResponse localVarResponse = (IRestResponse)await this.Configuration.ApiClient.CallApiAsync(localVarPath,
                                                                                                            Method.POST, localVarQueryParams, localVarPostBody, localVarHeaderParams, localVarFormParams, localVarFileParams,
                                                                                                            localVarPathParams, localVarHttpContentType);

            int localVarStatusCode = (int)localVarResponse.StatusCode;

            if (ExceptionFactory != null)
            {
                Exception exception = ExceptionFactory("ConsultCodiOperations", localVarResponse);
                if (exception != null)
                {
                    throw exception;
                }
            }

            return(new ApiResponse <PagerResponseDto>(localVarStatusCode,
                                                      localVarResponse.Headers.ToDictionary(x => x.Name, x => string.Join(",", x.Value)),
                                                      (PagerResponseDto)this.Configuration.ApiClient.Deserialize(localVarResponse, typeof(PagerResponseDto))));
        }
        /// <summary>
        /// Consulta de operaciones Obtiene las operaciones generadas a partir de peticiones de pago CODI® de forma paginada, pudiendo aplicar filtros.
        /// </summary>
        /// <exception cref="MX.Wire4.Client.ApiException">Thrown when fails to make API call</exception>
        /// <param name="authorization">Header para token</param>
        /// <param name="body">Filtros de busqueda (optional)</param>
        /// <param name="companyId">Es el identificador de empresa CODI®. (optional)</param>
        /// <param name="page">Es el número de pago. (optional)</param>
        /// <param name="salesPointId">Es el identificador del punto de venta. (optional)</param>
        /// <param name="size">Es el tamaño de página. (optional)</param>
        /// <returns>PagerResponseDto</returns>
        public PagerResponseDto ConsultCodiOperations(string authorization, CodiOperationsFiltersRequestDTO body = null, string companyId = null, string page = null, string salesPointId = null, string size = null)
        {
            ApiResponse <PagerResponseDto> localVarResponse = ConsultCodiOperationsWithHttpInfo(authorization, body, companyId, page, salesPointId, size);

            return(localVarResponse.Data);
        }