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