globalpayments-api 3.0.0 → 3.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (596) hide show
  1. package/.eslintignore +9 -0
  2. package/.eslintrc.cjs +39 -0
  3. package/.prettierrc +14 -4
  4. package/CHANGELOG.md +44 -32
  5. package/lib/src/Builders/AuthorizationBuilder.d.ts +325 -325
  6. package/lib/src/Builders/AuthorizationBuilder.js +616 -600
  7. package/lib/src/Builders/AuthorizationBuilder.js.map +1 -1
  8. package/lib/src/Builders/BaseBuilder/ValidationClause.d.ts +14 -14
  9. package/lib/src/Builders/BaseBuilder/ValidationClause.js +61 -61
  10. package/lib/src/Builders/BaseBuilder/ValidationClause.js.map +1 -1
  11. package/lib/src/Builders/BaseBuilder/ValidationTarget.d.ts +16 -16
  12. package/lib/src/Builders/BaseBuilder/ValidationTarget.js +35 -28
  13. package/lib/src/Builders/BaseBuilder/ValidationTarget.js.map +1 -1
  14. package/lib/src/Builders/BaseBuilder/Validations.d.ts +11 -11
  15. package/lib/src/Builders/BaseBuilder/Validations.js +54 -56
  16. package/lib/src/Builders/BaseBuilder/Validations.js.map +1 -1
  17. package/lib/src/Builders/BaseBuilder.d.ts +11 -11
  18. package/lib/src/Builders/BaseBuilder.js +16 -16
  19. package/lib/src/Builders/BaseBuilder.js.map +1 -1
  20. package/lib/src/Builders/ManagementBuilder.d.ts +104 -103
  21. package/lib/src/Builders/ManagementBuilder.js +207 -227
  22. package/lib/src/Builders/ManagementBuilder.js.map +1 -1
  23. package/lib/src/Builders/PayFacBuilder.d.ts +98 -96
  24. package/lib/src/Builders/PayFacBuilder.js +233 -184
  25. package/lib/src/Builders/PayFacBuilder.js.map +1 -1
  26. package/lib/src/Builders/RecurringBuilder.d.ts +13 -13
  27. package/lib/src/Builders/RecurringBuilder.js +33 -47
  28. package/lib/src/Builders/RecurringBuilder.js.map +1 -1
  29. package/lib/src/Builders/ReportBuilder.d.ts +8 -8
  30. package/lib/src/Builders/ReportBuilder.js +20 -36
  31. package/lib/src/Builders/ReportBuilder.js.map +1 -1
  32. package/lib/src/Builders/RequestBuilder/GpApi/AccessTokenRequest.d.ts +11 -0
  33. package/lib/src/Builders/RequestBuilder/GpApi/AccessTokenRequest.js +23 -0
  34. package/lib/src/Builders/RequestBuilder/GpApi/AccessTokenRequest.js.map +1 -0
  35. package/lib/src/Builders/RequestBuilder/GpApi/GpApiAuthorizationRequestBuilder.d.ts +17 -0
  36. package/lib/src/Builders/RequestBuilder/GpApi/GpApiAuthorizationRequestBuilder.js +36 -0
  37. package/lib/src/Builders/RequestBuilder/GpApi/GpApiAuthorizationRequestBuilder.js.map +1 -0
  38. package/lib/src/Builders/RequestBuilder/GpApi/GpApiSessionInfo.d.ts +6 -0
  39. package/lib/src/Builders/RequestBuilder/GpApi/GpApiSessionInfo.js +49 -0
  40. package/lib/src/Builders/RequestBuilder/GpApi/GpApiSessionInfo.js.map +1 -0
  41. package/lib/src/Builders/RequestBuilder/GpApi/index.d.ts +3 -0
  42. package/lib/src/Builders/RequestBuilder/GpApi/index.js +20 -0
  43. package/lib/src/Builders/RequestBuilder/GpApi/index.js.map +1 -0
  44. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomAuthorizationRequestBuilder.d.ts +17 -22
  45. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomAuthorizationRequestBuilder.js +108 -159
  46. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomAuthorizationRequestBuilder.js.map +1 -1
  47. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomManagementRequestBuilder.d.ts +11 -0
  48. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomManagementRequestBuilder.js +83 -0
  49. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomManagementRequestBuilder.js.map +1 -0
  50. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomRequestBuilder.d.ts +9 -6
  51. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomRequestBuilder.js +65 -23
  52. package/lib/src/Builders/RequestBuilder/GpEcom/GpEcomRequestBuilder.js.map +1 -1
  53. package/lib/src/Builders/RequestBuilder/GpEcom/index.d.ts +3 -2
  54. package/lib/src/Builders/RequestBuilder/GpEcom/index.js +19 -14
  55. package/lib/src/Builders/RequestBuilder/GpEcom/index.js.map +1 -1
  56. package/lib/src/Builders/RequestBuilder/RequestBuilderFactory.d.ts +7 -6
  57. package/lib/src/Builders/RequestBuilder/RequestBuilderFactory.js +30 -29
  58. package/lib/src/Builders/RequestBuilder/RequestBuilderFactory.js.map +1 -1
  59. package/lib/src/Builders/RequestBuilder/index.d.ts +3 -2
  60. package/lib/src/Builders/RequestBuilder/index.js +19 -14
  61. package/lib/src/Builders/RequestBuilder/index.js.map +1 -1
  62. package/lib/src/Builders/TransactionBuilder.d.ts +12 -10
  63. package/lib/src/Builders/TransactionBuilder.js +42 -46
  64. package/lib/src/Builders/TransactionBuilder.js.map +1 -1
  65. package/lib/src/Builders/TransactionReportBuilder.d.ts +15 -15
  66. package/lib/src/Builders/TransactionReportBuilder.js +64 -79
  67. package/lib/src/Builders/TransactionReportBuilder.js.map +1 -1
  68. package/lib/src/Builders/index.d.ts +8 -8
  69. package/lib/src/Builders/index.js +24 -20
  70. package/lib/src/Builders/index.js.map +1 -1
  71. package/lib/src/ConfiguredServices.d.ts +18 -22
  72. package/lib/src/ConfiguredServices.js +23 -56
  73. package/lib/src/ConfiguredServices.js.map +1 -1
  74. package/lib/src/Entities/Address.d.ts +13 -13
  75. package/lib/src/Entities/Address.js +20 -19
  76. package/lib/src/Entities/Address.js.map +1 -1
  77. package/lib/src/Entities/BatchSummary.d.ts +6 -6
  78. package/lib/src/Entities/BatchSummary.js +10 -9
  79. package/lib/src/Entities/BatchSummary.js.map +1 -1
  80. package/lib/src/Entities/Customer.d.ts +64 -64
  81. package/lib/src/Entities/Customer.js +79 -47
  82. package/lib/src/Entities/Customer.js.map +1 -1
  83. package/lib/src/Entities/CustomerDocument.d.ts +8 -0
  84. package/lib/src/Entities/CustomerDocument.js +16 -0
  85. package/lib/src/Entities/CustomerDocument.js.map +1 -0
  86. package/lib/src/Entities/DocumentUploadData.d.ts +13 -13
  87. package/lib/src/Entities/DocumentUploadData.js +80 -48
  88. package/lib/src/Entities/DocumentUploadData.js.map +1 -1
  89. package/lib/src/Entities/EcommerceInfo.d.ts +12 -12
  90. package/lib/src/Entities/EcommerceInfo.js +21 -14
  91. package/lib/src/Entities/EcommerceInfo.js.map +1 -1
  92. package/lib/src/Entities/EncryptionData.d.ts +6 -6
  93. package/lib/src/Entities/EncryptionData.js +10 -9
  94. package/lib/src/Entities/EncryptionData.js.map +1 -1
  95. package/lib/src/Entities/Enums.d.ts +428 -373
  96. package/lib/src/Entities/Enums.js +564 -497
  97. package/lib/src/Entities/Enums.js.map +1 -1
  98. package/lib/src/Entities/Errors.d.ts +23 -23
  99. package/lib/src/Entities/Errors.js +71 -106
  100. package/lib/src/Entities/Errors.js.map +1 -1
  101. package/lib/src/Entities/GpApi/AccessTokenInfo.d.ts +16 -0
  102. package/lib/src/Entities/GpApi/AccessTokenInfo.js +21 -0
  103. package/lib/src/Entities/GpApi/AccessTokenInfo.js.map +1 -0
  104. package/lib/src/Entities/GpApi/GpApiAccount.d.ts +5 -0
  105. package/lib/src/Entities/GpApi/GpApiAccount.js +13 -0
  106. package/lib/src/Entities/GpApi/GpApiAccount.js.map +1 -0
  107. package/lib/src/Entities/GpApi/GpApiRequest.d.ts +21 -0
  108. package/lib/src/Entities/GpApi/GpApiRequest.js +26 -0
  109. package/lib/src/Entities/GpApi/GpApiRequest.js.map +1 -0
  110. package/lib/src/Entities/GpApi/GpApiTokenResponse.d.ts +52 -0
  111. package/lib/src/Entities/GpApi/GpApiTokenResponse.js +115 -0
  112. package/lib/src/Entities/GpApi/GpApiTokenResponse.js.map +1 -0
  113. package/lib/src/Entities/GpApi/index.d.ts +4 -0
  114. package/lib/src/Entities/GpApi/index.js +21 -0
  115. package/lib/src/Entities/GpApi/index.js.map +1 -0
  116. package/lib/src/Entities/HostedPaymentData.d.ts +10 -10
  117. package/lib/src/Entities/HostedPaymentData.js +16 -10
  118. package/lib/src/Entities/HostedPaymentData.js.map +1 -1
  119. package/lib/src/Entities/IRequestBuilder.d.ts +6 -7
  120. package/lib/src/Entities/IRequestBuilder.js +2 -2
  121. package/lib/src/Entities/ProFac/AccountBalanceResponseData.d.ts +7 -7
  122. package/lib/src/Entities/ProFac/AccountBalanceResponseData.js +11 -9
  123. package/lib/src/Entities/ProFac/AccountBalanceResponseData.js.map +1 -1
  124. package/lib/src/Entities/ProFac/AccountPermissions.d.ts +15 -15
  125. package/lib/src/Entities/ProFac/AccountPermissions.js +18 -9
  126. package/lib/src/Entities/ProFac/AccountPermissions.js.map +1 -1
  127. package/lib/src/Entities/ProFac/BankAccountData.d.ts +10 -10
  128. package/lib/src/Entities/ProFac/BankAccountData.js +41 -9
  129. package/lib/src/Entities/ProFac/BankAccountData.js.map +1 -1
  130. package/lib/src/Entities/ProFac/BankAccountOwnershipData.d.ts +8 -8
  131. package/lib/src/Entities/ProFac/BankAccountOwnershipData.js +14 -11
  132. package/lib/src/Entities/ProFac/BankAccountOwnershipData.js.map +1 -1
  133. package/lib/src/Entities/ProFac/BeneficialOwnerData.d.ts +6 -6
  134. package/lib/src/Entities/ProFac/BeneficialOwnerData.js +11 -10
  135. package/lib/src/Entities/ProFac/BeneficialOwnerData.js.map +1 -1
  136. package/lib/src/Entities/ProFac/BeneficialOwnerDataResult.d.ts +5 -5
  137. package/lib/src/Entities/ProFac/BeneficialOwnerDataResult.js +9 -9
  138. package/lib/src/Entities/ProFac/BeneficialOwnerDataResult.js.map +1 -1
  139. package/lib/src/Entities/ProFac/BusinessData.d.ts +15 -14
  140. package/lib/src/Entities/ProFac/BusinessData.js +49 -11
  141. package/lib/src/Entities/ProFac/BusinessData.js.map +1 -1
  142. package/lib/src/Entities/ProFac/DeviceAttributeInfo.d.ts +4 -4
  143. package/lib/src/Entities/ProFac/DeviceAttributeInfo.js +16 -9
  144. package/lib/src/Entities/ProFac/DeviceAttributeInfo.js.map +1 -1
  145. package/lib/src/Entities/ProFac/DeviceData.d.ts +5 -5
  146. package/lib/src/Entities/ProFac/DeviceData.js +10 -10
  147. package/lib/src/Entities/ProFac/DeviceData.js.map +1 -1
  148. package/lib/src/Entities/ProFac/DeviceInfo.d.ts +6 -6
  149. package/lib/src/Entities/ProFac/DeviceInfo.js +18 -9
  150. package/lib/src/Entities/ProFac/DeviceInfo.js.map +1 -1
  151. package/lib/src/Entities/ProFac/FlashFundsPaymentCardData.d.ts +7 -7
  152. package/lib/src/Entities/ProFac/FlashFundsPaymentCardData.js +14 -13
  153. package/lib/src/Entities/ProFac/FlashFundsPaymentCardData.js.map +1 -1
  154. package/lib/src/Entities/ProFac/GrossBillingInformation.d.ts +8 -8
  155. package/lib/src/Entities/ProFac/GrossBillingInformation.js +9 -9
  156. package/lib/src/Entities/ProFac/GrossBillingInformation.js.map +1 -1
  157. package/lib/src/Entities/ProFac/OrderDevice.d.ts +18 -18
  158. package/lib/src/Entities/ProFac/OrderDevice.js +22 -9
  159. package/lib/src/Entities/ProFac/OrderDevice.js.map +1 -1
  160. package/lib/src/Entities/ProFac/OwnersData.d.ts +12 -12
  161. package/lib/src/Entities/ProFac/OwnersData.js +42 -11
  162. package/lib/src/Entities/ProFac/OwnersData.js.map +1 -1
  163. package/lib/src/Entities/ProFac/PayFacResponseData.d.ts +55 -55
  164. package/lib/src/Entities/ProFac/PayFacResponseData.js +61 -9
  165. package/lib/src/Entities/ProFac/PayFacResponseData.js.map +1 -1
  166. package/lib/src/Entities/ProFac/RenewAccountData.d.ts +10 -10
  167. package/lib/src/Entities/ProFac/RenewAccountData.js +37 -11
  168. package/lib/src/Entities/ProFac/RenewAccountData.js.map +1 -1
  169. package/lib/src/Entities/ProFac/SignificantOwnerData.d.ts +8 -8
  170. package/lib/src/Entities/ProFac/SignificantOwnerData.js +26 -11
  171. package/lib/src/Entities/ProFac/SignificantOwnerData.js.map +1 -1
  172. package/lib/src/Entities/ProFac/ThreatRiskData.d.ts +5 -5
  173. package/lib/src/Entities/ProFac/ThreatRiskData.js +18 -9
  174. package/lib/src/Entities/ProFac/ThreatRiskData.js.map +1 -1
  175. package/lib/src/Entities/ProFac/UserPersonalData.d.ts +26 -26
  176. package/lib/src/Entities/ProFac/UserPersonalData.js +81 -14
  177. package/lib/src/Entities/ProFac/UserPersonalData.js.map +1 -1
  178. package/lib/src/Entities/RecurringEntity.d.ts +14 -14
  179. package/lib/src/Entities/RecurringEntity.js +91 -86
  180. package/lib/src/Entities/RecurringEntity.js.map +1 -1
  181. package/lib/src/Entities/Request.d.ts +10 -9
  182. package/lib/src/Entities/Request.js +17 -14
  183. package/lib/src/Entities/Request.js.map +1 -1
  184. package/lib/src/Entities/SSORequestData.d.ts +5 -5
  185. package/lib/src/Entities/SSORequestData.js +18 -9
  186. package/lib/src/Entities/SSORequestData.js.map +1 -1
  187. package/lib/src/Entities/Schedule.d.ts +47 -47
  188. package/lib/src/Entities/Schedule.js +324 -253
  189. package/lib/src/Entities/Schedule.js.map +1 -1
  190. package/lib/src/Entities/ServiceEndpoints.d.ts +12 -4
  191. package/lib/src/Entities/ServiceEndpoints.js +16 -8
  192. package/lib/src/Entities/ServiceEndpoints.js.map +1 -1
  193. package/lib/src/Entities/Transaction.d.ts +78 -78
  194. package/lib/src/Entities/Transaction.js +126 -108
  195. package/lib/src/Entities/Transaction.js.map +1 -1
  196. package/lib/src/Entities/TransactionSummary.d.ts +61 -61
  197. package/lib/src/Entities/TransactionSummary.js +65 -9
  198. package/lib/src/Entities/TransactionSummary.js.map +1 -1
  199. package/lib/src/Entities/index.d.ts +17 -15
  200. package/lib/src/Entities/index.js +33 -27
  201. package/lib/src/Entities/index.js.map +1 -1
  202. package/lib/src/Gateways/Gateway.d.ts +12 -10
  203. package/lib/src/Gateways/Gateway.js +69 -42
  204. package/lib/src/Gateways/Gateway.js.map +1 -1
  205. package/lib/src/Gateways/GatewayResponse.d.ts +8 -0
  206. package/lib/src/Gateways/GatewayResponse.js +15 -0
  207. package/lib/src/Gateways/GatewayResponse.js.map +1 -0
  208. package/lib/src/Gateways/GpApiConnector.d.ts +41 -0
  209. package/lib/src/Gateways/GpApiConnector.js +218 -0
  210. package/lib/src/Gateways/GpApiConnector.js.map +1 -0
  211. package/lib/src/Gateways/GpEcomConnector.d.ts +36 -36
  212. package/lib/src/Gateways/GpEcomConnector.js +464 -556
  213. package/lib/src/Gateways/GpEcomConnector.js.map +1 -1
  214. package/lib/src/Gateways/IPayFacProvider.d.ts +5 -5
  215. package/lib/src/Gateways/IPayFacProvider.js +2 -2
  216. package/lib/src/Gateways/IPaymentGateway.d.ts +8 -8
  217. package/lib/src/Gateways/IPaymentGateway.js +2 -2
  218. package/lib/src/Gateways/IRecurringService.d.ts +6 -6
  219. package/lib/src/Gateways/IRecurringService.js +2 -2
  220. package/lib/src/Gateways/PayPlanConnector.d.ts +42 -42
  221. package/lib/src/Gateways/PayPlanConnector.js +531 -552
  222. package/lib/src/Gateways/PayPlanConnector.js.map +1 -1
  223. package/lib/src/Gateways/PorticoConnector.d.ts +48 -44
  224. package/lib/src/Gateways/PorticoConnector.js +1012 -1017
  225. package/lib/src/Gateways/PorticoConnector.js.map +1 -1
  226. package/lib/src/Gateways/ProPayConnector.d.ts +45 -41
  227. package/lib/src/Gateways/ProPayConnector.js +801 -694
  228. package/lib/src/Gateways/ProPayConnector.js.map +1 -1
  229. package/lib/src/Gateways/RestGateway.d.ts +8 -6
  230. package/lib/src/Gateways/RestGateway.js +48 -31
  231. package/lib/src/Gateways/RestGateway.js.map +1 -1
  232. package/lib/src/Gateways/XmlGateway.d.ts +5 -6
  233. package/lib/src/Gateways/XmlGateway.js +13 -37
  234. package/lib/src/Gateways/XmlGateway.js.map +1 -1
  235. package/lib/src/Gateways/https-wrapper.d.ts +3 -3
  236. package/lib/src/Gateways/https-wrapper.js +76 -35
  237. package/lib/src/Gateways/https-wrapper.js.map +1 -1
  238. package/lib/src/Gateways/index.d.ts +9 -8
  239. package/lib/src/Gateways/index.js +25 -20
  240. package/lib/src/Gateways/index.js.map +1 -1
  241. package/lib/src/HostedPaymentConfig.d.ts +12 -12
  242. package/lib/src/HostedPaymentConfig.js +15 -9
  243. package/lib/src/HostedPaymentConfig.js.map +1 -1
  244. package/lib/src/Mapping/GpApiMapping.d.ts +5 -0
  245. package/lib/src/Mapping/GpApiMapping.js +14 -0
  246. package/lib/src/Mapping/GpApiMapping.js.map +1 -0
  247. package/lib/src/Mapping/GpEcomMapping.d.ts +9 -9
  248. package/lib/src/Mapping/GpEcomMapping.js +84 -73
  249. package/lib/src/Mapping/GpEcomMapping.js.map +1 -1
  250. package/lib/src/Mapping/index.d.ts +2 -1
  251. package/lib/src/Mapping/index.js +18 -13
  252. package/lib/src/Mapping/index.js.map +1 -1
  253. package/lib/src/PaymentMethods/Cash.d.ts +8 -8
  254. package/lib/src/PaymentMethods/Cash.js +15 -36
  255. package/lib/src/PaymentMethods/Cash.js.map +1 -1
  256. package/lib/src/PaymentMethods/Credit.d.ts +85 -85
  257. package/lib/src/PaymentMethods/Credit.js +104 -106
  258. package/lib/src/PaymentMethods/Credit.js.map +1 -1
  259. package/lib/src/PaymentMethods/CreditCardData.d.ts +20 -20
  260. package/lib/src/PaymentMethods/CreditCardData.js +46 -57
  261. package/lib/src/PaymentMethods/CreditCardData.js.map +1 -1
  262. package/lib/src/PaymentMethods/CreditTrackData.d.ts +7 -7
  263. package/lib/src/PaymentMethods/CreditTrackData.js +9 -27
  264. package/lib/src/PaymentMethods/CreditTrackData.js.map +1 -1
  265. package/lib/src/PaymentMethods/Debit.d.ts +40 -40
  266. package/lib/src/PaymentMethods/Debit.js +51 -70
  267. package/lib/src/PaymentMethods/Debit.js.map +1 -1
  268. package/lib/src/PaymentMethods/DebitTrackData.d.ts +7 -7
  269. package/lib/src/PaymentMethods/DebitTrackData.js +9 -27
  270. package/lib/src/PaymentMethods/DebitTrackData.js.map +1 -1
  271. package/lib/src/PaymentMethods/EBT.d.ts +48 -48
  272. package/lib/src/PaymentMethods/EBT.js +67 -88
  273. package/lib/src/PaymentMethods/EBT.js.map +1 -1
  274. package/lib/src/PaymentMethods/EBTCardData.d.ts +16 -16
  275. package/lib/src/PaymentMethods/EBTCardData.js +24 -32
  276. package/lib/src/PaymentMethods/EBTCardData.js.map +1 -1
  277. package/lib/src/PaymentMethods/EBTTrackData.d.ts +8 -8
  278. package/lib/src/PaymentMethods/EBTTrackData.js +10 -27
  279. package/lib/src/PaymentMethods/EBTTrackData.js.map +1 -1
  280. package/lib/src/PaymentMethods/ECheck.d.ts +32 -32
  281. package/lib/src/PaymentMethods/ECheck.js +37 -40
  282. package/lib/src/PaymentMethods/ECheck.js.map +1 -1
  283. package/lib/src/PaymentMethods/GiftCard.d.ts +131 -131
  284. package/lib/src/PaymentMethods/GiftCard.js +188 -205
  285. package/lib/src/PaymentMethods/GiftCard.js.map +1 -1
  286. package/lib/src/PaymentMethods/Interfaces.d.ts +55 -55
  287. package/lib/src/PaymentMethods/Interfaces.js +2 -2
  288. package/lib/src/PaymentMethods/PaymentMethod.d.ts +19 -19
  289. package/lib/src/PaymentMethods/PaymentMethod.js +56 -114
  290. package/lib/src/PaymentMethods/PaymentMethod.js.map +1 -1
  291. package/lib/src/PaymentMethods/RecurringPaymentMethod.d.ts +23 -23
  292. package/lib/src/PaymentMethods/RecurringPaymentMethod.js +65 -77
  293. package/lib/src/PaymentMethods/RecurringPaymentMethod.js.map +1 -1
  294. package/lib/src/PaymentMethods/TransactionReference.d.ts +10 -10
  295. package/lib/src/PaymentMethods/TransactionReference.js +16 -12
  296. package/lib/src/PaymentMethods/TransactionReference.js.map +1 -1
  297. package/lib/src/PaymentMethods/index.d.ts +15 -15
  298. package/lib/src/PaymentMethods/index.js +31 -27
  299. package/lib/src/PaymentMethods/index.js.map +1 -1
  300. package/lib/src/ServiceConfigs/AcceptorConfig.d.ts +29 -41
  301. package/lib/src/ServiceConfigs/AcceptorConfig.js +42 -29
  302. package/lib/src/ServiceConfigs/AcceptorConfig.js.map +1 -1
  303. package/lib/src/ServiceConfigs/Configuration.d.ts +15 -15
  304. package/lib/src/ServiceConfigs/Configuration.js +19 -15
  305. package/lib/src/ServiceConfigs/Configuration.js.map +1 -1
  306. package/lib/src/ServiceConfigs/Gateways/GatewayConfig.d.ts +14 -14
  307. package/lib/src/ServiceConfigs/Gateways/GatewayConfig.js +29 -45
  308. package/lib/src/ServiceConfigs/Gateways/GatewayConfig.js.map +1 -1
  309. package/lib/src/ServiceConfigs/Gateways/GpApiConfig.d.ts +21 -0
  310. package/lib/src/ServiceConfigs/Gateways/GpApiConfig.js +44 -0
  311. package/lib/src/ServiceConfigs/Gateways/GpApiConfig.js.map +1 -0
  312. package/lib/src/ServiceConfigs/Gateways/GpEcomConfig.d.ts +21 -27
  313. package/lib/src/ServiceConfigs/Gateways/GpEcomConfig.js +49 -60
  314. package/lib/src/ServiceConfigs/Gateways/GpEcomConfig.js.map +1 -1
  315. package/lib/src/ServiceConfigs/Gateways/PorticoConfig.d.ts +22 -0
  316. package/lib/src/ServiceConfigs/Gateways/PorticoConfig.js +116 -0
  317. package/lib/src/ServiceConfigs/Gateways/PorticoConfig.js.map +1 -0
  318. package/lib/src/ServiceConfigs/Gateways/index.d.ts +4 -2
  319. package/lib/src/ServiceConfigs/Gateways/index.js +20 -14
  320. package/lib/src/ServiceConfigs/Gateways/index.js.map +1 -1
  321. package/lib/src/ServiceConfigs/ServicesConfigs.d.ts +6 -0
  322. package/lib/src/ServiceConfigs/ServicesConfigs.js +14 -0
  323. package/lib/src/ServiceConfigs/ServicesConfigs.js.map +1 -0
  324. package/lib/src/ServiceConfigs/index.d.ts +4 -5
  325. package/lib/src/ServiceConfigs/index.js +20 -17
  326. package/lib/src/ServiceConfigs/index.js.map +1 -1
  327. package/lib/src/Services/BatchService.d.ts +4 -4
  328. package/lib/src/Services/BatchService.js +14 -17
  329. package/lib/src/Services/BatchService.js.map +1 -1
  330. package/lib/src/Services/CheckService.d.ts +7 -6
  331. package/lib/src/Services/CheckService.js +19 -20
  332. package/lib/src/Services/CheckService.js.map +1 -1
  333. package/lib/src/Services/CreditService.d.ts +13 -12
  334. package/lib/src/Services/CreditService.js +53 -54
  335. package/lib/src/Services/CreditService.js.map +1 -1
  336. package/lib/src/Services/DebitService.d.ts +8 -7
  337. package/lib/src/Services/DebitService.js +27 -28
  338. package/lib/src/Services/DebitService.js.map +1 -1
  339. package/lib/src/Services/EBTService.d.ts +9 -8
  340. package/lib/src/Services/EBTService.js +30 -32
  341. package/lib/src/Services/EBTService.js.map +1 -1
  342. package/lib/src/Services/GiftService.d.ts +17 -16
  343. package/lib/src/Services/GiftService.js +53 -54
  344. package/lib/src/Services/GiftService.js.map +1 -1
  345. package/lib/src/Services/GpApiServices.d.ts +4 -0
  346. package/lib/src/Services/GpApiServices.js +44 -0
  347. package/lib/src/Services/GpApiServices.js.map +1 -0
  348. package/lib/src/Services/HostedService.d.ts +10 -9
  349. package/lib/src/Services/HostedService.js +58 -59
  350. package/lib/src/Services/HostedService.js.map +1 -1
  351. package/lib/src/Services/PayFacService.d.ts +26 -26
  352. package/lib/src/Services/PayFacService.js +75 -77
  353. package/lib/src/Services/PayFacService.js.map +1 -1
  354. package/lib/src/Services/RecurringService.d.ts +8 -8
  355. package/lib/src/Services/RecurringService.js +23 -27
  356. package/lib/src/Services/RecurringService.js.map +1 -1
  357. package/lib/src/Services/ReportingService.d.ts +6 -6
  358. package/lib/src/Services/ReportingService.js +17 -19
  359. package/lib/src/Services/ReportingService.js.map +1 -1
  360. package/lib/src/Services/index.d.ts +10 -9
  361. package/lib/src/Services/index.js +26 -21
  362. package/lib/src/Services/index.js.map +1 -1
  363. package/lib/src/ServicesContainer.d.ts +17 -26
  364. package/lib/src/ServicesContainer.js +57 -139
  365. package/lib/src/ServicesContainer.js.map +1 -1
  366. package/lib/src/Utils/GenerationUtils.d.ts +5 -5
  367. package/lib/src/Utils/GenerationUtils.js +33 -36
  368. package/lib/src/Utils/GenerationUtils.js.map +1 -1
  369. package/lib/src/Utils/InputValidation.d.ts +12 -12
  370. package/lib/src/Utils/InputValidation.js +70 -72
  371. package/lib/src/Utils/InputValidation.js.map +1 -1
  372. package/lib/src/Utils/Sha1.d.ts +6 -6
  373. package/lib/src/Utils/Sha1.js +230 -225
  374. package/lib/src/Utils/Sha1.js.map +1 -1
  375. package/lib/src/Utils/StringUtils.d.ts +6 -6
  376. package/lib/src/Utils/StringUtils.js +50 -53
  377. package/lib/src/Utils/StringUtils.js.map +1 -1
  378. package/lib/src/Utils/index.d.ts +2 -2
  379. package/lib/src/Utils/index.js +18 -14
  380. package/lib/src/Utils/index.js.map +1 -1
  381. package/lib/src/index.d.ts +12 -12
  382. package/lib/src/index.js +32 -28
  383. package/lib/src/index.js.map +1 -1
  384. package/lib/test/Data/BaseGpApiTestConfig.d.ts +13 -0
  385. package/lib/test/Data/BaseGpApiTestConfig.js +42 -0
  386. package/lib/test/Data/BaseGpApiTestConfig.js.map +1 -0
  387. package/lib/test/Data/TestCards.d.ts +24 -24
  388. package/lib/test/Data/TestCards.js +219 -232
  389. package/lib/test/Data/TestCards.js.map +1 -1
  390. package/lib/test/Data/TestChecks.d.ts +4 -4
  391. package/lib/test/Data/TestChecks.js +26 -32
  392. package/lib/test/Data/TestChecks.js.map +1 -1
  393. package/lib/test/Data/index.d.ts +2 -2
  394. package/lib/test/Data/index.js +18 -14
  395. package/lib/test/Data/index.js.map +1 -1
  396. package/lib/test/Integration/Gateways/{ProPayConnector/Certifications/GetInformationCertificationTests.d.ts → GpApiConnector/AccessTokenTest.d.ts} +1 -1
  397. package/lib/test/Integration/Gateways/GpApiConnector/AccessTokenTest.js +102 -0
  398. package/lib/test/Integration/Gateways/GpApiConnector/AccessTokenTest.js.map +1 -0
  399. package/lib/test/Integration/Gateways/{RealexConnector → GpEcomConnector}/Certification/AuthTest.d.ts +1 -1
  400. package/lib/test/Integration/Gateways/GpEcomConnector/Certification/AuthTest.js +2446 -0
  401. package/lib/test/Integration/Gateways/GpEcomConnector/Certification/AuthTest.js.map +1 -0
  402. package/lib/test/Integration/Gateways/{RealexConnector → GpEcomConnector}/Certification/AvsTest.d.ts +1 -1
  403. package/lib/test/Integration/Gateways/GpEcomConnector/Certification/AvsTest.js +506 -0
  404. package/lib/test/Integration/Gateways/GpEcomConnector/Certification/AvsTest.js.map +1 -0
  405. package/lib/test/Integration/Gateways/{RealexConnector → GpEcomConnector}/Certification/CreditTest.d.ts +1 -1
  406. package/lib/test/Integration/Gateways/GpEcomConnector/Certification/CreditTest.js +1296 -0
  407. package/lib/test/Integration/Gateways/GpEcomConnector/Certification/CreditTest.js.map +1 -0
  408. package/lib/test/Integration/Gateways/{RealexConnector → GpEcomConnector}/Certification/HoldTest.d.ts +1 -1
  409. package/lib/test/Integration/Gateways/GpEcomConnector/Certification/HoldTest.js +847 -0
  410. package/lib/test/Integration/Gateways/GpEcomConnector/Certification/HoldTest.js.map +1 -0
  411. package/lib/test/Integration/Gateways/{RealexConnector → GpEcomConnector}/CreditTest.d.ts +1 -1
  412. package/lib/test/Integration/Gateways/GpEcomConnector/CreditTest.js +214 -0
  413. package/lib/test/Integration/Gateways/GpEcomConnector/CreditTest.js.map +1 -0
  414. package/lib/test/Integration/Gateways/{RealexConnector → GpEcomConnector}/HppTest.d.ts +1 -1
  415. package/lib/test/Integration/Gateways/GpEcomConnector/HppTest.js +98 -0
  416. package/lib/test/Integration/Gateways/GpEcomConnector/HppTest.js.map +1 -0
  417. package/lib/test/Integration/Gateways/{RealexConnector → GpEcomConnector}/RecurringTest.d.ts +1 -1
  418. package/lib/test/Integration/Gateways/GpEcomConnector/RecurringTest.js +132 -0
  419. package/lib/test/Integration/Gateways/GpEcomConnector/RecurringTest.js.map +1 -0
  420. package/lib/test/Integration/Gateways/PorticoConnector/AchTest.d.ts +1 -1
  421. package/lib/test/Integration/Gateways/PorticoConnector/AchTest.js +58 -112
  422. package/lib/test/Integration/Gateways/PorticoConnector/AchTest.js.map +1 -1
  423. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/CheckTest.d.ts +1 -1
  424. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/CheckTest.js +377 -483
  425. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/CheckTest.js.map +1 -1
  426. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceCheckTest.d.ts +1 -1
  427. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceCheckTest.js +85 -83
  428. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceCheckTest.js.map +1 -1
  429. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceTest.d.ts +1 -1
  430. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceTest.js +1722 -1720
  431. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/EcommerceTest.js.map +1 -1
  432. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoCheckTest.d.ts +1 -1
  433. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoCheckTest.js +85 -83
  434. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoCheckTest.js.map +1 -1
  435. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoTest.d.ts +1 -1
  436. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoTest.js +1759 -1757
  437. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/MotoTest.js.map +1 -1
  438. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RecurringTest.d.ts +1 -1
  439. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RecurringTest.js +419 -682
  440. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RecurringTest.js.map +1 -1
  441. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RetailTest.d.ts +1 -1
  442. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RetailTest.js +2220 -2218
  443. package/lib/test/Integration/Gateways/PorticoConnector/Certifications/RetailTest.js.map +1 -1
  444. package/lib/test/Integration/Gateways/PorticoConnector/CreditTest.d.ts +1 -1
  445. package/lib/test/Integration/Gateways/PorticoConnector/CreditTest.js +391 -707
  446. package/lib/test/Integration/Gateways/PorticoConnector/CreditTest.js.map +1 -1
  447. package/lib/test/Integration/Gateways/PorticoConnector/DebitTest.d.ts +1 -1
  448. package/lib/test/Integration/Gateways/PorticoConnector/DebitTest.js +81 -151
  449. package/lib/test/Integration/Gateways/PorticoConnector/DebitTest.js.map +1 -1
  450. package/lib/test/Integration/Gateways/PorticoConnector/EbtTest.d.ts +1 -1
  451. package/lib/test/Integration/Gateways/PorticoConnector/EbtTest.js +71 -171
  452. package/lib/test/Integration/Gateways/PorticoConnector/EbtTest.js.map +1 -1
  453. package/lib/test/Integration/Gateways/PorticoConnector/EcommerceTest.d.ts +1 -1
  454. package/lib/test/Integration/Gateways/PorticoConnector/EcommerceTest.js +110 -192
  455. package/lib/test/Integration/Gateways/PorticoConnector/EcommerceTest.js.map +1 -1
  456. package/lib/test/Integration/Gateways/PorticoConnector/GiftTest.d.ts +1 -1
  457. package/lib/test/Integration/Gateways/PorticoConnector/GiftTest.js +146 -377
  458. package/lib/test/Integration/Gateways/PorticoConnector/GiftTest.js.map +1 -1
  459. package/lib/test/Integration/Gateways/PorticoConnector/RecurringTest.d.ts +1 -1
  460. package/lib/test/Integration/Gateways/PorticoConnector/RecurringTest.js +100 -196
  461. package/lib/test/Integration/Gateways/PorticoConnector/RecurringTest.js.map +1 -1
  462. package/lib/test/Integration/Gateways/PorticoConnector/ReportingTest.d.ts +1 -1
  463. package/lib/test/Integration/Gateways/PorticoConnector/ReportingTest.js +49 -47
  464. package/lib/test/Integration/Gateways/PorticoConnector/ReportingTest.js.map +1 -1
  465. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayAccountCertificationTests.d.ts → GetInformationCertificationTest.d.ts} +1 -1
  466. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/GetInformationCertificationTest.js +44 -0
  467. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/GetInformationCertificationTest.js.map +1 -0
  468. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayFundCertificationTests.d.ts → ProPayAccountCertificationTest.d.ts} +1 -1
  469. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayAccountCertificationTest.js +221 -0
  470. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayAccountCertificationTest.js.map +1 -0
  471. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/{ProPayInNetworkTransactionCertificationTests.d.ts → ProPayFundCertificationTest.d.ts} +1 -1
  472. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayFundCertificationTest.js +60 -0
  473. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayFundCertificationTest.js.map +1 -0
  474. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayInNetworkTransactionCertificationTest.d.ts +1 -0
  475. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayInNetworkTransactionCertificationTest.js +80 -0
  476. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayInNetworkTransactionCertificationTest.js.map +1 -0
  477. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/TestData/TestAccountData.d.ts +39 -39
  478. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/TestData/TestAccountData.js +392 -371
  479. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/TestData/TestAccountData.js.map +1 -1
  480. package/lib/test/Integration/Gateways/ProPayConnector/GetInformationTest.d.ts +1 -0
  481. package/lib/test/Integration/Gateways/ProPayConnector/GetInformationTest.js +44 -0
  482. package/lib/test/Integration/Gateways/ProPayConnector/GetInformationTest.js.map +1 -0
  483. package/lib/test/Integration/Gateways/ProPayConnector/ProPayAccountTest.d.ts +1 -0
  484. package/lib/test/Integration/Gateways/ProPayConnector/ProPayAccountTest.js +330 -0
  485. package/lib/test/Integration/Gateways/ProPayConnector/ProPayAccountTest.js.map +1 -0
  486. package/lib/test/Integration/Gateways/ProPayConnector/ProPayFundsTest.d.ts +1 -0
  487. package/lib/test/Integration/Gateways/ProPayConnector/ProPayFundsTest.js +60 -0
  488. package/lib/test/Integration/Gateways/ProPayConnector/ProPayFundsTest.js.map +1 -0
  489. package/lib/test/Integration/Gateways/ProPayConnector/ProPayInNetworkTransactionTest.d.ts +1 -0
  490. package/lib/test/Integration/Gateways/ProPayConnector/ProPayInNetworkTransactionTest.js +80 -0
  491. package/lib/test/Integration/Gateways/ProPayConnector/ProPayInNetworkTransactionTest.js.map +1 -0
  492. package/lib/test/Integration/Gateways/ProPayConnector/TestData/TestAccountData.d.ts +34 -33
  493. package/lib/test/Integration/Gateways/ProPayConnector/TestData/TestAccountData.js +321 -268
  494. package/lib/test/Integration/Gateways/ProPayConnector/TestData/TestAccountData.js.map +1 -1
  495. package/lib/test/Integration/Gateways/ProPayConnector/TestData/TestFundsData.d.ts +4 -4
  496. package/lib/test/Integration/Gateways/ProPayConnector/TestData/TestFundsData.js +27 -30
  497. package/lib/test/Integration/Gateways/ProPayConnector/TestData/TestFundsData.js.map +1 -1
  498. package/lib/test/Integration/Services/CheckServiceTest.d.ts +1 -1
  499. package/lib/test/Integration/Services/CheckServiceTest.js +44 -98
  500. package/lib/test/Integration/Services/CheckServiceTest.js.map +1 -1
  501. package/lib/test/Integration/Services/CreditServiceTest.d.ts +1 -1
  502. package/lib/test/Integration/Services/CreditServiceTest.js +173 -313
  503. package/lib/test/Integration/Services/CreditServiceTest.js.map +1 -1
  504. package/lib/test/Integration/Services/DebitServiceTest.d.ts +1 -1
  505. package/lib/test/Integration/Services/DebitServiceTest.js +80 -154
  506. package/lib/test/Integration/Services/DebitServiceTest.js.map +1 -1
  507. package/lib/test/Integration/Services/EBTServiceTest.d.ts +1 -1
  508. package/lib/test/Integration/Services/EBTServiceTest.js +63 -135
  509. package/lib/test/Integration/Services/EBTServiceTest.js.map +1 -1
  510. package/lib/test/Unit/Builders/AuthorizationBuilder/ValidationTest.d.ts +1 -1
  511. package/lib/test/Unit/Builders/AuthorizationBuilder/ValidationTest.js +110 -161
  512. package/lib/test/Unit/Builders/AuthorizationBuilder/ValidationTest.js.map +1 -1
  513. package/lib/test/Unit/Builders/ReportBuilder/ValidationTest.d.ts +1 -1
  514. package/lib/test/Unit/Builders/ReportBuilder/ValidationTest.js +61 -139
  515. package/lib/test/Unit/Builders/ReportBuilder/ValidationTest.js.map +1 -1
  516. package/lib/test/Unit/Gateways/GpEcomConnector/CreditTest.d.ts +1 -1
  517. package/lib/test/Unit/Gateways/GpEcomConnector/CreditTest.js +33 -72
  518. package/lib/test/Unit/Gateways/GpEcomConnector/CreditTest.js.map +1 -1
  519. package/lib/test/Unit/Gateways/PorticoConnector/InputValidationTest.d.ts +1 -1
  520. package/lib/test/Unit/Gateways/PorticoConnector/InputValidationTest.js +124 -202
  521. package/lib/test/Unit/Gateways/PorticoConnector/InputValidationTest.js.map +1 -1
  522. package/package.json +65 -58
  523. package/tsconfig.eslint.json +15 -0
  524. package/lib/src/Gateways/RealexConnector.d.ts +0 -30
  525. package/lib/src/Gateways/RealexConnector.js +0 -524
  526. package/lib/src/Gateways/RealexConnector.js.map +0 -1
  527. package/lib/src/ServiceConfigs/ServicesConfig.d.ts +0 -27
  528. package/lib/src/ServiceConfigs/ServicesConfig.js +0 -51
  529. package/lib/src/ServiceConfigs/ServicesConfig.js.map +0 -1
  530. package/lib/src/ServiceConfigs/ServicesConfigsAdded.d.ts +0 -10
  531. package/lib/src/ServiceConfigs/ServicesConfigsAdded.js +0 -27
  532. package/lib/src/ServiceConfigs/ServicesConfigsAdded.js.map +0 -1
  533. package/lib/src/ServicesConfig.d.ts +0 -27
  534. package/lib/src/ServicesConfig.js +0 -51
  535. package/lib/src/ServicesConfig.js.map +0 -1
  536. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/GetInformationCertificationTests.js +0 -101
  537. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/GetInformationCertificationTests.js.map +0 -1
  538. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayAccountCertificationTests.js +0 -353
  539. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayAccountCertificationTests.js.map +0 -1
  540. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayFundCertificationTests.js +0 -124
  541. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayFundCertificationTests.js.map +0 -1
  542. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayInNetworkTransactionCertificationTests.js +0 -143
  543. package/lib/test/Integration/Gateways/ProPayConnector/Certifications/ProPayInNetworkTransactionCertificationTests.js.map +0 -1
  544. package/lib/test/Integration/Gateways/ProPayConnector/GetInformationTests.d.ts +0 -1
  545. package/lib/test/Integration/Gateways/ProPayConnector/GetInformationTests.js +0 -101
  546. package/lib/test/Integration/Gateways/ProPayConnector/GetInformationTests.js.map +0 -1
  547. package/lib/test/Integration/Gateways/ProPayConnector/ProPayAccountTests.d.ts +0 -1
  548. package/lib/test/Integration/Gateways/ProPayConnector/ProPayAccountTests.js +0 -536
  549. package/lib/test/Integration/Gateways/ProPayConnector/ProPayAccountTests.js.map +0 -1
  550. package/lib/test/Integration/Gateways/ProPayConnector/ProPayFundsTests.d.ts +0 -1
  551. package/lib/test/Integration/Gateways/ProPayConnector/ProPayFundsTests.js +0 -125
  552. package/lib/test/Integration/Gateways/ProPayConnector/ProPayFundsTests.js.map +0 -1
  553. package/lib/test/Integration/Gateways/ProPayConnector/ProPayInNetworkTransactionTests.d.ts +0 -1
  554. package/lib/test/Integration/Gateways/ProPayConnector/ProPayInNetworkTransactionTests.js +0 -145
  555. package/lib/test/Integration/Gateways/ProPayConnector/ProPayInNetworkTransactionTests.js.map +0 -1
  556. package/lib/test/Integration/Gateways/RealexConnector/Certification/AuthTest.js +0 -4374
  557. package/lib/test/Integration/Gateways/RealexConnector/Certification/AuthTest.js.map +0 -1
  558. package/lib/test/Integration/Gateways/RealexConnector/Certification/AvsTest.js +0 -759
  559. package/lib/test/Integration/Gateways/RealexConnector/Certification/AvsTest.js.map +0 -1
  560. package/lib/test/Integration/Gateways/RealexConnector/Certification/CreditTest.js +0 -2400
  561. package/lib/test/Integration/Gateways/RealexConnector/Certification/CreditTest.js.map +0 -1
  562. package/lib/test/Integration/Gateways/RealexConnector/Certification/HoldTest.js +0 -1657
  563. package/lib/test/Integration/Gateways/RealexConnector/Certification/HoldTest.js.map +0 -1
  564. package/lib/test/Integration/Gateways/RealexConnector/Certification/ManualTest.d.ts +0 -1
  565. package/lib/test/Integration/Gateways/RealexConnector/Certification/ManualTest.js +0 -5651
  566. package/lib/test/Integration/Gateways/RealexConnector/Certification/ManualTest.js.map +0 -1
  567. package/lib/test/Integration/Gateways/RealexConnector/Certification/OtbTest.d.ts +0 -1
  568. package/lib/test/Integration/Gateways/RealexConnector/Certification/OtbTest.js +0 -1986
  569. package/lib/test/Integration/Gateways/RealexConnector/Certification/OtbTest.js.map +0 -1
  570. package/lib/test/Integration/Gateways/RealexConnector/Certification/RebateTest.d.ts +0 -1
  571. package/lib/test/Integration/Gateways/RealexConnector/Certification/RebateTest.js +0 -2370
  572. package/lib/test/Integration/Gateways/RealexConnector/Certification/RebateTest.js.map +0 -1
  573. package/lib/test/Integration/Gateways/RealexConnector/Certification/ReleaseTest.d.ts +0 -1
  574. package/lib/test/Integration/Gateways/RealexConnector/Certification/ReleaseTest.js +0 -1704
  575. package/lib/test/Integration/Gateways/RealexConnector/Certification/ReleaseTest.js.map +0 -1
  576. package/lib/test/Integration/Gateways/RealexConnector/Certification/SettleTest.d.ts +0 -1
  577. package/lib/test/Integration/Gateways/RealexConnector/Certification/SettleTest.js +0 -2054
  578. package/lib/test/Integration/Gateways/RealexConnector/Certification/SettleTest.js.map +0 -1
  579. package/lib/test/Integration/Gateways/RealexConnector/Certification/ValidationTest.d.ts +0 -1
  580. package/lib/test/Integration/Gateways/RealexConnector/Certification/ValidationTest.js +0 -2470
  581. package/lib/test/Integration/Gateways/RealexConnector/Certification/ValidationTest.js.map +0 -1
  582. package/lib/test/Integration/Gateways/RealexConnector/Certification/VerifyEnrolledTest.d.ts +0 -1
  583. package/lib/test/Integration/Gateways/RealexConnector/Certification/VerifyEnrolledTest.js +0 -3117
  584. package/lib/test/Integration/Gateways/RealexConnector/Certification/VerifyEnrolledTest.js.map +0 -1
  585. package/lib/test/Integration/Gateways/RealexConnector/Certification/VoidTest.d.ts +0 -1
  586. package/lib/test/Integration/Gateways/RealexConnector/Certification/VoidTest.js +0 -2032
  587. package/lib/test/Integration/Gateways/RealexConnector/Certification/VoidTest.js.map +0 -1
  588. package/lib/test/Integration/Gateways/RealexConnector/CreditTest.js +0 -323
  589. package/lib/test/Integration/Gateways/RealexConnector/CreditTest.js.map +0 -1
  590. package/lib/test/Integration/Gateways/RealexConnector/HppTest.js +0 -99
  591. package/lib/test/Integration/Gateways/RealexConnector/HppTest.js.map +0 -1
  592. package/lib/test/Integration/Gateways/RealexConnector/RecurringTest.js +0 -264
  593. package/lib/test/Integration/Gateways/RealexConnector/RecurringTest.js.map +0 -1
  594. package/lib/test/Unit/Gateways/RealexConnector/CreditTest.d.ts +0 -1
  595. package/lib/test/Unit/Gateways/RealexConnector/CreditTest.js +0 -71
  596. package/lib/test/Unit/Gateways/RealexConnector/CreditTest.js.map +0 -1
@@ -1,557 +1,465 @@
1
- "use strict";
2
- var __extends = (this && this.__extends) || (function () {
3
- var extendStatics = function (d, b) {
4
- extendStatics = Object.setPrototypeOf ||
5
- ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
- function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
- return extendStatics(d, b);
8
- };
9
- return function (d, b) {
10
- if (typeof b !== "function" && b !== null)
11
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
- extendStatics(d, b);
13
- function __() { this.constructor = d; }
14
- d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
- };
16
- })();
17
- Object.defineProperty(exports, "__esModule", { value: true });
18
- exports.GpEcomConnector = void 0;
19
- var elementtree_1 = require("@azz/elementtree");
20
- var __1 = require("..");
21
- var XmlGateway_1 = require("./XmlGateway");
22
- var src_1 = require("../../src");
23
- var GpEcomConnector = /** @class */ (function (_super) {
24
- __extends(GpEcomConnector, _super);
25
- function GpEcomConnector(config) {
26
- var _this = _super.call(this) || this;
27
- _this.supportsHostedPayments = true;
28
- _this.supportsRetrieval = false;
29
- _this.supportsUpdatePaymentDetails = true;
30
- _this.config = config;
31
- return _this;
32
- }
33
- // @ts-ignore
34
- GpEcomConnector.prototype.processAuthorization = function (builder) {
35
- var transactionType = src_1.GpEcomMapping.mapAuthRequestType(builder);
36
- var acceptedResponseCodes = this.mapAcceptedCodes(transactionType);
37
- return this.executeProcess(builder).then(function (response) {
38
- return src_1.GpEcomMapping.mapResponse(response, acceptedResponseCodes);
39
- });
40
- };
41
- GpEcomConnector.prototype.executeProcess = function (builder) {
42
- var processFactory = new __1.RequestBuilderFactory();
43
- var requestBuilder = processFactory.getRequestBuilder(builder, this.config.gatewayProvider);
44
- if (!requestBuilder) {
45
- throw new Error("Request builder not found!");
46
- }
47
- var request = requestBuilder.buildRequest(builder, this.config);
48
- if (!request) {
49
- throw new Error("Request was not generated!");
50
- }
51
- return this.doTransaction(request.requestBody);
52
- };
53
- GpEcomConnector.prototype.processOldAuthorization = function (builder) {
54
- var _this = this;
55
- var timestamp = __1.GenerationUtils.generateTimestamp();
56
- var orderId = builder.orderId
57
- ? builder.orderId
58
- : __1.GenerationUtils.generateOrderId();
59
- // build Request
60
- var request = elementtree_1.Element("request", {
61
- timestamp: timestamp,
62
- type: this.mapAuthRequestType(builder),
63
- });
64
- if (this.merchantId) {
65
- elementtree_1.SubElement(request, "merchantid").append(elementtree_1.CData(this.merchantId));
66
- }
67
- if (this.accountId) {
68
- elementtree_1.SubElement(request, "account").append(elementtree_1.CData(this.accountId));
69
- }
70
- if (this.channel) {
71
- elementtree_1.SubElement(request, "channel").append(elementtree_1.CData(this.channel));
72
- }
73
- elementtree_1.SubElement(request, "orderid").append(elementtree_1.CData(orderId));
74
- if (builder.amount) {
75
- var amountAttrs = builder.currency
76
- ? { currency: builder.currency }
77
- : {};
78
- elementtree_1.SubElement(request, "amount", amountAttrs).append(elementtree_1.CData(this.numberFormat(builder.amount)));
79
- }
80
- // hydrate the payment data fields
81
- if (builder.paymentMethod instanceof __1.CreditCardData) {
82
- var card = builder.paymentMethod;
83
- if (builder.transactionModifier === __1.TransactionModifier.EncryptedMobile) {
84
- elementtree_1.SubElement(request, "token").append(elementtree_1.CData(card.token));
85
- elementtree_1.SubElement(request, "mobile").append(elementtree_1.CData(card.mobileType));
86
- }
87
- else {
88
- var cardElement = elementtree_1.SubElement(request, "card");
89
- elementtree_1.SubElement(cardElement, "number").append(elementtree_1.CData(card.number));
90
- var date = __1.StringUtils.leftPad(card.expMonth, 2, "0") +
91
- __1.StringUtils.leftPad((card.expYear || "").substr(2, 2), 2, "0");
92
- elementtree_1.SubElement(cardElement, "expdate").append(elementtree_1.CData(date));
93
- elementtree_1.SubElement(cardElement, "type").append(elementtree_1.CData(card.getCardType().toUpperCase()));
94
- elementtree_1.SubElement(cardElement, "chname").append(elementtree_1.CData(card.cardHolderName));
95
- if (card.cvn) {
96
- var cvnElement = elementtree_1.SubElement(cardElement, "cvn");
97
- elementtree_1.SubElement(cvnElement, "number").append(elementtree_1.CData(card.cvn));
98
- elementtree_1.SubElement(cvnElement, "presind").append(elementtree_1.CData(card.cvnPresenceIndicator.toString()));
99
- }
100
- // issueno
101
- }
102
- var isVerify = builder.transactionType === __1.TransactionType.Verify;
103
- elementtree_1.SubElement(request, "sha1hash").append(elementtree_1.CData(this.generateHash(timestamp, orderId, builder.amount ? this.numberFormat(builder.amount) : "", builder.currency, builder.transactionModifier === __1.TransactionModifier.EncryptedMobile
104
- ? card.token
105
- : card.number, isVerify)));
106
- }
107
- if (builder.paymentMethod instanceof __1.RecurringPaymentMethod) {
108
- var recurring = builder.paymentMethod;
109
- elementtree_1.SubElement(request, "payerref").append(elementtree_1.CData(recurring.customerKey));
110
- elementtree_1.SubElement(request, "paymentmethod").append(elementtree_1.CData(recurring.key || recurring.id));
111
- if (builder.cvn) {
112
- var paymentData = elementtree_1.SubElement(request, "paymentdata");
113
- var cvn = elementtree_1.SubElement(paymentData, "cvn");
114
- elementtree_1.SubElement(cvn, "number").append(elementtree_1.CData(builder.cvn));
115
- }
116
- var isVerify = builder.transactionType === __1.TransactionType.Verify;
117
- elementtree_1.SubElement(request, "sha1hash").append(elementtree_1.CData(this.generateHash(timestamp, orderId, builder.amount ? this.numberFormat(builder.amount) : "", builder.currency, recurring.customerKey, isVerify)));
118
- }
119
- // refund hash
120
- if (builder.transactionType === __1.TransactionType.Refund) {
121
- elementtree_1.SubElement(request, "refundhash").append(elementtree_1.CData(__1.GenerationUtils.generateHash(this.refundPassword) || ""));
122
- }
123
- // this needs to be figured out based on txn type and set to 0, 1 or MULTI
124
- if (builder.transactionType === __1.TransactionType.Sale ||
125
- builder.transactionType === __1.TransactionType.Auth) {
126
- var autoSettle = builder.transactionType === __1.TransactionType.Sale ? "1" : "0";
127
- elementtree_1.SubElement(request, "autosettle", { flag: autoSettle });
128
- }
129
- if (builder.description) {
130
- var comments = elementtree_1.SubElement(request, "comments");
131
- elementtree_1.SubElement(comments, "comment", { id: 1 }).append(elementtree_1.CData(builder.description));
132
- }
133
- if (builder.customerId ||
134
- builder.productId ||
135
- builder.customerIpAddress ||
136
- builder.clientTransactionId) {
137
- var tssInfo = elementtree_1.SubElement(request, "tssinfo");
138
- elementtree_1.SubElement(tssInfo, "custnum").append(elementtree_1.CData(builder.customerId));
139
- elementtree_1.SubElement(tssInfo, "prodid").append(elementtree_1.CData(builder.productId));
140
- elementtree_1.SubElement(tssInfo, "varref").append(elementtree_1.CData(builder.clientTransactionId));
141
- elementtree_1.SubElement(tssInfo, "custipaddress").append(elementtree_1.CData(builder.customerIpAddress));
142
- }
143
- if (builder.ecommerceInfo) {
144
- var mpi = elementtree_1.SubElement(request, "mpi");
145
- elementtree_1.SubElement(mpi, "cavv").append(elementtree_1.CData(builder.ecommerceInfo.cavv));
146
- elementtree_1.SubElement(mpi, "xid").append(elementtree_1.CData(builder.ecommerceInfo.xid));
147
- elementtree_1.SubElement(mpi, "eci").append(elementtree_1.CData(builder.ecommerceInfo.eci));
148
- }
149
- return this.doTransaction(this.buildEnvelope(request)).then(function (response) {
150
- return _this.mapResponse(response);
151
- });
152
- };
153
- GpEcomConnector.prototype.serializeRequest = function (builder) {
154
- if (!this.hostedPaymentConfig) {
155
- throw new __1.ApiError("Hosted configuration missing. Please check your configuration");
156
- }
157
- var encoder = this.hostedPaymentConfig.version === __1.HppVersion.Version2
158
- ? function (t) { return t; }
159
- : __1.StringUtils.btoa;
160
- var request = {};
161
- var orderId = builder.orderId || __1.GenerationUtils.generateOrderId();
162
- var timestamp = builder.timestamp || __1.GenerationUtils.generateTimestamp();
163
- if (builder.transactionType !== __1.TransactionType.Sale &&
164
- builder.transactionType !== __1.TransactionType.Auth &&
165
- builder.transactionType !== __1.TransactionType.Verify) {
166
- throw new __1.UnsupportedTransactionError();
167
- }
168
- request.MERCHANT_ID = encoder(this.merchantId || "");
169
- request.ACCOUNT = encoder(this.accountId || "");
170
- request.CHANNEL = encoder(this.channel || "");
171
- request.ORDER_ID = encoder(orderId || "");
172
- if (builder.amount) {
173
- request.AMOUNT = encoder(this.numberFormat(builder.amount) || "");
174
- }
175
- request.CURRENCY = encoder(builder.currency || "");
176
- request.TIMESTAMP = encoder(timestamp || "");
177
- request.AUTO_SETTLE_FLAG = encoder(builder.transactionType === __1.TransactionType.Sale ? "1" : "0" || "");
178
- request.COMMENT1 = encoder(builder.Description || "");
179
- // request.COMMENT2 = encoder( || "");
180
- if (this.hostedPaymentConfig.requestTransactionStabilityScore) {
181
- request.RETURN_TSS = encoder(this.hostedPaymentConfig.requestTransactionStabilityScore
182
- ? "1"
183
- : "0" || "");
184
- }
185
- if (this.hostedPaymentConfig.directCurrencyConversionEnabled) {
186
- request.DCC_ENABLE = encoder(this.hostedPaymentConfig.directCurrencyConversionEnabled
187
- ? "1"
188
- : "0" || "");
189
- }
190
- if (builder.hostedPaymentData) {
191
- request.CUST_NUM = encoder(builder.hostedPaymentData.customerNumber || "");
192
- if (this.hostedPaymentConfig.displaySavedCards &&
193
- builder.hostedPaymentData.customerKey) {
194
- request.HPP_SELECT_STORED_CARD = encoder(builder.hostedPaymentData.customerKey || "");
195
- }
196
- if (builder.hostedPaymentData.offerToSaveCard) {
197
- request.OFFER_SAVE_CARD = encoder(builder.hostedPaymentData.offerToSaveCard ? "1" : "0" || "");
198
- }
199
- if (builder.hostedPaymentData.customerExists) {
200
- request.PAYER_EXIST = encoder(builder.hostedPaymentData.customerExists ? "1" : "0" || "");
201
- }
202
- request.PAYER_REF = encoder(builder.hostedPaymentData.customerKey || "");
203
- request.PMT_REF = encoder(builder.hostedPaymentData.paymentKey || "");
204
- request.PROD_ID = encoder(builder.hostedPaymentData.productId || "");
205
- }
206
- if (builder.shippingAddress) {
207
- request.SHIPPING_CODE = encoder(builder.shippingAddress.postalCode || "");
208
- request.SHIPPING_CO = encoder(builder.shippingAddress.country || "");
209
- }
210
- if (builder.sillingAddress) {
211
- request.BILLING_CODE = encoder(builder.billingAddress.postalCode || "");
212
- request.BILLING_CO = encoder(builder.billingAddress.country || "");
213
- }
214
- request.CUST_NUM = encoder(builder.customerId || "");
215
- request.VAR_REF = encoder(builder.clientTransactionId || "");
216
- request.HPP_LANG = encoder(this.hostedPaymentConfig.language || "");
217
- request.MERCHANT_RESPONSE_URL = encoder(this.hostedPaymentConfig.responseUrl || "");
218
- request.CARD_PAYMENT_BUTTON = encoder(this.hostedPaymentConfig.paymentButtonText || "");
219
- if (this.hostedPaymentConfig.cardStorageEnabled) {
220
- request.CARD_STORAGE_ENABLE = encoder(this.hostedPaymentConfig.cardStorageEnabled ? "1" : "0" || "");
221
- }
222
- if (builder.transactionType === __1.TransactionType.Verify) {
223
- request.VALIDATE_CARD_ONLY = encoder("1" || "");
224
- }
225
- if (this.hostedPaymentConfig.fraudFilterMode) {
226
- request.HPP_FRAUD_FILTER_MODE = encoder(this.hostedPaymentConfig.fraudFilterMode.toString() || "");
227
- }
228
- if (builder.recurringType || builder.recurringSequence) {
229
- if (builder.recurringType) {
230
- request.RECURRING_TYPE = encoder(builder.recurringType.toString().toLowerCase() || "");
231
- }
232
- if (builder.recurringSequence) {
233
- request.RECURRING_SEQUENCE = encoder(builder.recurringSequence.toString().toLowerCase() || "");
234
- }
235
- }
236
- if (this.hostedPaymentConfig.version) {
237
- request.HPP_VERSION = encoder(this.hostedPaymentConfig.version.toString() || "");
238
- }
239
- var toHash = [
240
- timestamp,
241
- this.merchantId,
242
- orderId,
243
- builder.amount ? this.numberFormat(builder.amount) : null,
244
- builder.currency,
245
- ];
246
- if (this.hostedPaymentConfig.cardStorageEnabled ||
247
- (builder.hostedPaymentData && builder.hostedPaymentData.offerToSaveCard)) {
248
- toHash.push(builder.hostedPaymentData.customerKey
249
- ? builder.hostedPaymentData.customerKey
250
- : null);
251
- toHash.push(builder.hostedPaymentData.paymentKey
252
- ? builder.hostedPaymentData.paymentKey
253
- : null);
254
- }
255
- if (this.hostedPaymentConfig.fraudFilterMode &&
256
- this.hostedPaymentConfig.fraudFilterMode !== __1.FraudFilterMode.None) {
257
- toHash.push(this.hostedPaymentConfig.fraudFilterMode.toString());
258
- }
259
- request.SHA1HASH = encoder(__1.GenerationUtils.generateHash(toHash.join("."), this.sharedSecret) || "");
260
- return JSON.stringify(request);
261
- };
262
- GpEcomConnector.prototype.manageTransaction = function (builder) {
263
- var _this = this;
264
- var timestamp = __1.GenerationUtils.generateTimestamp();
265
- var orderId = builder.orderId || __1.GenerationUtils.generateOrderId();
266
- // build Request
267
- var request = elementtree_1.Element("request", {
268
- timestamp: timestamp,
269
- type: this.mapManageRequestType(builder.transactionType),
270
- });
271
- if (this.merchantId) {
272
- elementtree_1.SubElement(request, "merchantid").append(elementtree_1.CData(this.merchantId));
273
- }
274
- if (this.accountId) {
275
- elementtree_1.SubElement(request, "account").append(elementtree_1.CData(this.accountId));
276
- }
277
- if (this.channel) {
278
- elementtree_1.SubElement(request, "channel").append(elementtree_1.CData(this.channel));
279
- }
280
- elementtree_1.SubElement(request, "orderid").append(elementtree_1.CData(orderId));
281
- if (builder.paymentMethod) {
282
- var ref = builder.paymentMethod;
283
- elementtree_1.SubElement(request, "pasref").append(elementtree_1.CData(ref.transactionId));
284
- }
285
- if (builder.amount) {
286
- var amountAttrs = builder.currency
287
- ? { currency: builder.currency }
288
- : {};
289
- elementtree_1.SubElement(request, "amount", amountAttrs).append(elementtree_1.CData(this.numberFormat(builder.amount)));
290
- }
291
- else if (builder.transactionType === __1.TransactionType.Capture) {
292
- throw new __1.BuilderError("Amount cannot be null for capture");
293
- }
294
- if (builder.transactionType === __1.TransactionType.Refund) {
295
- if (builder.authorizationCode) {
296
- elementtree_1.SubElement(request, "authcode").append(elementtree_1.CData(builder.authorizationCode));
297
- }
298
- elementtree_1.SubElement(request, "refundhash").append(elementtree_1.CData(__1.GenerationUtils.generateHash(this.rebatePassword)));
299
- }
300
- if (builder.reasonCode) {
301
- elementtree_1.SubElement(request, "reasoncode").append(elementtree_1.CData(builder.reasonCode.toString()));
302
- }
303
- if (builder.description) {
304
- var comments = elementtree_1.SubElement(request, "comments");
305
- elementtree_1.SubElement(comments, "comment", { id: 1 }).append(elementtree_1.CData(builder.description));
306
- }
307
- elementtree_1.SubElement(request, "sha1hash").append(elementtree_1.CData(this.generateHash(timestamp, orderId, builder.amount ? this.numberFormat(builder.amount) : "", builder.currency, "")));
308
- return this.doTransaction(this.buildEnvelope(request)).then(function (response) {
309
- return _this.mapResponse(response);
310
- });
311
- };
312
- GpEcomConnector.prototype.processReport = function (_builder) {
313
- throw new __1.UnsupportedTransactionError("Reporting functionality is not supported through this gateway.");
314
- };
315
- GpEcomConnector.prototype.processRecurring = function (builder) {
316
- var _this = this;
317
- var timestamp = __1.GenerationUtils.generateTimestamp();
318
- var orderId = builder.orderId || __1.GenerationUtils.generateOrderId();
319
- // build Request
320
- var request = elementtree_1.Element("request", {
321
- timestamp: timestamp,
322
- type: this.mapRecurringRequestType(builder),
323
- });
324
- if (this.merchantId) {
325
- elementtree_1.SubElement(request, "merchantid").append(elementtree_1.CData(this.merchantId));
326
- }
327
- if (this.accountId) {
328
- elementtree_1.SubElement(request, "account").append(elementtree_1.CData(this.accountId));
329
- }
330
- elementtree_1.SubElement(request, "orderid").append(elementtree_1.CData(orderId));
331
- if (builder.transactionType === __1.TransactionType.Create ||
332
- builder.transactionType === __1.TransactionType.Edit) {
333
- if (builder.entity instanceof __1.Customer) {
334
- var customer = builder.entity;
335
- request.append(this.buildCustomer(customer));
336
- elementtree_1.SubElement(request, "sha1hash").append(elementtree_1.CData(__1.GenerationUtils.generateHash([timestamp, this.merchantId, orderId, "", "", customer.key].join("."), this.sharedSecret)));
337
- }
338
- else if (builder.entity instanceof __1.RecurringPaymentMethod) {
339
- var payment = builder.entity;
340
- var cardElement = elementtree_1.SubElement(request, "card");
341
- elementtree_1.SubElement(cardElement, "ref").append(elementtree_1.CData(payment.key || payment.id));
342
- elementtree_1.SubElement(cardElement, "payerref").append(elementtree_1.CData(payment.customerKey));
343
- if (payment.paymentMethod) {
344
- var card = payment.paymentMethod;
345
- var expiry = __1.StringUtils.leftPad(card.expMonth, 2, "0") +
346
- __1.StringUtils.leftPad((card.expYear || "").substr(2, 2), 2, "0");
347
- elementtree_1.SubElement(cardElement, "number").append(elementtree_1.CData(card.number));
348
- elementtree_1.SubElement(cardElement, "expdate").append(elementtree_1.CData(expiry));
349
- elementtree_1.SubElement(cardElement, "chname").append(elementtree_1.CData(card.cardHolderName));
350
- elementtree_1.SubElement(cardElement, "type").append(elementtree_1.CData(card.getCardType().toUpperCase()));
351
- var sha1hash = "";
352
- if (builder.transactionType === __1.TransactionType.Create) {
353
- sha1hash = __1.GenerationUtils.generateHash([
354
- timestamp,
355
- this.merchantId,
356
- orderId,
357
- "",
358
- "",
359
- payment.customerKey,
360
- card.cardHolderName,
361
- card.number,
362
- ].join("."), this.sharedSecret);
363
- }
364
- else {
365
- sha1hash = __1.GenerationUtils.generateHash([
366
- timestamp,
367
- this.merchantId,
368
- payment.customerKey,
369
- payment.key || payment.id,
370
- expiry,
371
- card.number,
372
- ].join("."), this.sharedSecret);
373
- }
374
- elementtree_1.SubElement(request, "sha1hash").append(elementtree_1.CData(sha1hash));
375
- }
376
- }
377
- }
378
- else if (builder.transactionType === __1.TransactionType.Delete) {
379
- if (builder.entity instanceof __1.RecurringPaymentMethod) {
380
- var payment = builder.entity;
381
- var cardElement = elementtree_1.SubElement(request, "card");
382
- elementtree_1.SubElement(cardElement, "ref").append(elementtree_1.CData(payment.key || payment.id));
383
- elementtree_1.SubElement(cardElement, "payerref").append(elementtree_1.CData(payment.customerKey));
384
- }
385
- }
386
- return this.doTransaction(this.buildEnvelope(request)).then(function (response) {
387
- return _this.mapRecurringResponse(response, builder);
388
- });
389
- };
390
- GpEcomConnector.prototype.buildEnvelope = function (transaction) {
391
- return new elementtree_1.ElementTree(transaction).write();
392
- };
393
- GpEcomConnector.prototype.buildCustomer = function (customer) {
394
- var payer = elementtree_1.Element("payer", {
395
- ref: customer.key || __1.StringUtils.uuid(),
396
- type: "Retail",
397
- });
398
- elementtree_1.SubElement(payer, "title").append(elementtree_1.CData(customer.title));
399
- elementtree_1.SubElement(payer, "firstname").append(elementtree_1.CData(customer.firstName));
400
- elementtree_1.SubElement(payer, "surname").append(elementtree_1.CData(customer.lastName));
401
- elementtree_1.SubElement(payer, "company").append(elementtree_1.CData(customer.company));
402
- if (customer.address) {
403
- var address = elementtree_1.SubElement(payer, "address");
404
- elementtree_1.SubElement(address, "line1").append(elementtree_1.CData(customer.address.streetAddress1));
405
- elementtree_1.SubElement(address, "line2").append(elementtree_1.CData(customer.address.streetAddress2));
406
- elementtree_1.SubElement(address, "line3").append(elementtree_1.CData(customer.address.streetAddress3));
407
- elementtree_1.SubElement(address, "city").append(elementtree_1.CData(customer.address.city));
408
- elementtree_1.SubElement(address, "county").append(elementtree_1.CData(customer.address.province));
409
- elementtree_1.SubElement(address, "postcode").append(elementtree_1.CData(customer.address.postalCode));
410
- if (customer.address.country) {
411
- elementtree_1.SubElement(address, "country", { code: "GB" }).append(elementtree_1.CData(customer.address.country));
412
- }
413
- }
414
- var phone = elementtree_1.SubElement(payer, "phonenumbers");
415
- elementtree_1.SubElement(phone, "home").append(elementtree_1.CData(customer.homePhone));
416
- elementtree_1.SubElement(phone, "work").append(elementtree_1.CData(customer.workPhone));
417
- elementtree_1.SubElement(phone, "fax").append(elementtree_1.CData(customer.fax));
418
- elementtree_1.SubElement(phone, "mobile").append(elementtree_1.CData(customer.mobilePhone));
419
- elementtree_1.SubElement(payer, "email").append(elementtree_1.CData(customer.email));
420
- return payer;
421
- };
422
- GpEcomConnector.prototype.mapResponse = function (rawResponse) {
423
- var result = new __1.Transaction();
424
- var root = elementtree_1.XML(rawResponse);
425
- this.checkResponse(root);
426
- result.responseCode = root.findtext(".//result");
427
- result.responseMessage = root.findtext(".//message");
428
- result.cvnResponseCode = root.findtext(".//cvnresult");
429
- result.avsResponseCode = root.findtext(".//avspostcoderesponse");
430
- result.timestamp = root.findtext(".//timestamp");
431
- result.transactionReference = new __1.TransactionReference();
432
- result.transactionReference.authCode = root.findtext(".//authcode");
433
- result.transactionReference.orderId = root.findtext(".//orderid");
434
- result.transactionReference.paymentMethodType = __1.PaymentMethodType.Credit;
435
- result.transactionReference.transactionId = root.findtext(".//pasref");
436
- return result;
437
- };
438
- GpEcomConnector.prototype.mapRecurringResponse = function (rawResponse, builder) {
439
- var root = elementtree_1.XML(rawResponse);
440
- this.checkResponse(root);
441
- return builder.entity;
442
- };
443
- GpEcomConnector.prototype.checkResponse = function (root, acceptedCodes) {
444
- if (!acceptedCodes) {
445
- acceptedCodes = ["00"];
446
- }
447
- var responseCode = root.findtext(".//result");
448
- var responseMessage = root.findtext(".//message");
449
- if (acceptedCodes.indexOf(responseCode) === -1) {
450
- throw new __1.GatewayError("Unexpected Gateway Response: " + responseCode + " - " + responseMessage, responseCode, responseMessage);
451
- }
452
- };
453
- GpEcomConnector.prototype.generateHash = function (timestamp, orderId, amount, currency, paymentData, verify) {
454
- if (verify === void 0) { verify = false; }
455
- var data = [timestamp, this.merchantId, orderId];
456
- if (false === verify) {
457
- data.push(amount);
458
- data.push(currency);
459
- }
460
- data.push(paymentData);
461
- return __1.GenerationUtils.generateHash(data.join("."), this.sharedSecret);
462
- };
463
- GpEcomConnector.prototype.mapAuthRequestType = function (builder) {
464
- switch (builder.transactionType) {
465
- case __1.TransactionType.Sale:
466
- case __1.TransactionType.Auth:
467
- if (builder.paymentMethod.paymentMethodType === __1.PaymentMethodType.Credit) {
468
- if (builder.transactionModifier === __1.TransactionModifier.Offline) {
469
- return "offline";
470
- }
471
- if (builder.transactionModifier === __1.TransactionModifier.EncryptedMobile) {
472
- return "auth-mobile";
473
- }
474
- return "auth";
475
- }
476
- return "receipt-in";
477
- case __1.TransactionType.Capture:
478
- return "settle";
479
- case __1.TransactionType.Verify:
480
- if (builder.paymentMethod.paymentMethodType === __1.PaymentMethodType.Credit) {
481
- return "otb";
482
- }
483
- return "receipt-in-otb";
484
- case __1.TransactionType.Refund:
485
- if (builder.paymentMethod.paymentMethodType === __1.PaymentMethodType.Credit) {
486
- return "credit";
487
- }
488
- return "payment-out";
489
- case __1.TransactionType.Reversal:
490
- default:
491
- throw new __1.UnsupportedTransactionError("The selected gateway does not support this transaction type.");
492
- }
493
- };
494
- GpEcomConnector.prototype.mapManageRequestType = function (type) {
495
- switch (type) {
496
- case __1.TransactionType.Capture:
497
- return "settle";
498
- case __1.TransactionType.Hold:
499
- return "hold";
500
- case __1.TransactionType.Refund:
501
- return "rebate";
502
- case __1.TransactionType.Release:
503
- return "release";
504
- case __1.TransactionType.Void:
505
- case __1.TransactionType.Reversal:
506
- return "void";
507
- default:
508
- return "unknown";
509
- }
510
- };
511
- GpEcomConnector.prototype.mapRecurringRequestType = function (builder) {
512
- var entity = builder.entity;
513
- switch (builder.transactionType) {
514
- case __1.TransactionType.Create:
515
- if (entity instanceof __1.Customer) {
516
- return "payer-new";
517
- }
518
- if (entity instanceof __1.Schedule) {
519
- throw new __1.UnsupportedTransactionError();
520
- }
521
- return "card-new";
522
- case __1.TransactionType.Edit:
523
- if (entity instanceof __1.Customer) {
524
- return "payer-edit";
525
- }
526
- if (entity instanceof __1.Schedule) {
527
- throw new __1.UnsupportedTransactionError();
528
- }
529
- return "card-update-card";
530
- case __1.TransactionType.Delete:
531
- if (entity instanceof __1.Customer || entity instanceof __1.Schedule) {
532
- throw new __1.UnsupportedTransactionError();
533
- }
534
- return "card-cancel-card";
535
- default:
536
- throw new __1.UnsupportedTransactionError();
537
- }
538
- };
539
- GpEcomConnector.prototype.numberFormat = function (amount) {
540
- var f = parseFloat(amount.toString()) * 100;
541
- return parseFloat(f.toFixed(2)).toString();
542
- };
543
- GpEcomConnector.prototype.mapAcceptedCodes = function (paymentMethodType) {
544
- switch (paymentMethodType) {
545
- case "3ds-verifysig":
546
- case "3ds-verifyenrolled":
547
- return ["00", "110"];
548
- case "payment-set":
549
- return ["01", "00"];
550
- default:
551
- return ["00"];
552
- }
553
- };
554
- return GpEcomConnector;
555
- }(XmlGateway_1.XmlGateway));
556
- exports.GpEcomConnector = GpEcomConnector;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GpEcomConnector = void 0;
4
+ const elementtree_1 = require("@azz/elementtree");
5
+ const __1 = require("..");
6
+ const XmlGateway_1 = require("./XmlGateway");
7
+ const src_1 = require("../../src");
8
+ class GpEcomConnector extends XmlGateway_1.XmlGateway {
9
+ merchantId;
10
+ accountId;
11
+ sharedSecret;
12
+ channel;
13
+ rebatePassword;
14
+ refundPassword;
15
+ supportsHostedPayments = true;
16
+ supportsRetrieval = true;
17
+ supportsUpdatePaymentDetails = true;
18
+ hostedPaymentConfig;
19
+ config;
20
+ constructor(config) {
21
+ super();
22
+ this.config = config;
23
+ }
24
+ processAuthorization(builder) {
25
+ const transactionType = src_1.GpEcomMapping.mapAuthRequestType(builder);
26
+ const acceptedResponseCodes = this.mapAcceptedCodes(transactionType);
27
+ return this.executeProcess(builder).then((response) => src_1.GpEcomMapping.mapResponse(response, acceptedResponseCodes));
28
+ }
29
+ manageTransaction(builder) {
30
+ const transactionType = src_1.GpEcomMapping.mapManageRequestType(builder);
31
+ return this.executeProcess(builder).then((response) => src_1.GpEcomMapping.mapResponse(response, this.mapAcceptedCodes(transactionType)));
32
+ }
33
+ executeProcess(builder) {
34
+ const processFactory = new __1.RequestBuilderFactory();
35
+ const requestBuilder = processFactory.getRequestBuilder(builder, this.config.gatewayProvider);
36
+ if (!requestBuilder) {
37
+ throw new __1.ApiError("Request builder not found!");
38
+ }
39
+ const request = requestBuilder.buildRequest(builder, this.config);
40
+ if (!request) {
41
+ throw new __1.ApiError("Request was not generated!");
42
+ }
43
+ return this.doTransaction(request.requestBody);
44
+ }
45
+ serializeRequest(builder) {
46
+ if (!this.hostedPaymentConfig) {
47
+ throw new __1.ApiError("Hosted configuration missing. Please check your configuration");
48
+ }
49
+ const encoder = this.hostedPaymentConfig.version === __1.HppVersion.Version2
50
+ ? (t) => t
51
+ : __1.StringUtils.btoa;
52
+ const request = {};
53
+ const orderId = builder.orderId || __1.GenerationUtils.generateOrderId();
54
+ const timestamp = builder.timestamp || __1.GenerationUtils.generateTimestamp();
55
+ if (builder.transactionType !== __1.TransactionType.Sale &&
56
+ builder.transactionType !== __1.TransactionType.Auth &&
57
+ builder.transactionType !== __1.TransactionType.Verify) {
58
+ throw new __1.UnsupportedTransactionError();
59
+ }
60
+ request.MERCHANT_ID = encoder(this.merchantId || "");
61
+ request.ACCOUNT = encoder(this.accountId || "");
62
+ request.CHANNEL = encoder(this.channel || "");
63
+ request.ORDER_ID = encoder(orderId || "");
64
+ if (builder.amount) {
65
+ request.AMOUNT = encoder(this.numberFormat(builder.amount) || "");
66
+ }
67
+ request.CURRENCY = encoder(builder.currency || "");
68
+ request.TIMESTAMP = encoder(timestamp || "");
69
+ request.AUTO_SETTLE_FLAG = encoder(builder.transactionType === __1.TransactionType.Sale ? "1" : "0" || "");
70
+ request.COMMENT1 = encoder(builder.Description || "");
71
+ // request.COMMENT2 = encoder( || "");
72
+ if (this.hostedPaymentConfig.requestTransactionStabilityScore) {
73
+ request.RETURN_TSS = encoder(this.hostedPaymentConfig.requestTransactionStabilityScore
74
+ ? "1"
75
+ : "0" || "");
76
+ }
77
+ if (this.hostedPaymentConfig.directCurrencyConversionEnabled) {
78
+ request.DCC_ENABLE = encoder(this.hostedPaymentConfig.directCurrencyConversionEnabled
79
+ ? "1"
80
+ : "0" || "");
81
+ }
82
+ if (builder.hostedPaymentData) {
83
+ request.CUST_NUM = encoder(builder.hostedPaymentData.customerNumber || "");
84
+ if (this.hostedPaymentConfig.displaySavedCards &&
85
+ builder.hostedPaymentData.customerKey) {
86
+ request.HPP_SELECT_STORED_CARD = encoder(builder.hostedPaymentData.customerKey || "");
87
+ }
88
+ if (builder.hostedPaymentData.offerToSaveCard) {
89
+ request.OFFER_SAVE_CARD = encoder(builder.hostedPaymentData.offerToSaveCard ? "1" : "0" || "");
90
+ }
91
+ if (builder.hostedPaymentData.customerExists) {
92
+ request.PAYER_EXIST = encoder(builder.hostedPaymentData.customerExists ? "1" : "0" || "");
93
+ }
94
+ request.PAYER_REF = encoder(builder.hostedPaymentData.customerKey || "");
95
+ request.PMT_REF = encoder(builder.hostedPaymentData.paymentKey || "");
96
+ request.PROD_ID = encoder(builder.hostedPaymentData.productId || "");
97
+ }
98
+ if (builder.shippingAddress) {
99
+ request.SHIPPING_CODE = encoder(builder.shippingAddress.postalCode || "");
100
+ request.SHIPPING_CO = encoder(builder.shippingAddress.country || "");
101
+ }
102
+ if (builder.sillingAddress) {
103
+ request.BILLING_CODE = encoder(builder.billingAddress.postalCode || "");
104
+ request.BILLING_CO = encoder(builder.billingAddress.country || "");
105
+ }
106
+ request.CUST_NUM = encoder(builder.customerId || "");
107
+ request.VAR_REF = encoder(builder.clientTransactionId || "");
108
+ request.HPP_LANG = encoder(this.hostedPaymentConfig.language || "");
109
+ request.MERCHANT_RESPONSE_URL = encoder(this.hostedPaymentConfig.responseUrl || "");
110
+ request.CARD_PAYMENT_BUTTON = encoder(this.hostedPaymentConfig.paymentButtonText || "");
111
+ if (this.hostedPaymentConfig.cardStorageEnabled) {
112
+ request.CARD_STORAGE_ENABLE = encoder(this.hostedPaymentConfig.cardStorageEnabled ? "1" : "0" || "");
113
+ }
114
+ if (builder.transactionType === __1.TransactionType.Verify) {
115
+ request.VALIDATE_CARD_ONLY = encoder("1" || "");
116
+ }
117
+ if (this.hostedPaymentConfig.fraudFilterMode) {
118
+ request.HPP_FRAUD_FILTER_MODE = encoder(this.hostedPaymentConfig.fraudFilterMode.toString() || "");
119
+ }
120
+ if (builder.recurringType || builder.recurringSequence) {
121
+ if (builder.recurringType) {
122
+ request.RECURRING_TYPE = encoder(builder.recurringType.toString().toLowerCase() || "");
123
+ }
124
+ if (builder.recurringSequence) {
125
+ request.RECURRING_SEQUENCE = encoder(builder.recurringSequence.toString().toLowerCase() || "");
126
+ }
127
+ }
128
+ if (this.hostedPaymentConfig.version) {
129
+ request.HPP_VERSION = encoder(this.hostedPaymentConfig.version.toString() || "");
130
+ }
131
+ const toHash = [
132
+ timestamp,
133
+ this.merchantId,
134
+ orderId,
135
+ builder.amount ? this.numberFormat(builder.amount) : null,
136
+ builder.currency,
137
+ ];
138
+ if (this.hostedPaymentConfig.cardStorageEnabled ||
139
+ (builder.hostedPaymentData && builder.hostedPaymentData.offerToSaveCard)) {
140
+ toHash.push(builder.hostedPaymentData.customerKey
141
+ ? builder.hostedPaymentData.customerKey
142
+ : null);
143
+ toHash.push(builder.hostedPaymentData.paymentKey
144
+ ? builder.hostedPaymentData.paymentKey
145
+ : null);
146
+ }
147
+ if (this.hostedPaymentConfig.fraudFilterMode &&
148
+ this.hostedPaymentConfig.fraudFilterMode !== __1.FraudFilterMode.None) {
149
+ toHash.push(this.hostedPaymentConfig.fraudFilterMode.toString());
150
+ }
151
+ request.SHA1HASH = encoder(__1.GenerationUtils.generateHash(toHash.join("."), this.sharedSecret) || "");
152
+ return JSON.stringify(request);
153
+ }
154
+ oldManageTransaction(builder) {
155
+ const timestamp = __1.GenerationUtils.generateTimestamp();
156
+ const orderId = builder.orderId || __1.GenerationUtils.generateOrderId();
157
+ // build Request
158
+ const request = (0, elementtree_1.Element)("request", {
159
+ timestamp,
160
+ type: this.mapManageRequestType(builder.transactionType),
161
+ });
162
+ if (this.merchantId) {
163
+ (0, elementtree_1.SubElement)(request, "merchantid").append((0, elementtree_1.CData)(this.merchantId));
164
+ }
165
+ if (this.accountId) {
166
+ (0, elementtree_1.SubElement)(request, "account").append((0, elementtree_1.CData)(this.accountId));
167
+ }
168
+ if (this.channel) {
169
+ (0, elementtree_1.SubElement)(request, "channel").append((0, elementtree_1.CData)(this.channel));
170
+ }
171
+ (0, elementtree_1.SubElement)(request, "orderid").append((0, elementtree_1.CData)(orderId));
172
+ if (builder.paymentMethod) {
173
+ const ref = builder.paymentMethod;
174
+ (0, elementtree_1.SubElement)(request, "pasref").append((0, elementtree_1.CData)(ref.transactionId));
175
+ }
176
+ if (builder.amount) {
177
+ const amountAttrs = builder.currency
178
+ ? { currency: builder.currency }
179
+ : {};
180
+ (0, elementtree_1.SubElement)(request, "amount", amountAttrs).append((0, elementtree_1.CData)(this.numberFormat(builder.amount)));
181
+ }
182
+ else if (builder.transactionType === __1.TransactionType.Capture) {
183
+ throw new __1.BuilderError("Amount cannot be null for capture");
184
+ }
185
+ if (builder.transactionType === __1.TransactionType.Refund) {
186
+ if (builder.authorizationCode) {
187
+ (0, elementtree_1.SubElement)(request, "authcode").append((0, elementtree_1.CData)(builder.authorizationCode));
188
+ }
189
+ (0, elementtree_1.SubElement)(request, "refundhash").append((0, elementtree_1.CData)(__1.GenerationUtils.generateHash(this.rebatePassword)));
190
+ }
191
+ if (builder.reasonCode) {
192
+ (0, elementtree_1.SubElement)(request, "reasoncode").append((0, elementtree_1.CData)(builder.reasonCode.toString()));
193
+ }
194
+ if (builder.description) {
195
+ const comments = (0, elementtree_1.SubElement)(request, "comments");
196
+ (0, elementtree_1.SubElement)(comments, "comment", { id: 1 }).append((0, elementtree_1.CData)(builder.description));
197
+ }
198
+ (0, elementtree_1.SubElement)(request, "sha1hash").append((0, elementtree_1.CData)(this.generateHash(timestamp, orderId, builder.amount ? this.numberFormat(builder.amount) : "", builder.currency, "")));
199
+ return this.doTransaction(this.buildEnvelope(request)).then((response) => this.mapResponse(response));
200
+ }
201
+ processReport() {
202
+ throw new __1.UnsupportedTransactionError("Reporting functionality is not supported through this gateway.");
203
+ }
204
+ processRecurring(builder) {
205
+ const timestamp = __1.GenerationUtils.generateTimestamp();
206
+ const orderId = builder.orderId || __1.GenerationUtils.generateOrderId();
207
+ // build Request
208
+ const request = (0, elementtree_1.Element)("request", {
209
+ timestamp,
210
+ type: this.mapRecurringRequestType(builder),
211
+ });
212
+ if (this.config.merchantId) {
213
+ (0, elementtree_1.SubElement)(request, "merchantid").append((0, elementtree_1.CData)(this.config.merchantId));
214
+ }
215
+ if (builder.transactionType === __1.TransactionType.Create ||
216
+ builder.transactionType === __1.TransactionType.Edit) {
217
+ if (this.config.channel) {
218
+ (0, elementtree_1.SubElement)(request, "channel").append((0, elementtree_1.CData)(this.config.channel));
219
+ }
220
+ if (this.config.accountId) {
221
+ (0, elementtree_1.SubElement)(request, "account").append((0, elementtree_1.CData)(this.config.accountId));
222
+ }
223
+ if (builder.entity instanceof __1.Customer) {
224
+ (0, elementtree_1.SubElement)(request, "orderid").append((0, elementtree_1.CData)(orderId));
225
+ const customer = builder.entity;
226
+ request.append(this.buildCustomer(customer, builder));
227
+ (0, elementtree_1.SubElement)(request, "sha1hash").append((0, elementtree_1.CData)(__1.GenerationUtils.generateHash([
228
+ timestamp,
229
+ this.config.merchantId,
230
+ orderId,
231
+ "",
232
+ "",
233
+ customer.key,
234
+ ].join("."), this.config.sharedSecret)));
235
+ }
236
+ else if (builder.entity instanceof __1.RecurringPaymentMethod) {
237
+ const payment = builder.entity;
238
+ const cardElement = (0, elementtree_1.SubElement)(request, "card");
239
+ (0, elementtree_1.SubElement)(cardElement, "ref").append((0, elementtree_1.CData)(payment.key || payment.id));
240
+ (0, elementtree_1.SubElement)(cardElement, "payerref").append((0, elementtree_1.CData)(payment.customerKey));
241
+ if (payment.paymentMethod) {
242
+ const card = payment.paymentMethod;
243
+ const expiry = __1.StringUtils.leftPad(card.expMonth, 2, "0") +
244
+ __1.StringUtils.leftPad((card.expYear || "").substr(2, 2), 2, "0");
245
+ (0, elementtree_1.SubElement)(cardElement, "number").append((0, elementtree_1.CData)(card.number));
246
+ (0, elementtree_1.SubElement)(cardElement, "expdate").append((0, elementtree_1.CData)(expiry));
247
+ (0, elementtree_1.SubElement)(cardElement, "chname").append((0, elementtree_1.CData)(card.cardHolderName));
248
+ (0, elementtree_1.SubElement)(cardElement, "type").append((0, elementtree_1.CData)(card.getCardType().toUpperCase()));
249
+ let sha1hash = "";
250
+ if (builder.transactionType === __1.TransactionType.Create) {
251
+ sha1hash = __1.GenerationUtils.generateHash([
252
+ timestamp,
253
+ this.config.merchantId,
254
+ orderId,
255
+ "",
256
+ "",
257
+ payment.customerKey,
258
+ card.cardHolderName,
259
+ card.number,
260
+ ].join("."), this.config.sharedSecret);
261
+ }
262
+ else {
263
+ sha1hash = __1.GenerationUtils.generateHash([
264
+ timestamp,
265
+ this.config.merchantId,
266
+ payment.customerKey,
267
+ payment.key || payment.id,
268
+ expiry,
269
+ card.number,
270
+ ].join("."), this.config.sharedSecret);
271
+ }
272
+ (0, elementtree_1.SubElement)(request, "sha1hash").append((0, elementtree_1.CData)(sha1hash));
273
+ }
274
+ }
275
+ }
276
+ else if (builder.transactionType === __1.TransactionType.Delete) {
277
+ if (builder.entity instanceof __1.RecurringPaymentMethod) {
278
+ const payment = builder.entity;
279
+ const cardElement = (0, elementtree_1.SubElement)(request, "card");
280
+ (0, elementtree_1.SubElement)(cardElement, "ref").append((0, elementtree_1.CData)(payment.key || payment.id));
281
+ (0, elementtree_1.SubElement)(cardElement, "payerref").append((0, elementtree_1.CData)(payment.customerKey));
282
+ }
283
+ }
284
+ return this.doTransaction(this.buildEnvelope(request)).then((response) => this.mapRecurringResponse(response, builder));
285
+ }
286
+ buildEnvelope(transaction) {
287
+ return new elementtree_1.ElementTree(transaction).write();
288
+ }
289
+ buildCustomer(customer, builder) {
290
+ const payer = (0, elementtree_1.Element)("payer", {
291
+ ref: customer.key || __1.StringUtils.uuid(),
292
+ });
293
+ const type = builder.transactionType === __1.TransactionType.Edit
294
+ ? "Subscriber"
295
+ : "Retail";
296
+ (0, elementtree_1.SubElement)(payer, "type").append((0, elementtree_1.CData)(type));
297
+ (0, elementtree_1.SubElement)(payer, "title").append((0, elementtree_1.CData)(customer.title));
298
+ (0, elementtree_1.SubElement)(payer, "firstname").append((0, elementtree_1.CData)(customer.firstName));
299
+ (0, elementtree_1.SubElement)(payer, "surname").append((0, elementtree_1.CData)(customer.lastName));
300
+ (0, elementtree_1.SubElement)(payer, "company").append((0, elementtree_1.CData)(customer.company));
301
+ if (customer.address) {
302
+ const address = (0, elementtree_1.SubElement)(payer, "address");
303
+ (0, elementtree_1.SubElement)(address, "line1").append((0, elementtree_1.CData)(customer.address.streetAddress1));
304
+ (0, elementtree_1.SubElement)(address, "line2").append((0, elementtree_1.CData)(customer.address.streetAddress2));
305
+ (0, elementtree_1.SubElement)(address, "line3").append((0, elementtree_1.CData)(customer.address.streetAddress3));
306
+ (0, elementtree_1.SubElement)(address, "city").append((0, elementtree_1.CData)(customer.address.city));
307
+ (0, elementtree_1.SubElement)(address, "county").append((0, elementtree_1.CData)(customer.address.province));
308
+ (0, elementtree_1.SubElement)(address, "postcode").append((0, elementtree_1.CData)(customer.address.postalCode));
309
+ if (customer.address.country) {
310
+ (0, elementtree_1.SubElement)(address, "country", { code: "GB" }).append((0, elementtree_1.CData)(customer.address.country));
311
+ }
312
+ }
313
+ const phone = (0, elementtree_1.SubElement)(payer, "phonenumbers");
314
+ (0, elementtree_1.SubElement)(phone, "home").append((0, elementtree_1.CData)(customer.homePhone));
315
+ (0, elementtree_1.SubElement)(phone, "work").append((0, elementtree_1.CData)(customer.workPhone));
316
+ (0, elementtree_1.SubElement)(phone, "fax").append((0, elementtree_1.CData)(customer.fax));
317
+ (0, elementtree_1.SubElement)(phone, "mobile").append((0, elementtree_1.CData)(customer.mobilePhone));
318
+ (0, elementtree_1.SubElement)(payer, "email").append((0, elementtree_1.CData)(customer.email));
319
+ return payer;
320
+ }
321
+ mapResponse(rawResponse) {
322
+ const result = new __1.Transaction();
323
+ const root = (0, elementtree_1.XML)(rawResponse);
324
+ this.checkResponse(root);
325
+ result.responseCode = root.findtext(".//result");
326
+ result.responseMessage = root.findtext(".//message");
327
+ result.cvnResponseCode = root.findtext(".//cvnresult");
328
+ result.avsResponseCode = root.findtext(".//avspostcoderesponse");
329
+ result.timestamp = root.findtext(".//timestamp");
330
+ result.transactionReference = new __1.TransactionReference();
331
+ result.transactionReference.authCode = root.findtext(".//authcode");
332
+ result.transactionReference.orderId = root.findtext(".//orderid");
333
+ result.transactionReference.paymentMethodType = __1.PaymentMethodType.Credit;
334
+ result.transactionReference.transactionId = root.findtext(".//pasref");
335
+ return result;
336
+ }
337
+ mapRecurringResponse(rawResponse, builder) {
338
+ const root = (0, elementtree_1.XML)(rawResponse);
339
+ this.checkResponse(root);
340
+ return builder.entity;
341
+ }
342
+ checkResponse(root, acceptedCodes) {
343
+ if (!acceptedCodes) {
344
+ acceptedCodes = ["00"];
345
+ }
346
+ const responseCode = root.findtext(".//result");
347
+ const responseMessage = root.findtext(".//message");
348
+ if (acceptedCodes.indexOf(responseCode) === -1) {
349
+ throw new __1.GatewayError(`Unexpected Gateway Response: ${responseCode} - ${responseMessage}`, responseCode, responseMessage);
350
+ }
351
+ }
352
+ generateHash(timestamp, orderId, amount, currency, paymentData, verify = false) {
353
+ const data = [timestamp, this.merchantId, orderId];
354
+ if (false === verify) {
355
+ data.push(amount);
356
+ data.push(currency);
357
+ }
358
+ data.push(paymentData);
359
+ return __1.GenerationUtils.generateHash(data.join("."), this.sharedSecret);
360
+ }
361
+ mapAuthRequestType(builder) {
362
+ switch (builder.transactionType) {
363
+ case __1.TransactionType.Sale:
364
+ case __1.TransactionType.Auth:
365
+ if (builder.paymentMethod.paymentMethodType === __1.PaymentMethodType.Credit) {
366
+ if (builder.transactionModifier === __1.TransactionModifier.Offline) {
367
+ return "offline";
368
+ }
369
+ if (builder.transactionModifier === __1.TransactionModifier.EncryptedMobile) {
370
+ return "auth-mobile";
371
+ }
372
+ return "auth";
373
+ }
374
+ return "receipt-in";
375
+ case __1.TransactionType.Capture:
376
+ return "settle";
377
+ case __1.TransactionType.Verify:
378
+ if (builder.paymentMethod.paymentMethodType === __1.PaymentMethodType.Credit) {
379
+ return "otb";
380
+ }
381
+ return "receipt-in-otb";
382
+ case __1.TransactionType.Refund:
383
+ if (builder.paymentMethod.paymentMethodType === __1.PaymentMethodType.Credit) {
384
+ return "credit";
385
+ }
386
+ return "payment-out";
387
+ case __1.TransactionType.Reversal:
388
+ throw new __1.UnsupportedTransactionError("The selected gateway does not support this transaction type.");
389
+ default:
390
+ return "unknown";
391
+ }
392
+ }
393
+ mapManageRequestType(type) {
394
+ switch (type) {
395
+ case __1.TransactionType.Capture:
396
+ return "settle";
397
+ case __1.TransactionType.Hold:
398
+ return "hold";
399
+ case __1.TransactionType.Refund:
400
+ return "rebate";
401
+ case __1.TransactionType.Release:
402
+ return "release";
403
+ case __1.TransactionType.Void:
404
+ case __1.TransactionType.Reversal:
405
+ return "void";
406
+ default:
407
+ return "unknown";
408
+ }
409
+ }
410
+ mapRecurringRequestType(builder) {
411
+ const entity = builder.entity;
412
+ switch (builder.transactionType) {
413
+ case __1.TransactionType.Create:
414
+ if (entity instanceof __1.Customer) {
415
+ return "payer-new";
416
+ }
417
+ else if (entity instanceof __1.RecurringPaymentMethod) {
418
+ return "card-new";
419
+ }
420
+ else if (entity instanceof __1.Schedule) {
421
+ return "schedule-new";
422
+ }
423
+ case __1.TransactionType.Edit:
424
+ if (entity instanceof __1.Customer) {
425
+ return "payer-edit";
426
+ }
427
+ if (entity instanceof __1.Schedule) {
428
+ throw new __1.UnsupportedTransactionError();
429
+ }
430
+ return "card-update-card";
431
+ case __1.TransactionType.Delete:
432
+ if (entity instanceof __1.Customer || entity instanceof __1.Schedule) {
433
+ throw new __1.UnsupportedTransactionError();
434
+ }
435
+ return "card-cancel-card";
436
+ case __1.TransactionType.Fetch:
437
+ if (entity instanceof __1.Schedule) {
438
+ return "schedule-get";
439
+ }
440
+ case __1.TransactionType.Search:
441
+ if (entity instanceof __1.Schedule) {
442
+ return "schedule-search";
443
+ }
444
+ default:
445
+ throw new __1.UnsupportedTransactionError();
446
+ }
447
+ }
448
+ numberFormat(amount) {
449
+ const f = parseFloat(amount.toString()) * 100;
450
+ return parseFloat(f.toFixed(2)).toString();
451
+ }
452
+ mapAcceptedCodes(paymentMethodType) {
453
+ switch (paymentMethodType) {
454
+ case "3ds-verifysig":
455
+ case "3ds-verifyenrolled":
456
+ return ["00", "110"];
457
+ case "payment-set":
458
+ return ["01", "00"];
459
+ default:
460
+ return ["00"];
461
+ }
462
+ }
463
+ }
464
+ exports.GpEcomConnector = GpEcomConnector;
557
465
  //# sourceMappingURL=GpEcomConnector.js.map