Example #1
0
        /// <summary>
        /// Retrieve VAT Payments
        /// </summary>
        /// <returns></returns>
        public paymentResponse Payments(paymentRequest request, string testScenario = null)
        {
            RefreshAccessToken();
            string             url         = urlSite + _urlPayments.Replace("{vrn}", vrn) + "?from=" + request.from?.ToString("yyyy-MM-dd") + "&to=" + request.to?.ToString("yyyy-MM-dd");
            HttpRequestMessage httpRequest = new HttpRequestMessage(HttpMethod.Get, url);

            httpRequest.Headers.Accept.Add(new MediaTypeWithQualityHeaderValue(_acceptHeader));
            httpRequest.Headers.Authorization = new AuthenticationHeaderValue("Bearer", token.AccessToken);

            foreach (var item in fraudHeaders)
            {
                httpRequest.Headers.Add(item.Key, item.Value);
            }

            if (!String.IsNullOrEmpty(testScenario))
            {
                httpRequest.Headers.Add("Gov-Test-Scenario", testScenario);
            }

            paymentResponse paymentResponse = null;

            using (var httpClient = new HttpClient())
            {
                HttpResponseMessage response = httpClient.SendAsync(httpRequest).Result;
                checkApiResponse(response, VATApiType.RetrieveVATliabilities);

                var content = response.Content.ReadAsStringAsync();
                paymentResponse = JsonConvert.DeserializeObject <paymentResponse>(content.Result);
            }

            return(paymentResponse);
        }
Example #2
0
        public static void GetVATPaymentsProc(VATMaint vatMaint, DateTime from, DateTime to, string testScenario = null)
        {
            paymentRequest req = new paymentRequest()
            {
                from = from, to = to
            };
            paymentResponse paymentResponse = null;

            try
            {
                paymentResponse = vatMaint.VATProvider.Payments(req, testScenario);
            }
            catch (Exceptions.VATAPIInvalidToken eToken)
            {
                Trace.WriteError(eToken);
                //         vatMaint.signInHMRC.SetEnabled(true);
                throw new Exception(Messages.PleaseAuthorize);
            }
            catch (Exceptions.VATAPIException eApi)
            {
                Trace.WriteError(eApi);
                if (eApi.Data.Contains("json"))
                {
                    Trace.WriteError(eApi.Data["json"].ToString());
                }
                if (eApi.Code != error.MATCHING_RESOURCE_NOT_FOUND)
                {
                    throw eApi;
                }
            }
            catch (Exception e)
            {
                Trace.WriteError(e);
                throw e;
            }
            vatMaint.Payments.Clear();
            if (paymentResponse != null)
            {
                foreach (var o in paymentResponse.payments)
                {
                    vatMaint.Payments.Add(new Payment()
                    {
                        amount   = o.amount,
                        received = (o.received == null) ? (DateTime?)null : DateTime.ParseExact(o.received, "yyyy-MM-dd", System.Globalization.CultureInfo.InvariantCulture)
                    });
                }
            }
            return;
        }
Example #3
0
        /// <summary>
        /// Criação de Pagamento do Pedido
        /// </summary>
        /// <param name="pedido"></param>
        /// <returns>KeyValuePair (TransactionUuid, Message)</returns>
        public static KeyValuePair <string, string> CreatePayment(Pedido pedido)
        {
            #region SoapHeader
            SoapHeader = new PayzenHeader
            {
                ShopId    = ApiShopid,
                RequestId = Guid.NewGuid().ToString(),
                Timestamp = DateTime.UtcNow.ToString("yyyy-MM-ddTHH:mm:ssZ"),
                Mode      = ApiMode
            };

            var concatRequestIdTimeStamp = SoapHeader.RequestId + SoapHeader.Timestamp;
            SoapHeader.AuthToken = SecurityHmacSha256.HmacSha256(concatRequestIdTimeStamp, ApiCertificado);
            #endregion

            #region ObjectsRequest
            var common = new commonRequest
            {
                paymentSource           = PaymentSource.EC.ToString(),
                submissionDate          = pedido.DataInsercao,
                submissionDateSpecified = true
            };

            var payment = new paymentRequest
            {
                //transactionId = "0",
                amount            = Convert.ToInt64(pedido.ListaCompra.Total), //não concordo com a conversão
                amountSpecified   = true,
                currency          = 986,                                       //BRL - Real,
                currencySpecified = true
            };
            if (!string.IsNullOrEmpty(pedido?.ListaHistorico?.LastOrDefault(x => !string.IsNullOrEmpty(x.CodigoRetornoTransacao))?.CodigoRetornoTransacao))
            {
                payment.retryUuid = pedido?.ListaHistorico?.LastOrDefault(x => !string.IsNullOrEmpty(x.CodigoRetornoTransacao))?.CodigoRetornoTransacao;
            }

            var order = new orderRequest
            {
                orderId = $"{ApiMode}-{pedido.Id}"
            };

            var card = new cardRequest
            {
                expiryYear           = Convert.ToInt32($"20{pedido.Cartao.Validade.Split('/').LastOrDefault()}"), //2020,
                expiryYearSpecified  = true,
                expiryMonth          = Convert.ToInt32(pedido.Cartao.Validade.Split('/').FirstOrDefault()),       //4,
                expiryMonthSpecified = true,
                cardSecurityCode     = pedido.Cartao.Cvv,                                                         //"123",
                number = pedido.Cartao.NumeroSemMascara,                                                          //"5970100300000018",
                scheme = "MASTERCARD"                                                                             //Core.Resources.Resources.SearchTypeCardByNumber(pedido.Cartao.NumeroSemMascara)
            };
            #endregion

            #region Create - SoapRequest
            var body = Serialization.Serialize(common);
            body += Serialization.Serialize(payment);
            body += Serialization.Serialize(order);
            body += Serialization.Serialize(card);

            var soapEnvelopeXml = CreateSoapEnvelope(UrlHeader, SoapHeader, PayzenMethods.createPayment.ToString(), body);
            var webRequest      = CreateWebRequest(UrlApiWsdl);

            InsertSoapEnvelopeIntoWebRequest(soapEnvelopeXml, webRequest);
            #endregion

            string result;
            using (var response = webRequest.GetResponse())
            {
                using (var rd = new StreamReader(response.GetResponseStream()))
                {
                    result = rd.ReadToEnd();
                }
            }

            //Extraindo o objeto [CreatePaymentResponseCreatePaymentResult]
            if (!result.Contains("createPaymentResult"))
            {
                throw new BusinessRuleException($"Não encontrado [createPaymentResult]: {result}");
            }

            var xml = new XmlDocument();
            xml.LoadXml(result);
            var xmlMethod    = xml.DocumentElement.SelectNodes("//createPaymentResult").Item(0).OuterXml.Replace("createPaymentResult", "createPaymentResponseCreatePaymentResult");
            var methodResult = Serialization.LoadFromXmlString <createPaymentResponseCreatePaymentResult>(xmlMethod);

            TransactionStatus statusPagamento;
            Enum.TryParse(methodResult.commonResponse.transactionStatusLabel, out statusPagamento);

            return(new KeyValuePair <string, string>(methodResult.paymentResponse.transactionUuid,
                                                     $"{(methodResult.commonResponse.responseCode == 0 && statusPagamento == TransactionStatus.AUTHORISED ? "sucesso" : "erro")} - responseCodeDetails [{methodResult.commonResponse.responseCodeDetail}] transactionStatusLabel [{methodResult.commonResponse.transactionStatusLabel}]"));
        }