/// <summary> /// Получаем детали о покупке /// </summary> /// <param name="token">Токен, пришедший через GET от PayPal</param> /// <returns>Детали покупки</returns> public Dictionary<string, string> GetCheckoutDetails(string token) { var errList = Validate(); if (errList.Count != 0) { throw new Exception("Can`t get PayPal token because an error has occurred: " + string.Join(",", errList.ToArray())); } if (string.IsNullOrWhiteSpace(token)) { throw new Exception("Token can`t be empty"); } var retDict = new Dictionary<string, string>(); var client = new WebClient(); var requestStr = string.Format("{0}/?USER={1}&PWD={2}&SIGNATURE={3}&METHOD=GetExpressCheckoutDetails&VERSION={4}&token={5}", PayPalURL, User, Password, Signature, Version, token); var sr = new StreamReader(client.OpenRead(requestStr)); string newLine; while ((newLine = sr.ReadLine()) != null) { foreach (var curPair in newLine.Split('&')) { var pairKeyVal = curPair.Split('='); retDict.Add(pairKeyVal[0], pairKeyVal[1]); } } TokenResponse = retDict; return retDict; }
/// <summary> /// Операция для получения токена /// </summary> /// <param name="amount">Стоимость</param> /// <param name="currencyCode">Валюта</param> /// <param name="action">Действие на сайте PayPal, которое пользователь должен будет сделать</param> /// <param name="cancelUrl">URL, куда перенаправят пользователя в случае ошибки или отказа от проведения платежа</param> /// <param name="returnUrl">URL, куда перенаправят пользователя в случае успешного выполнения платежа</param> /// <returns>Все параметры, которые пришли от PayPal</returns> public Dictionary<string, string> GetToken(Currency currencyCode, PayAction action, string cancelUrl, string returnUrl) { var errList = Validate(); if (errList.Count != 0) { throw new Exception("Can`t get PayPal token because an error has occurred: " + string.Join(",", errList.ToArray())); } if (string.IsNullOrWhiteSpace(cancelUrl)) { throw new Exception("Cancel url is not defined"); } if (string.IsNullOrWhiteSpace(returnUrl)) { throw new Exception("Successfull url is not defined"); } var retDict = new Dictionary<string, string>(); /* --- Получаем сумму для оплаты --- */ decimal amount = basket.Sum(t => Convert.ToDecimal(t.Amount)); /* --- !Получаем сумму для оплаты --- */ var client = new WebClient(); var requestStr = new StringBuilder(); requestStr.Append(string.Format("{0}/?USER={1}&PWD={2}&SIGNATURE={3}&METHOD=SetExpressCheckout&VERSION={4}&PAYMENTREQUEST_0_AMT={5}&PAYMENTREQUEST_0_CURRENCYCODE={6}&PAYMENTREQUEST_0_PAYMENTACTION={7}&cancelUrl={8}&returnUrl={9}", PayPalURL, User, Password, Signature, Version, amount.ToString("F").Replace(',','.'), currencyCode.ToString("F"), action.ToString("F"), cancelUrl, returnUrl)); requestStr.Append(currencyCode == Currency.RUB ? "&LOCALECODE=RU" : "&LOCALECODE=US"); for (int i = 0; i < basket.Count; i++) { requestStr.Append(string.Format("&L_PAYMENTREQUEST_0_NAME{0}={1}&L_PAYMENTREQUEST_0_DESC{0}={2}&L_PAYMENTREQUEST_0_AMT{0}={3}&L_PAYMENTREQUEST_0_QTY{0}={4}", i, basket[i].Name, basket[i].Description, basket[i].Amount.Replace(',', '.'), basket[i].Quantity)); } var sr = new StreamReader(client.OpenRead(requestStr.ToString())); string newLine; while ((newLine = sr.ReadLine()) != null) { foreach (var curPair in newLine.Split('&')) { var pairKeyVal = curPair.Split('='); retDict.Add(pairKeyVal[0], pairKeyVal[1]); } } TokenResponse = retDict; return retDict; }
/// <summary> /// Завершает платеж и производит транзакцию /// </summary> /// <param name="token">Токен, выданный PayPal для операции. После операции перевода он должен прийти в GET параметре</param> /// <param name="payerId">Идентификатор плательщика, выданный PayPal после операции. Он должен прийти в GET параметре</param> /// <param name="amount">Стоимость. Должна совпадать с той стоимостью, что указана в токене</param> /// <returns></returns> public Dictionary<string, string> ConfirmPayment(string token, string payerId, decimal amount, Currency curr) { var errList = Validate(); if (errList.Count != 0) { throw new Exception("Can`t get PayPal token because an error has occurred: " + string.Join(",", errList.ToArray())); } if (string.IsNullOrWhiteSpace(payerId)) { throw new Exception("Payer ID can`t be empty"); } if (string.IsNullOrWhiteSpace(token)) { throw new Exception("Token can`t be empty"); } var retDict = new Dictionary<string, string>(); var client = new WebClient(); var requestStr = string.Format("{0}/?USER={1}&PWD={2}&SIGNATURE={3}&METHOD=DoExpressCheckoutPayment&VERSION={4}&token={5}&PAYERID={6}&PAYMENTREQUEST_0_AMT={7}&PAYMENTREQUEST_0_CURRENCYCODE={8}", PayPalURL, User, Password, Signature, Version, token, payerId, amount.ToString("F").Replace(',','.'), curr); if (!string.IsNullOrWhiteSpace(NotifyURL)) { requestStr += string.Format("&PAYMENTREQUEST_0_NOTIFYURL={0}", NotifyURL); } var sr = new StreamReader(client.OpenRead(requestStr)); string newLine; while ((newLine = sr.ReadLine()) != null) { foreach (var curPair in newLine.Split('&')) { var pairKeyVal = curPair.Split('='); retDict.Add(pairKeyVal[0], pairKeyVal[1]); } } TokenResponse = retDict; return retDict; }