seamusabshere-active_merchant 1.4.2.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (277) hide show
  1. data/CHANGELOG +399 -0
  2. data/CONTRIBUTERS +90 -0
  3. data/MIT-LICENSE +20 -0
  4. data/README +133 -0
  5. data/Rakefile +161 -0
  6. data/active_merchant.gemspec +17 -0
  7. data/gem-public_cert.pem +20 -0
  8. data/generators/gateway/USAGE +5 -0
  9. data/generators/gateway/gateway_generator.rb +61 -0
  10. data/generators/gateway/templates/gateway.rb +77 -0
  11. data/generators/gateway/templates/gateway_test.rb +49 -0
  12. data/generators/gateway/templates/remote_gateway_test.rb +57 -0
  13. data/generators/integration/USAGE +5 -0
  14. data/generators/integration/integration_generator.rb +68 -0
  15. data/generators/integration/templates/helper.rb +34 -0
  16. data/generators/integration/templates/helper_test.rb +54 -0
  17. data/generators/integration/templates/integration.rb +18 -0
  18. data/generators/integration/templates/module_test.rb +9 -0
  19. data/generators/integration/templates/notification.rb +100 -0
  20. data/generators/integration/templates/notification_test.rb +41 -0
  21. data/init.rb +3 -0
  22. data/lib/active_merchant.rb +76 -0
  23. data/lib/active_merchant/billing/avs_result.rb +95 -0
  24. data/lib/active_merchant/billing/base.rb +57 -0
  25. data/lib/active_merchant/billing/check.rb +68 -0
  26. data/lib/active_merchant/billing/credit_card.rb +157 -0
  27. data/lib/active_merchant/billing/credit_card_formatting.rb +21 -0
  28. data/lib/active_merchant/billing/credit_card_methods.rb +125 -0
  29. data/lib/active_merchant/billing/cvv_result.rb +38 -0
  30. data/lib/active_merchant/billing/expiry_date.rb +28 -0
  31. data/lib/active_merchant/billing/gateway.rb +162 -0
  32. data/lib/active_merchant/billing/gateways.rb +3 -0
  33. data/lib/active_merchant/billing/gateways/authorize_net.rb +646 -0
  34. data/lib/active_merchant/billing/gateways/authorize_net_cim.rb +702 -0
  35. data/lib/active_merchant/billing/gateways/beanstream.rb +102 -0
  36. data/lib/active_merchant/billing/gateways/beanstream/beanstream_core.rb +233 -0
  37. data/lib/active_merchant/billing/gateways/beanstream_interac.rb +54 -0
  38. data/lib/active_merchant/billing/gateways/bogus.rb +86 -0
  39. data/lib/active_merchant/billing/gateways/braintree.rb +222 -0
  40. data/lib/active_merchant/billing/gateways/card_stream.rb +230 -0
  41. data/lib/active_merchant/billing/gateways/cyber_source.rb +406 -0
  42. data/lib/active_merchant/billing/gateways/data_cash.rb +595 -0
  43. data/lib/active_merchant/billing/gateways/efsnet.rb +229 -0
  44. data/lib/active_merchant/billing/gateways/eway.rb +272 -0
  45. data/lib/active_merchant/billing/gateways/exact.rb +222 -0
  46. data/lib/active_merchant/billing/gateways/linkpoint.rb +396 -0
  47. data/lib/active_merchant/billing/gateways/modern_payments.rb +36 -0
  48. data/lib/active_merchant/billing/gateways/modern_payments_cim.rb +214 -0
  49. data/lib/active_merchant/billing/gateways/moneris.rb +205 -0
  50. data/lib/active_merchant/billing/gateways/net_registry.rb +189 -0
  51. data/lib/active_merchant/billing/gateways/netbilling.rb +168 -0
  52. data/lib/active_merchant/billing/gateways/pay_junction.rb +392 -0
  53. data/lib/active_merchant/billing/gateways/pay_secure.rb +120 -0
  54. data/lib/active_merchant/billing/gateways/payflow.rb +236 -0
  55. data/lib/active_merchant/billing/gateways/payflow/payflow_common_api.rb +213 -0
  56. data/lib/active_merchant/billing/gateways/payflow/payflow_express_response.rb +39 -0
  57. data/lib/active_merchant/billing/gateways/payflow/payflow_response.rb +13 -0
  58. data/lib/active_merchant/billing/gateways/payflow_express.rb +138 -0
  59. data/lib/active_merchant/billing/gateways/payflow_express_uk.rb +15 -0
  60. data/lib/active_merchant/billing/gateways/payflow_uk.rb +21 -0
  61. data/lib/active_merchant/billing/gateways/payment_express.rb +242 -0
  62. data/lib/active_merchant/billing/gateways/paypal.rb +108 -0
  63. data/lib/active_merchant/billing/gateways/paypal/paypal_common_api.rb +325 -0
  64. data/lib/active_merchant/billing/gateways/paypal/paypal_express_response.rb +38 -0
  65. data/lib/active_merchant/billing/gateways/paypal_ca.rb +13 -0
  66. data/lib/active_merchant/billing/gateways/paypal_express.rb +130 -0
  67. data/lib/active_merchant/billing/gateways/paypal_express_common.rb +20 -0
  68. data/lib/active_merchant/billing/gateways/plugnpay.rb +292 -0
  69. data/lib/active_merchant/billing/gateways/protx.rb +284 -0
  70. data/lib/active_merchant/billing/gateways/psigate.rb +214 -0
  71. data/lib/active_merchant/billing/gateways/psl_card.rb +302 -0
  72. data/lib/active_merchant/billing/gateways/quickpay.rb +183 -0
  73. data/lib/active_merchant/billing/gateways/realex.rb +200 -0
  74. data/lib/active_merchant/billing/gateways/sage.rb +145 -0
  75. data/lib/active_merchant/billing/gateways/sage/sage_bankcard.rb +88 -0
  76. data/lib/active_merchant/billing/gateways/sage/sage_core.rb +110 -0
  77. data/lib/active_merchant/billing/gateways/sage/sage_virtual_check.rb +97 -0
  78. data/lib/active_merchant/billing/gateways/secure_pay.rb +31 -0
  79. data/lib/active_merchant/billing/gateways/secure_pay_au.rb +157 -0
  80. data/lib/active_merchant/billing/gateways/secure_pay_tech.rb +113 -0
  81. data/lib/active_merchant/billing/gateways/skip_jack.rb +439 -0
  82. data/lib/active_merchant/billing/gateways/trans_first.rb +127 -0
  83. data/lib/active_merchant/billing/gateways/trust_commerce.rb +414 -0
  84. data/lib/active_merchant/billing/gateways/usa_epay.rb +194 -0
  85. data/lib/active_merchant/billing/gateways/verifi.rb +228 -0
  86. data/lib/active_merchant/billing/gateways/viaklix.rb +165 -0
  87. data/lib/active_merchant/billing/gateways/wirecard.rb +305 -0
  88. data/lib/active_merchant/billing/integrations.rb +21 -0
  89. data/lib/active_merchant/billing/integrations/action_view_helper.rb +79 -0
  90. data/lib/active_merchant/billing/integrations/bogus.rb +22 -0
  91. data/lib/active_merchant/billing/integrations/bogus/helper.rb +17 -0
  92. data/lib/active_merchant/billing/integrations/bogus/notification.rb +11 -0
  93. data/lib/active_merchant/billing/integrations/bogus/return.rb +10 -0
  94. data/lib/active_merchant/billing/integrations/chronopay.rb +22 -0
  95. data/lib/active_merchant/billing/integrations/chronopay/helper.rb +81 -0
  96. data/lib/active_merchant/billing/integrations/chronopay/notification.rb +156 -0
  97. data/lib/active_merchant/billing/integrations/chronopay/return.rb +10 -0
  98. data/lib/active_merchant/billing/integrations/gestpay.rb +26 -0
  99. data/lib/active_merchant/billing/integrations/gestpay/common.rb +42 -0
  100. data/lib/active_merchant/billing/integrations/gestpay/helper.rb +70 -0
  101. data/lib/active_merchant/billing/integrations/gestpay/notification.rb +83 -0
  102. data/lib/active_merchant/billing/integrations/gestpay/return.rb +10 -0
  103. data/lib/active_merchant/billing/integrations/helper.rb +93 -0
  104. data/lib/active_merchant/billing/integrations/hi_trust.rb +26 -0
  105. data/lib/active_merchant/billing/integrations/hi_trust/helper.rb +58 -0
  106. data/lib/active_merchant/billing/integrations/hi_trust/notification.rb +59 -0
  107. data/lib/active_merchant/billing/integrations/hi_trust/return.rb +67 -0
  108. data/lib/active_merchant/billing/integrations/nochex.rb +87 -0
  109. data/lib/active_merchant/billing/integrations/nochex/helper.rb +68 -0
  110. data/lib/active_merchant/billing/integrations/nochex/notification.rb +94 -0
  111. data/lib/active_merchant/billing/integrations/nochex/return.rb +10 -0
  112. data/lib/active_merchant/billing/integrations/notification.rb +62 -0
  113. data/lib/active_merchant/billing/integrations/paypal.rb +40 -0
  114. data/lib/active_merchant/billing/integrations/paypal/helper.rb +118 -0
  115. data/lib/active_merchant/billing/integrations/paypal/notification.rb +154 -0
  116. data/lib/active_merchant/billing/integrations/paypal/return.rb +10 -0
  117. data/lib/active_merchant/billing/integrations/return.rb +35 -0
  118. data/lib/active_merchant/billing/integrations/two_checkout.rb +23 -0
  119. data/lib/active_merchant/billing/integrations/two_checkout/helper.rb +59 -0
  120. data/lib/active_merchant/billing/integrations/two_checkout/notification.rb +114 -0
  121. data/lib/active_merchant/billing/integrations/two_checkout/return.rb +17 -0
  122. data/lib/active_merchant/billing/response.rb +32 -0
  123. data/lib/active_merchant/lib/country.rb +298 -0
  124. data/lib/active_merchant/lib/error.rb +4 -0
  125. data/lib/active_merchant/lib/post_data.rb +22 -0
  126. data/lib/active_merchant/lib/posts_data.rb +89 -0
  127. data/lib/active_merchant/lib/requires_parameters.rb +16 -0
  128. data/lib/active_merchant/lib/utils.rb +18 -0
  129. data/lib/active_merchant/lib/validateable.rb +76 -0
  130. data/lib/certs/cacert.pem +7815 -0
  131. data/lib/support/gateway_support.rb +58 -0
  132. data/lib/tasks/cia.rb +90 -0
  133. data/script/destroy +14 -0
  134. data/script/generate +14 -0
  135. data/test/extra/binding_of_caller.rb +80 -0
  136. data/test/extra/breakpoint.rb +547 -0
  137. data/test/fixtures.yml +301 -0
  138. data/test/remote/gateways/remote_authorize_net_cim_test.rb +459 -0
  139. data/test/remote/gateways/remote_authorize_net_test.rb +145 -0
  140. data/test/remote/gateways/remote_beanstream_interac_test.rb +53 -0
  141. data/test/remote/gateways/remote_beanstream_test.rb +150 -0
  142. data/test/remote/gateways/remote_braintree_test.rb +154 -0
  143. data/test/remote/gateways/remote_card_stream_test.rb +148 -0
  144. data/test/remote/gateways/remote_cyber_source_test.rb +144 -0
  145. data/test/remote/gateways/remote_data_cash_test.rb +357 -0
  146. data/test/remote/gateways/remote_efsnet_test.rb +81 -0
  147. data/test/remote/gateways/remote_eway_test.rb +74 -0
  148. data/test/remote/gateways/remote_exact_test.rb +60 -0
  149. data/test/remote/gateways/remote_linkpoint_test.rb +112 -0
  150. data/test/remote/gateways/remote_modern_payments_cim_test.rb +58 -0
  151. data/test/remote/gateways/remote_modern_payments_test.rb +43 -0
  152. data/test/remote/gateways/remote_moneris_test.rb +82 -0
  153. data/test/remote/gateways/remote_net_registry_test.rb +85 -0
  154. data/test/remote/gateways/remote_netbilling_test.rb +70 -0
  155. data/test/remote/gateways/remote_pay_junction_test.rb +143 -0
  156. data/test/remote/gateways/remote_pay_secure_test.rb +39 -0
  157. data/test/remote/gateways/remote_payflow_express_test.rb +50 -0
  158. data/test/remote/gateways/remote_payflow_test.rb +237 -0
  159. data/test/remote/gateways/remote_payflow_uk_test.rb +173 -0
  160. data/test/remote/gateways/remote_payment_express_test.rb +126 -0
  161. data/test/remote/gateways/remote_paypal_express_test.rb +49 -0
  162. data/test/remote/gateways/remote_paypal_test.rb +167 -0
  163. data/test/remote/gateways/remote_plugnpay_test.rb +72 -0
  164. data/test/remote/gateways/remote_protx_test.rb +184 -0
  165. data/test/remote/gateways/remote_psigate_test.rb +50 -0
  166. data/test/remote/gateways/remote_psl_card_test.rb +106 -0
  167. data/test/remote/gateways/remote_quickpay_test.rb +182 -0
  168. data/test/remote/gateways/remote_realex_test.rb +224 -0
  169. data/test/remote/gateways/remote_sage_bankcard_test.rb +109 -0
  170. data/test/remote/gateways/remote_sage_test.rb +87 -0
  171. data/test/remote/gateways/remote_sage_virtual_check_test.rb +62 -0
  172. data/test/remote/gateways/remote_secure_pay_au_test.rb +40 -0
  173. data/test/remote/gateways/remote_secure_pay_tech_test.rb +37 -0
  174. data/test/remote/gateways/remote_secure_pay_test.rb +28 -0
  175. data/test/remote/gateways/remote_skipjack_test.rb +105 -0
  176. data/test/remote/gateways/remote_trans_first_test.rb +34 -0
  177. data/test/remote/gateways/remote_trust_commerce_test.rb +152 -0
  178. data/test/remote/gateways/remote_usa_epay_test.rb +46 -0
  179. data/test/remote/gateways/remote_verifi_test.rb +107 -0
  180. data/test/remote/gateways/remote_viaklix_test.rb +43 -0
  181. data/test/remote/gateways/remote_wirecard_test.rb +77 -0
  182. data/test/remote/integrations/remote_gestpay_integration_test.rb +37 -0
  183. data/test/remote/integrations/remote_paypal_integration_test.rb +26 -0
  184. data/test/test_helper.rb +191 -0
  185. data/test/unit/avs_result_test.rb +59 -0
  186. data/test/unit/base_test.rb +55 -0
  187. data/test/unit/check_test.rb +88 -0
  188. data/test/unit/country_code_test.rb +33 -0
  189. data/test/unit/country_test.rb +64 -0
  190. data/test/unit/credit_card_formatting_test.rb +19 -0
  191. data/test/unit/credit_card_methods_test.rb +170 -0
  192. data/test/unit/credit_card_test.rb +311 -0
  193. data/test/unit/cvv_result_test.rb +33 -0
  194. data/test/unit/expiry_date_test.rb +21 -0
  195. data/test/unit/gateways/authorize_net_cim_test.rb +638 -0
  196. data/test/unit/gateways/authorize_net_test.rb +291 -0
  197. data/test/unit/gateways/beanstream_interac_test.rb +51 -0
  198. data/test/unit/gateways/beanstream_test.rb +108 -0
  199. data/test/unit/gateways/bogus_test.rb +42 -0
  200. data/test/unit/gateways/braintree_test.rb +116 -0
  201. data/test/unit/gateways/card_stream_test.rb +90 -0
  202. data/test/unit/gateways/cyber_source_test.rb +188 -0
  203. data/test/unit/gateways/data_cash_test.rb +132 -0
  204. data/test/unit/gateways/efsnet_test.rb +123 -0
  205. data/test/unit/gateways/eway_test.rb +118 -0
  206. data/test/unit/gateways/exact_test.rb +156 -0
  207. data/test/unit/gateways/gateway_test.rb +48 -0
  208. data/test/unit/gateways/linkpoint_test.rb +167 -0
  209. data/test/unit/gateways/modern_payments_cim_test.rb +171 -0
  210. data/test/unit/gateways/moneris_test.rb +158 -0
  211. data/test/unit/gateways/net_registry_test.rb +416 -0
  212. data/test/unit/gateways/netbilling_test.rb +54 -0
  213. data/test/unit/gateways/pay_junction_test.rb +123 -0
  214. data/test/unit/gateways/pay_secure_test.rb +71 -0
  215. data/test/unit/gateways/payflow_express_test.rb +173 -0
  216. data/test/unit/gateways/payflow_express_uk_test.rb +14 -0
  217. data/test/unit/gateways/payflow_test.rb +301 -0
  218. data/test/unit/gateways/payflow_uk_test.rb +30 -0
  219. data/test/unit/gateways/payment_express_test.rb +195 -0
  220. data/test/unit/gateways/paypal_express_test.rb +382 -0
  221. data/test/unit/gateways/paypal_test.rb +520 -0
  222. data/test/unit/gateways/plugnpay_test.rb +86 -0
  223. data/test/unit/gateways/protx_test.rb +122 -0
  224. data/test/unit/gateways/psigate_test.rb +169 -0
  225. data/test/unit/gateways/psl_card_test.rb +64 -0
  226. data/test/unit/gateways/quickpay_test.rb +112 -0
  227. data/test/unit/gateways/realex_test.rb +151 -0
  228. data/test/unit/gateways/sage_bankcard_test.rb +162 -0
  229. data/test/unit/gateways/sage_virtual_check_test.rb +71 -0
  230. data/test/unit/gateways/secure_pay_au_test.rb +207 -0
  231. data/test/unit/gateways/secure_pay_tech_test.rb +44 -0
  232. data/test/unit/gateways/secure_pay_test.rb +87 -0
  233. data/test/unit/gateways/skip_jack_test.rb +133 -0
  234. data/test/unit/gateways/trans_first_test.rb +112 -0
  235. data/test/unit/gateways/trust_commerce_test.rb +78 -0
  236. data/test/unit/gateways/usa_epay_test.rb +128 -0
  237. data/test/unit/gateways/verifi_test.rb +96 -0
  238. data/test/unit/gateways/viaklix_test.rb +78 -0
  239. data/test/unit/gateways/wirecard_test.rb +232 -0
  240. data/test/unit/generators/test_gateway_generator.rb +46 -0
  241. data/test/unit/generators/test_generator_helper.rb +20 -0
  242. data/test/unit/generators/test_integration_generator.rb +53 -0
  243. data/test/unit/integrations/action_view_helper_test.rb +50 -0
  244. data/test/unit/integrations/bogus_module_test.rb +20 -0
  245. data/test/unit/integrations/chronopay_module_test.rb +13 -0
  246. data/test/unit/integrations/gestpay_module_test.rb +14 -0
  247. data/test/unit/integrations/helpers/bogus_helper_test.rb +28 -0
  248. data/test/unit/integrations/helpers/chronopay_helper_test.rb +67 -0
  249. data/test/unit/integrations/helpers/gestpay_helper_test.rb +100 -0
  250. data/test/unit/integrations/helpers/hi_trust_helper_test.rb +16 -0
  251. data/test/unit/integrations/helpers/nochex_helper_test.rb +53 -0
  252. data/test/unit/integrations/helpers/paypal_helper_test.rb +162 -0
  253. data/test/unit/integrations/helpers/two_checkout_helper_test.rb +92 -0
  254. data/test/unit/integrations/hi_trust_module_test.rb +13 -0
  255. data/test/unit/integrations/nochex_module_test.rb +13 -0
  256. data/test/unit/integrations/notifications/chronopay_notification_test.rb +66 -0
  257. data/test/unit/integrations/notifications/gestpay_notification_test.rb +60 -0
  258. data/test/unit/integrations/notifications/hi_trust_notification_test.rb +59 -0
  259. data/test/unit/integrations/notifications/nochex_notification_test.rb +51 -0
  260. data/test/unit/integrations/notifications/notification_test.rb +54 -0
  261. data/test/unit/integrations/notifications/paypal_notification_test.rb +85 -0
  262. data/test/unit/integrations/notifications/two_checkout_notification_test.rb +55 -0
  263. data/test/unit/integrations/paypal_module_test.rb +28 -0
  264. data/test/unit/integrations/returns/chronopay_return_test.rb +11 -0
  265. data/test/unit/integrations/returns/gestpay_return_test.rb +10 -0
  266. data/test/unit/integrations/returns/hi_trust_return_test.rb +24 -0
  267. data/test/unit/integrations/returns/nochex_return_test.rb +10 -0
  268. data/test/unit/integrations/returns/paypal_return_test.rb +10 -0
  269. data/test/unit/integrations/returns/return_test.rb +11 -0
  270. data/test/unit/integrations/returns/two_checkout_return_test.rb +24 -0
  271. data/test/unit/integrations/two_checkout_module_test.rb +13 -0
  272. data/test/unit/post_data_test.rb +55 -0
  273. data/test/unit/posts_data_test.rb +100 -0
  274. data/test/unit/response_test.rb +28 -0
  275. data/test/unit/utils_test.rb +7 -0
  276. data/test/unit/validateable_test.rb +60 -0
  277. metadata +454 -0
@@ -0,0 +1,94 @@
1
+ require 'net/http'
2
+ require 'date'
3
+
4
+ module ActiveMerchant #:nodoc:
5
+ module Billing #:nodoc:
6
+ module Integrations #:nodoc:
7
+ module Nochex
8
+ # Parser and handler for incoming Automatic Payment Confirmations from Nochex.
9
+ class Notification < ActiveMerchant::Billing::Integrations::Notification
10
+ include ActiveMerchant::PostsData
11
+
12
+ def complete?
13
+ status == 'Completed'
14
+ end
15
+
16
+ # Id of the order we passed to Nochex
17
+ def item_id
18
+ params['order_id']
19
+ end
20
+
21
+ def transaction_id
22
+ params['transaction_id']
23
+ end
24
+
25
+ def currency
26
+ 'GBP'
27
+ end
28
+
29
+ # When was this payment received by the client.
30
+ def received_at
31
+ # U.K. Format: 27/09/2006 22:30:54
32
+ return if params['transaction_date'].blank?
33
+ time = params['transaction_date'].scan(/\d+/)
34
+ Time.utc(time[2], time[1], time[0], time[3], time[4], time[5])
35
+ end
36
+
37
+ def payer_email
38
+ params['from_email']
39
+ end
40
+
41
+ def receiver_email
42
+ params['to_email']
43
+ end
44
+
45
+ def security_key
46
+ params['security_key']
47
+ end
48
+
49
+ # the money amount we received in X.2 decimal.
50
+ def gross
51
+ params['amount']
52
+ end
53
+
54
+ # Was this a test transaction?
55
+ def test?
56
+ params['status'] == 'test'
57
+ end
58
+
59
+ def status
60
+ 'Completed'
61
+ end
62
+
63
+ # Acknowledge the transaction to Nochex. This method has to be called after a new
64
+ # apc arrives. Nochex will verify that all the information we received are correct and will return a
65
+ # ok or a fail. This is very similar to the PayPal IPN scheme.
66
+ #
67
+ # Example:
68
+ #
69
+ # def nochex_ipn
70
+ # notify = NochexNotification.new(request.raw_post)
71
+ #
72
+ # if notify.acknowledge
73
+ # ... process order ... if notify.complete?
74
+ # else
75
+ # ... log possible hacking attempt ...
76
+ # end
77
+ def acknowledge
78
+ payload = raw
79
+
80
+ response = ssl_post(Nochex.notification_confirmation_url, payload,
81
+ 'Content-Length' => "#{payload.size}",
82
+ 'User-Agent' => "Active Merchant -- http://activemerchant.org",
83
+ 'Content-Type' => "application/x-www-form-urlencoded"
84
+ )
85
+
86
+ raise StandardError.new("Faulty Nochex result: #{response}") unless ["AUTHORISED", "DECLINED"].include?(response)
87
+
88
+ response == "AUTHORISED"
89
+ end
90
+ end
91
+ end
92
+ end
93
+ end
94
+ end
@@ -0,0 +1,10 @@
1
+ module ActiveMerchant #:nodoc:
2
+ module Billing #:nodoc:
3
+ module Integrations #:nodoc:
4
+ module Nochex
5
+ class Return < ActiveMerchant::Billing::Integrations::Return
6
+ end
7
+ end
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,62 @@
1
+ module ActiveMerchant #:nodoc:
2
+ module Billing #:nodoc:
3
+ module Integrations #:nodoc:
4
+ class Notification
5
+ attr_accessor :params
6
+ attr_accessor :raw
7
+
8
+ # set this to an array in the subclass, to specify which IPs are allowed to send requests
9
+ class_inheritable_accessor :production_ips
10
+
11
+ def initialize(post, options = {})
12
+ @options = options
13
+ empty!
14
+ parse(post)
15
+ end
16
+
17
+ def status
18
+ raise NotImplementedError, "Must implement this method in the subclass"
19
+ end
20
+
21
+ # the money amount we received in X.2 decimal.
22
+ def gross
23
+ raise NotImplementedError, "Must implement this method in the subclass"
24
+ end
25
+
26
+ def gross_cents
27
+ (gross.to_f * 100.0).round
28
+ end
29
+
30
+ # This combines the gross and currency and returns a proper Money object.
31
+ # this requires the money library located at http://dist.leetsoft.com/api/money
32
+ def amount
33
+ return Money.new(gross_cents, currency) rescue ArgumentError
34
+ return Money.new(gross_cents) # maybe you have an own money object which doesn't take a currency?
35
+ end
36
+
37
+ # reset the notification.
38
+ def empty!
39
+ @params = Hash.new
40
+ @raw = ""
41
+ end
42
+
43
+ # Check if the request comes from an official IP
44
+ def valid_sender?(ip)
45
+ return true if ActiveMerchant::Billing::Base.integration_mode == :test || production_ips.blank?
46
+ production_ips.include?(ip)
47
+ end
48
+
49
+ private
50
+
51
+ # Take the posted data and move the relevant data into a hash
52
+ def parse(post)
53
+ @raw = post.to_s
54
+ for line in @raw.split('&')
55
+ key, value = *line.scan( %r{^([A-Za-z0-9_.]+)\=(.*)$} ).flatten
56
+ params[key] = CGI.unescape(value)
57
+ end
58
+ end
59
+ end
60
+ end
61
+ end
62
+ end
@@ -0,0 +1,40 @@
1
+ require 'active_merchant/billing/integrations/paypal/helper.rb'
2
+ require 'active_merchant/billing/integrations/paypal/notification.rb'
3
+ require 'active_merchant/billing/integrations/paypal/return.rb'
4
+
5
+ module ActiveMerchant #:nodoc:
6
+ module Billing #:nodoc:
7
+ module Integrations #:nodoc:
8
+ module Paypal
9
+
10
+ # Overwrite this if you want to change the Paypal test url
11
+ mattr_accessor :test_url
12
+ self.test_url = 'https://www.sandbox.paypal.com/cgi-bin/webscr'
13
+
14
+ # Overwrite this if you want to change the Paypal production url
15
+ mattr_accessor :production_url
16
+ self.production_url = 'https://www.paypal.com/cgi-bin/webscr'
17
+
18
+ def self.service_url
19
+ mode = ActiveMerchant::Billing::Base.integration_mode
20
+ case mode
21
+ when :production
22
+ self.production_url
23
+ when :test
24
+ self.test_url
25
+ else
26
+ raise StandardError, "Integration mode set to an invalid value: #{mode}"
27
+ end
28
+ end
29
+
30
+ def self.notification(post)
31
+ Notification.new(post)
32
+ end
33
+
34
+ def self.return(query_string)
35
+ Return.new(query_string)
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -0,0 +1,118 @@
1
+ module ActiveMerchant #:nodoc:
2
+ module Billing #:nodoc:
3
+ module Integrations #:nodoc:
4
+ module Paypal
5
+ class Helper < ActiveMerchant::Billing::Integrations::Helper
6
+ CANADIAN_PROVINCES = { 'AB' => 'Alberta',
7
+ 'BC' => 'British Columbia',
8
+ 'MB' => 'Manitoba',
9
+ 'NB' => 'New Brunswick',
10
+ 'NL' => 'Newfoundland',
11
+ 'NS' => 'Nova Scotia',
12
+ 'NU' => 'Nunavut',
13
+ 'NT' => 'Northwest Territories',
14
+ 'ON' => 'Ontario',
15
+ 'PE' => 'Prince Edward Island',
16
+ 'QC' => 'Quebec',
17
+ 'SK' => 'Saskatchewan',
18
+ 'YT' => 'Yukon'
19
+ }
20
+ # See https://www.paypal.com/IntegrationCenter/ic_std-variable-reference.html for details on the following options.
21
+ mapping :order, [ 'item_number', 'custom' ]
22
+
23
+ def initialize(order, account, options = {})
24
+ super
25
+ add_field('cmd', '_ext-enter')
26
+ add_field('redirect_cmd', '_xclick')
27
+ add_field('quantity', 1)
28
+ add_field('item_name', 'Store purchase')
29
+ add_field('no_shipping', '1')
30
+ add_field('no_note', '1')
31
+ add_field('charset', 'utf-8')
32
+ add_field('address_override', '0')
33
+ add_field('bn', application_id.to_s.slice(0,32)) unless application_id.blank?
34
+ end
35
+
36
+ mapping :amount, 'amount'
37
+ mapping :account, 'business'
38
+ mapping :currency, 'currency_code'
39
+ mapping :notify_url, 'notify_url'
40
+ mapping :return_url, 'return'
41
+ mapping :cancel_return_url, 'cancel_return'
42
+ mapping :invoice, 'invoice'
43
+ mapping :item_name, 'item_name'
44
+ mapping :quantity, 'quantity'
45
+ mapping :no_shipping, 'no_shipping'
46
+ mapping :no_note, 'no_note'
47
+ mapping :address_override, 'address_override'
48
+
49
+ mapping :application_id, 'bn'
50
+
51
+ mapping :customer, :first_name => 'first_name',
52
+ :last_name => 'last_name',
53
+ :email => 'email'
54
+
55
+ mapping :shipping_address, :city => 'city',
56
+ :address1 => 'address1',
57
+ :address2 => 'address2',
58
+ :state => 'state',
59
+ :zip => 'zip',
60
+ :country => 'country'
61
+
62
+ def shipping_address(params = {})
63
+
64
+ if params.has_key?(:phone)
65
+ phone = params.delete(:phone).to_s
66
+
67
+ # Whipe all non digits
68
+ phone.gsub!(/\D+/, '')
69
+
70
+ # Parse in the us style (555 555 5555) which seems to be the only format paypal supports. Ignore anything before this.
71
+ if phone =~ /(\d{3})(\d{3})(\d{4})$/
72
+ add_field('night_phone_a', $1)
73
+ add_field('night_phone_b', $2)
74
+ add_field('night_phone_c', $3)
75
+ end
76
+ end
77
+
78
+ # Get the country code in the correct format
79
+ # Use what we were given if we can't find anything
80
+ country_code = lookup_country_code(params.delete(:country))
81
+ add_field(mappings[:shipping_address][:country], country_code)
82
+
83
+ province_code = params.delete(:state)
84
+
85
+ case country_code
86
+ when 'CA'
87
+ add_field(mappings[:shipping_address][:state], CANADIAN_PROVINCES[province_code.upcase]) unless province_code.nil?
88
+ when 'US'
89
+ add_field(mappings[:shipping_address][:state], province_code)
90
+ else
91
+ add_field(mappings[:shipping_address][:state], province_code.blank? ? 'N/A' : province_code)
92
+ end
93
+
94
+ # Everything else
95
+ params.each do |k, v|
96
+ field = mappings[:shipping_address][k]
97
+ add_field(field, v) unless field.nil?
98
+ end
99
+ end
100
+
101
+ mapping :tax, 'tax'
102
+ mapping :shipping, 'shipping'
103
+ mapping :cmd, 'cmd'
104
+ mapping :custom, 'custom'
105
+ mapping :src, 'src'
106
+ mapping :sra, 'sra'
107
+ %w(a p t).each do |l|
108
+ (1..3).each do |i|
109
+ mapping "#{l}#{i}".to_sym, "#{l}#{i}"
110
+ end
111
+ end
112
+ end
113
+ end
114
+ end
115
+ end
116
+ end
117
+
118
+
@@ -0,0 +1,154 @@
1
+ require 'net/http'
2
+
3
+ module ActiveMerchant #:nodoc:
4
+ module Billing #:nodoc:
5
+ module Integrations #:nodoc:
6
+ module Paypal
7
+ # Parser and handler for incoming Instant payment notifications from paypal.
8
+ # The Example shows a typical handler in a rails application. Note that this
9
+ # is an example, please read the Paypal API documentation for all the details
10
+ # on creating a safe payment controller.
11
+ #
12
+ # Example
13
+ #
14
+ # class BackendController < ApplicationController
15
+ # include ActiveMerchant::Billing::Integrations
16
+ #
17
+ # def paypal_ipn
18
+ # notify = Paypal::Notification.new(request.raw_post)
19
+ #
20
+ # order = Order.find(notify.item_id)
21
+ #
22
+ # if notify.acknowledge
23
+ # begin
24
+ #
25
+ # if notify.complete? and order.total == notify.amount
26
+ # order.status = 'success'
27
+ #
28
+ # shop.ship(order)
29
+ # else
30
+ # logger.error("Failed to verify Paypal's notification, please investigate")
31
+ # end
32
+ #
33
+ # rescue => e
34
+ # order.status = 'failed'
35
+ # raise
36
+ # ensure
37
+ # order.save
38
+ # end
39
+ # end
40
+ #
41
+ # render :nothing
42
+ # end
43
+ # end
44
+ class Notification < ActiveMerchant::Billing::Integrations::Notification
45
+ include PostsData
46
+
47
+ # Was the transaction complete?
48
+ def complete?
49
+ status == "Completed"
50
+ end
51
+
52
+ # When was this payment received by the client.
53
+ # sometimes it can happen that we get the notification much later.
54
+ # One possible scenario is that our web application was down. In this case paypal tries several
55
+ # times an hour to inform us about the notification
56
+ def received_at
57
+ Time.parse params['payment_date']
58
+ end
59
+
60
+ # Status of transaction. List of possible values:
61
+ # <tt>Canceled-Reversal</tt>::
62
+ # <tt>Completed</tt>::
63
+ # <tt>Denied</tt>::
64
+ # <tt>Expired</tt>::
65
+ # <tt>Failed</tt>::
66
+ # <tt>In-Progress</tt>::
67
+ # <tt>Partially-Refunded</tt>::
68
+ # <tt>Pending</tt>::
69
+ # <tt>Processed</tt>::
70
+ # <tt>Refunded</tt>::
71
+ # <tt>Reversed</tt>::
72
+ # <tt>Voided</tt>::
73
+ def status
74
+ params['payment_status']
75
+ end
76
+
77
+ # Id of this transaction (paypal number)
78
+ def transaction_id
79
+ params['txn_id']
80
+ end
81
+
82
+ # What type of transaction are we dealing with?
83
+ # "cart" "send_money" "web_accept" are possible here.
84
+ def type
85
+ params['txn_type']
86
+ end
87
+
88
+ # the money amount we received in X.2 decimal.
89
+ def gross
90
+ params['mc_gross']
91
+ end
92
+
93
+ # the markup paypal charges for the transaction
94
+ def fee
95
+ params['mc_fee']
96
+ end
97
+
98
+ # What currency have we been dealing with
99
+ def currency
100
+ params['mc_currency']
101
+ end
102
+
103
+ # This is the item number which we submitted to paypal
104
+ # The custom field is also mapped to item_id because PayPal
105
+ # doesn't return item_number in dispute notifications
106
+ def item_id
107
+ params['item_number'] || params['custom']
108
+ end
109
+
110
+ # This is the invoice which you passed to paypal
111
+ def invoice
112
+ params['invoice']
113
+ end
114
+
115
+ # Was this a test transaction?
116
+ def test?
117
+ params['test_ipn'] == '1'
118
+ end
119
+
120
+ def account
121
+ params['business'] || params['receiver_email']
122
+ end
123
+
124
+ # Acknowledge the transaction to paypal. This method has to be called after a new
125
+ # ipn arrives. Paypal will verify that all the information we received are correct and will return a
126
+ # ok or a fail.
127
+ #
128
+ # Example:
129
+ #
130
+ # def paypal_ipn
131
+ # notify = PaypalNotification.new(request.raw_post)
132
+ #
133
+ # if notify.acknowledge
134
+ # ... process order ... if notify.complete?
135
+ # else
136
+ # ... log possible hacking attempt ...
137
+ # end
138
+ def acknowledge
139
+ payload = raw
140
+
141
+ response = ssl_post(Paypal.service_url + '?cmd=_notify-validate', payload,
142
+ 'Content-Length' => "#{payload.size}",
143
+ 'User-Agent' => "Active Merchant -- http://activemerchant.org"
144
+ )
145
+
146
+ raise StandardError.new("Faulty paypal result: #{response}") unless ["VERIFIED", "INVALID"].include?(response)
147
+
148
+ response == "VERIFIED"
149
+ end
150
+ end
151
+ end
152
+ end
153
+ end
154
+ end