...

четверг, 19 июня 2014 г.

Интеграция PayPal Here в iOS-приложение

Работая над одним своим проектом, я столкнулся с необходимостью интегрирования PayPal Here в приложения. PayPal вообще никогда не шел на встречу разработчикам, интегрироваться было достаточно сложно, но с PayPal Here дело обстоит несколько иначе (есть целый пример на gitHab’е). Одним словом, если вы владелец интернет-магазина, интернет-аукциона или вообще хотите проводить оплату в своем приложении, то вам будет интересно почитать о том, как можно интегрировать PayPal Here в iOS.

image


Кстати, несмотря на большое количество интернет-магазинов, оплата в которых осуществляется через PayPal, сервис PayPal Here до сих пор не доступен в российском сторе.


Что такое PayPal Here?


PayPal Here представляет собой мобильный терминал, через который можно оплачивать платежи, и является прямым конкурентом аналогичной программы от Square. Кроме проведения платежей посредством кредитных карт, PayPal Here может использоваться для оплаты чеками и для проверки финансовых транзакций за определенный период времени. Также, можно отправлять счета на электронную почту получателя через ПО от PayPal Here, и покупатель, получив счет, сможет его оплатить.


Я приведу пример интеграции для iOS и на Oblective-C. Если кого-то интересует Android, то его поддержка тоже имеется, но я с ней не работал.


Процесс интеграции.


К сожалению, PayPal не предоставляет какую-либо отдельную библиотеки для проведения операции непосредственно из своего приложения. Но безопасность превыше всего. Приходится вызывать стороннее приложение — составляем URL и делаем:



UIApplication *application = [UIApplication sharedApplication];
if ([application canOpenURL:pphUrl]){
[application openURL:pphUrl];
} else {
NSURL *url = [NSURL URLWithString:@"http://ift.tt/1lHV8H0"];
[application openURL:url];
}




где pphUrl содержит все данные об оплате.

Далее создаем простой UIViewController для редактирования данных:



@interface PPViewController : UIViewController <UITextFieldDelegate>

@property (weak, nonatomic) IBOutlet UITextField *priceField;
@property (weak, nonatomic) IBOutlet UITextField *taxField;
@property (weak, nonatomic) IBOutlet UITextField *nameField;
@property (weak, nonatomic) IBOutlet UITextField *quantityField;
@property (weak, nonatomic) IBOutlet UITextField *descriptionField;

@end


добавляем все необходимые поля запроса:



NSMutableDictionary *shirt = [NSMutableDictionary dictionary];
NSMutableDictionary *itemList = [NSMutableDictionary dictionary];
NSMutableDictionary *invoice = [NSMutableDictionary dictionary];

[shirt setObject:self.taxField.text forKey:@"taxRate"];
[shirt setObject:self.priceField.text forKey:@"unitPrice"];
[shirt setObject:self.quantityField.text forKey:@"quantity"];
[shirt setObject:self.nameField.text forKey:@"name"];
[shirt setObject:self.descriptionField.text forKey:@"description"];
[shirt setObject:@"Tax" forKey:@"taxName"];

NSMutableArray *items = [NSMutableArray arrayWithObject:shirt];
[itemList setObject:items forKey:@"item"];

[invoice setObject:@"DueOnReceipt" forKey:@"paymentTerms"];
[invoice setObject:@"0" forKey:@"discountPercent"];
[invoice setObject:@"USD" forKey:@"currencyCode"];
[invoice setObject:@"merchant@ebay.com" forKey:@"merchantEmail"];
[invoice setObject:@"foo@bar.com" forKey:@"payerEmail"];
[invoice setObject:itemList forKey:@"itemList"];


и переходим к завершающей стадии (здесь нам потребуется JSONKit):



NSString *jsonInvoice = [invoice JSONString];
NSString *encodedInvoice = [jsonInvoice stringByAddingPercentEscapesUsingEncoding:NSASCIIStringEncoding];

NSString *encodedPaymentTypes = [@"cash,card,paypal" stringByAddingPercentEscapesUsingEncoding:NSASCIIStringEncoding];

NSString *encodedReturnUrl = [@"http://myapphandler?{result}?Type={Type}&InvoiceId={InvoiceId}&Tip={Tip}&Email={Email}&TxId={TxId}" stringByAddingPercentEscapesUsingEncoding:NSASCIIStringEncoding];

NSString *pphUrlString = [NSString stringWithFormat:@"http://paypalheretakePayment?accepted=%@&returnUrl=%@&invoice=%@&step=choosePayment",
encodedPaymentTypes, encodedReturnUrl, encodedInvoice];

NSURL *pphUrl = [NSURL URLWithString:pphUrlString];




после этого мы открываем приложение по pphUrl как описано выше.

Заключение


В этой схеме есть одно маленькое НО — пока что приложение PayPalHere не умеет делать обратный вызов вашего приложения после проведения платежа, но думаю, что разработчики это скоро исправят.

Лично я рекомендую заниматься сборкой необходимого url на сервере, так как гораздо меньше возни, да и выглядит устойчивее к ошибкам. Во всяком случае, я делал именно так.


Надеюсь, что кому-нибудь эта статья поможет, всем удачной интеграции!

Буду рад ответить на ваши вопросы и прочитать про ваш опыт.


This entry passed through the Full-Text RSS service — if this is your content and you're reading it on someone else's site, please read the FAQ at http://ift.tt/jcXqJW.


1 комментарий: