connect-sdk-ruby 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/Gemfile +2 -0
- data/LICENSE.txt +22 -0
- data/README.md +140 -0
- data/Rakefile +34 -0
- data/connect-sdk-ruby.gemspec +28 -0
- data/examples/merchant/example_configuration.yml +6 -0
- data/examples/merchant/hostedcheckouts/create_hosted_checkout_example.rb +53 -0
- data/examples/merchant/hostedcheckouts/get_hosted_checkout_example.rb +22 -0
- data/examples/merchant/payments/approve_payment_example.rb +42 -0
- data/examples/merchant/payments/cancel_approval_payment_example.rb +22 -0
- data/examples/merchant/payments/cancel_payment_example.rb +22 -0
- data/examples/merchant/payments/create_payment_example.rb +177 -0
- data/examples/merchant/payments/get_payment_example.rb +22 -0
- data/examples/merchant/payments/process_challenged_payment_example.rb +22 -0
- data/examples/merchant/payments/refund_payment_example.rb +85 -0
- data/examples/merchant/payments/tokenize_payment_example.rb +27 -0
- data/examples/merchant/payouts/approve_payout_example.rb +27 -0
- data/examples/merchant/payouts/cancel_approval_payout_example.rb +22 -0
- data/examples/merchant/payouts/cancel_payout_example.rb +22 -0
- data/examples/merchant/payouts/create_payout_example.rb +96 -0
- data/examples/merchant/payouts/get_payout_example.rb +22 -0
- data/examples/merchant/productgroups/get_payment_product_group_example.rb +32 -0
- data/examples/merchant/productgroups/get_payment_product_groups_example.rb +32 -0
- data/examples/merchant/products/get_directory_example.rb +28 -0
- data/examples/merchant/products/get_payment_product_example.rb +32 -0
- data/examples/merchant/products/get_payment_products_example.rb +32 -0
- data/examples/merchant/refunds/approve_refund_example.rb +27 -0
- data/examples/merchant/refunds/cancel_approval_refund_example.rb +22 -0
- data/examples/merchant/refunds/cancel_refund_example.rb +22 -0
- data/examples/merchant/refunds/get_refund_example.rb +22 -0
- data/examples/merchant/riskassessments/risk_assessment_bank_account_example.rb +54 -0
- data/examples/merchant/riskassessments/risk_assessment_cards_example.rb +114 -0
- data/examples/merchant/services/convert_amount_example.rb +29 -0
- data/examples/merchant/services/convert_bank_account_example.rb +34 -0
- data/examples/merchant/services/iin_details_example.rb +27 -0
- data/examples/merchant/services/test_connection_example.rb +22 -0
- data/examples/merchant/sessions/create_session_example.rb +34 -0
- data/examples/merchant/tokens/approve_sepa_direct_debit_token_example.rb +29 -0
- data/examples/merchant/tokens/create_token_example.rb +82 -0
- data/examples/merchant/tokens/delete_token_example.rb +27 -0
- data/examples/merchant/tokens/get_token_example.rb +22 -0
- data/examples/merchant/tokens/update_token_example.rb +76 -0
- data/lib/ingenico/connect/sdk.rb +27 -0
- data/lib/ingenico/connect/sdk/api_exception.rb +52 -0
- data/lib/ingenico/connect/sdk/api_resource.rb +126 -0
- data/lib/ingenico/connect/sdk/authenticator.rb +15 -0
- data/lib/ingenico/connect/sdk/authorization_exception.rb +13 -0
- data/lib/ingenico/connect/sdk/call_context.rb +26 -0
- data/lib/ingenico/connect/sdk/client.rb +92 -0
- data/lib/ingenico/connect/sdk/communication_exception.rb +15 -0
- data/lib/ingenico/connect/sdk/communicator.rb +277 -0
- data/lib/ingenico/connect/sdk/communicator_configuration.rb +98 -0
- data/lib/ingenico/connect/sdk/connection.rb +31 -0
- data/lib/ingenico/connect/sdk/data_object.rb +43 -0
- data/lib/ingenico/connect/sdk/declined_payment_exception.rb +44 -0
- data/lib/ingenico/connect/sdk/declined_payout_exception.rb +44 -0
- data/lib/ingenico/connect/sdk/declined_refund_exception.rb +46 -0
- data/lib/ingenico/connect/sdk/declined_transaction_exception.rb +16 -0
- data/lib/ingenico/connect/sdk/defaultimpl.rb +6 -0
- data/lib/ingenico/connect/sdk/defaultimpl/authorization_type.rb +18 -0
- data/lib/ingenico/connect/sdk/defaultimpl/default_authenticator.rb +106 -0
- data/lib/ingenico/connect/sdk/defaultimpl/default_connection.rb +242 -0
- data/lib/ingenico/connect/sdk/defaultimpl/default_marshaller.rb +35 -0
- data/lib/ingenico/connect/sdk/domain/definitions/abstract_order_status.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/definitions/abstract_payment_method_specific_input.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/definitions/additional_order_input_airline_data.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/definitions/address.rb +81 -0
- data/lib/ingenico/connect/sdk/domain/definitions/airline_data.rb +165 -0
- data/lib/ingenico/connect/sdk/domain/definitions/airline_flight_leg.rb +102 -0
- data/lib/ingenico/connect/sdk/domain/definitions/amount_of_money.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/definitions/bank_account.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/definitions/bank_account_bban.rb +67 -0
- data/lib/ingenico/connect/sdk/domain/definitions/bank_account_iban.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/definitions/card.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/definitions/card_essentials.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/definitions/card_fraud_results.rb +50 -0
- data/lib/ingenico/connect/sdk/domain/definitions/card_without_cvv.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/definitions/company_information.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/definitions/contact_details_base.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/definitions/customer_base.rb +50 -0
- data/lib/ingenico/connect/sdk/domain/definitions/fraud_fields.rb +115 -0
- data/lib/ingenico/connect/sdk/domain/definitions/fraud_results.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/definitions/fraud_results_retail_decisions.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/definitions/key_value_pair.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/definitions/order_status_output.rb +67 -0
- data/lib/ingenico/connect/sdk/domain/definitions/payment_product_filter.rb +51 -0
- data/lib/ingenico/connect/sdk/domain/definitions/personal_name_base.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/definitions/result_do_risk_assessment.rb +61 -0
- data/lib/ingenico/connect/sdk/domain/definitions/retail_decisions_cc_fraud_check_output.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/definitions/validation_bank_account_check.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/definitions/validation_bank_account_output.rb +67 -0
- data/lib/ingenico/connect/sdk/domain/errors/api_error.rb +60 -0
- data/lib/ingenico/connect/sdk/domain/errors/error_response.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/hostedcheckout/create_hosted_checkout_request.rb +102 -0
- data/lib/ingenico/connect/sdk/domain/hostedcheckout/create_hosted_checkout_response.rb +59 -0
- data/lib/ingenico/connect/sdk/domain/hostedcheckout/created_payment_output.rb +72 -0
- data/lib/ingenico/connect/sdk/domain/hostedcheckout/displayed_data.rb +53 -0
- data/lib/ingenico/connect/sdk/domain/hostedcheckout/get_hosted_checkout_response.rb +43 -0
- data/lib/ingenico/connect/sdk/domain/hostedcheckout/hosted_checkout_specific_input.rb +78 -0
- data/lib/ingenico/connect/sdk/domain/hostedcheckout/payment_product_filters_hosted_checkout.rb +53 -0
- data/lib/ingenico/connect/sdk/domain/metadata/shopping_cart_extension.rb +48 -0
- data/lib/ingenico/connect/sdk/domain/payment/abstract_payment_method_specific_output.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/additional_order_input.rb +72 -0
- data/lib/ingenico/connect/sdk/domain/payment/address_personal.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/payment/approve_payment_card_payment_method_specific_output.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/approve_payment_non_sepa_direct_debit_payment_method_specific_input.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/approve_payment_payment_method_specific_input.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/approve_payment_request.rb +65 -0
- data/lib/ingenico/connect/sdk/domain/payment/approve_payment_sepa_direct_debit_payment_method_specific_input.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/bank_transfer_payment_method_specific_input.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/bank_transfer_payment_method_specific_input_base.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/bank_transfer_payment_method_specific_output.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/cancel_approval_payment_response.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/payment/cancel_payment_card_payment_method_specific_output.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/cancel_payment_response.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/payment/card_payment_method_specific_input.rb +61 -0
- data/lib/ingenico/connect/sdk/domain/payment/card_payment_method_specific_input_base.rb +60 -0
- data/lib/ingenico/connect/sdk/domain/payment/card_payment_method_specific_output.rb +65 -0
- data/lib/ingenico/connect/sdk/domain/payment/cash_payment_method_specific_input.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/payment/cash_payment_method_specific_input_base.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/cash_payment_method_specific_output.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/cash_payment_product1503_specific_input.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/cash_payment_product1504_specific_input.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/contact_details.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/create_payment_request.rb +131 -0
- data/lib/ingenico/connect/sdk/domain/payment/create_payment_response.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/create_payment_result.rb +58 -0
- data/lib/ingenico/connect/sdk/domain/payment/customer.rb +83 -0
- data/lib/ingenico/connect/sdk/domain/payment/external_cardholder_authentication_data.rb +60 -0
- data/lib/ingenico/connect/sdk/domain/payment/invoice_payment_method_specific_input.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/invoice_payment_method_specific_output.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/level3_summary_data.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/payment/line_item.rb +58 -0
- data/lib/ingenico/connect/sdk/domain/payment/line_item_invoice_data.rb +60 -0
- data/lib/ingenico/connect/sdk/domain/payment/line_item_level3_interchange_information.rb +81 -0
- data/lib/ingenico/connect/sdk/domain/payment/merchant_action.rb +64 -0
- data/lib/ingenico/connect/sdk/domain/payment/non_sepa_direct_debit_payment_method_specific_input.rb +71 -0
- data/lib/ingenico/connect/sdk/domain/payment/non_sepa_direct_debit_payment_method_specific_output.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/payment/non_sepa_direct_debit_payment_product705_specific_input.rb +50 -0
- data/lib/ingenico/connect/sdk/domain/payment/order.rb +83 -0
- data/lib/ingenico/connect/sdk/domain/payment/order_approve_payment.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/payment/order_invoice_data.rb +59 -0
- data/lib/ingenico/connect/sdk/domain/payment/order_output.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/payment/order_references.rb +57 -0
- data/lib/ingenico/connect/sdk/domain/payment/order_references_approve_payment.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/order_type_information.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment.rb +54 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_approval_response.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_creation_output.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_creation_references.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_error_response.rb +57 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_output.rb +116 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_product836_specific_output.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_product840_customer_account.rb +88 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_product840_specific_output.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_references.rb +67 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_response.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/payment_status_output.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/personal_information.rb +50 -0
- data/lib/ingenico/connect/sdk/domain/payment/personal_name.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/redirect_data.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/redirect_payment_method_specific_input.rb +72 -0
- data/lib/ingenico/connect/sdk/domain/payment/redirect_payment_method_specific_input_base.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/redirect_payment_method_specific_output.rb +58 -0
- data/lib/ingenico/connect/sdk/domain/payment/redirect_payment_product809_specific_input.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/redirect_payment_product816_specific_input.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/payment/redirect_payment_product882_specific_input.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payment/refund_bank_method_specific_output.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/refund_card_method_specific_output.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payment/refund_e_wallet_method_specific_output.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/payment/refund_method_specific_output.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/payment/refund_output.rb +72 -0
- data/lib/ingenico/connect/sdk/domain/payment/refund_payment_product840_customer_account.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/payment/refund_payment_product840_specific_output.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/payment/sepa_direct_debit_payment_method_specific_input.rb +60 -0
- data/lib/ingenico/connect/sdk/domain/payment/sepa_direct_debit_payment_method_specific_output.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/payment/three_d_secure_results.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/payment/tokenize_payment_request.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payout/approve_payout_request.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/payout/create_payout_request.rb +101 -0
- data/lib/ingenico/connect/sdk/domain/payout/payout_customer.rb +76 -0
- data/lib/ingenico/connect/sdk/domain/payout/payout_error_response.rb +57 -0
- data/lib/ingenico/connect/sdk/domain/payout/payout_references.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/payout/payout_response.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/payout/payout_result.rb +54 -0
- data/lib/ingenico/connect/sdk/domain/product/account_on_file.rb +64 -0
- data/lib/ingenico/connect/sdk/domain/product/account_on_file_attribute.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/product/account_on_file_display_hints.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/product/directory.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/product/directory_entry.rb +59 -0
- data/lib/ingenico/connect/sdk/domain/product/empty_validator.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/product/fixed_list_validator.rb +38 -0
- data/lib/ingenico/connect/sdk/domain/product/label_template_element.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/product/length_validator.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product.rb +134 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_display_hints.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_field.rb +61 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_field_data_restrictions.rb +43 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_field_display_hints.rb +96 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_field_form_element.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_field_tooltip.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_field_validators.rb +100 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_group.rb +71 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_group_response.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_groups.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_product_response.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/product/payment_products.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/product/range_validator.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/product/regular_expression_validator.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/product/value_mapping_element.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/refund/approve_refund_request.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/refund/bank_account_bban_refund.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/refund/bank_refund_method_specific_input.rb +54 -0
- data/lib/ingenico/connect/sdk/domain/refund/refund_customer.rb +58 -0
- data/lib/ingenico/connect/sdk/domain/refund/refund_error_response.rb +57 -0
- data/lib/ingenico/connect/sdk/domain/refund/refund_references.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/refund/refund_request.rb +76 -0
- data/lib/ingenico/connect/sdk/domain/refund/refund_response.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/refund/refund_result.rb +54 -0
- data/lib/ingenico/connect/sdk/domain/riskassessments/customer_risk_assessment.rb +65 -0
- data/lib/ingenico/connect/sdk/domain/riskassessments/order_risk_assessment.rb +58 -0
- data/lib/ingenico/connect/sdk/domain/riskassessments/personal_information_risk_assessment.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/riskassessments/personal_name_risk_assessment.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/riskassessments/risk_assessment.rb +54 -0
- data/lib/ingenico/connect/sdk/domain/riskassessments/risk_assessment_bank_account.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/riskassessments/risk_assessment_card.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/riskassessments/risk_assessment_response.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/services/bank_data.rb +53 -0
- data/lib/ingenico/connect/sdk/domain/services/bank_details.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/services/bank_details_request.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/services/bank_details_response.rb +69 -0
- data/lib/ingenico/connect/sdk/domain/services/convert_amount.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/services/get_iin_details_request.rb +43 -0
- data/lib/ingenico/connect/sdk/domain/services/get_iin_details_response.rb +60 -0
- data/lib/ingenico/connect/sdk/domain/services/iin_detail.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/services/payment_context.rb +50 -0
- data/lib/ingenico/connect/sdk/domain/services/swift.rb +95 -0
- data/lib/ingenico/connect/sdk/domain/services/test_connection.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/sessions/payment_product_filters_client_session.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/sessions/session_request.rb +49 -0
- data/lib/ingenico/connect/sdk/domain/sessions/session_response.rb +59 -0
- data/lib/ingenico/connect/sdk/domain/token/abstract_token.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/token/approve_token_request.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/token/contact_details_token.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/token/create_token_request.rb +76 -0
- data/lib/ingenico/connect/sdk/domain/token/create_token_response.rb +39 -0
- data/lib/ingenico/connect/sdk/domain/token/creditor.rb +102 -0
- data/lib/ingenico/connect/sdk/domain/token/customer_token.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/token/customer_token_with_contact_details.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/token/debtor.rb +102 -0
- data/lib/ingenico/connect/sdk/domain/token/mandate_approval.rb +46 -0
- data/lib/ingenico/connect/sdk/domain/token/mandate_non_sepa_direct_debit.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/token/mandate_sepa_direct_debit.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/token/mandate_sepa_direct_debit_with_mandate_id.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/token/mandate_sepa_direct_debit_without_creditor.rb +79 -0
- data/lib/ingenico/connect/sdk/domain/token/personal_information_token.rb +36 -0
- data/lib/ingenico/connect/sdk/domain/token/personal_name_token.rb +16 -0
- data/lib/ingenico/connect/sdk/domain/token/token_card.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/token/token_card_data.rb +50 -0
- data/lib/ingenico/connect/sdk/domain/token/token_e_wallet.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/token/token_e_wallet_data.rb +32 -0
- data/lib/ingenico/connect/sdk/domain/token/token_non_sepa_direct_debit.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/token/token_non_sepa_direct_debit_payment_product705_specific_data.rb +43 -0
- data/lib/ingenico/connect/sdk/domain/token/token_response.rb +83 -0
- data/lib/ingenico/connect/sdk/domain/token/token_sepa_direct_debit.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/token/token_sepa_direct_debit_without_creditor.rb +47 -0
- data/lib/ingenico/connect/sdk/domain/token/update_token_request.rb +76 -0
- data/lib/ingenico/connect/sdk/endpoint_configuration.rb +139 -0
- data/lib/ingenico/connect/sdk/exceptions.rb +8 -0
- data/lib/ingenico/connect/sdk/factory.rb +200 -0
- data/lib/ingenico/connect/sdk/global_collect_exception.rb +15 -0
- data/lib/ingenico/connect/sdk/idempotence_exception.rb +24 -0
- data/lib/ingenico/connect/sdk/logging.rb +10 -0
- data/lib/ingenico/connect/sdk/logging/communicator_logger.rb +19 -0
- data/lib/ingenico/connect/sdk/logging/log_message_builder.rb +61 -0
- data/lib/ingenico/connect/sdk/logging/logging_capable.rb +19 -0
- data/lib/ingenico/connect/sdk/logging/logging_util.rb +298 -0
- data/lib/ingenico/connect/sdk/logging/request_log_message_builder.rb +42 -0
- data/lib/ingenico/connect/sdk/logging/response_log_message_builder.rb +34 -0
- data/lib/ingenico/connect/sdk/logging/ruby_communicator_logger.rb +58 -0
- data/lib/ingenico/connect/sdk/logging/stdout_communicator_logger.rb +36 -0
- data/lib/ingenico/connect/sdk/marshaller.rb +19 -0
- data/lib/ingenico/connect/sdk/marshaller_syntax_exception.rb +6 -0
- data/lib/ingenico/connect/sdk/merchant/hostedcheckouts/hostedcheckouts_client.rb +88 -0
- data/lib/ingenico/connect/sdk/merchant/merchant_client.rb +110 -0
- data/lib/ingenico/connect/sdk/merchant/payments/payments_client.rb +319 -0
- data/lib/ingenico/connect/sdk/merchant/payouts/payouts_client.rb +197 -0
- data/lib/ingenico/connect/sdk/merchant/productgroups/find_productgroups_params.rb +55 -0
- data/lib/ingenico/connect/sdk/merchant/productgroups/get_productgroup_params.rb +55 -0
- data/lib/ingenico/connect/sdk/merchant/productgroups/productgroups_client.rb +90 -0
- data/lib/ingenico/connect/sdk/merchant/products/directory_params.rb +31 -0
- data/lib/ingenico/connect/sdk/merchant/products/find_products_params.rb +55 -0
- data/lib/ingenico/connect/sdk/merchant/products/get_product_params.rb +55 -0
- data/lib/ingenico/connect/sdk/merchant/products/products_client.rb +124 -0
- data/lib/ingenico/connect/sdk/merchant/refunds/refunds_client.rb +154 -0
- data/lib/ingenico/connect/sdk/merchant/riskassessments/riskassessments_client.rb +85 -0
- data/lib/ingenico/connect/sdk/merchant/services/convert_amount_params.rb +35 -0
- data/lib/ingenico/connect/sdk/merchant/services/services_client.rb +149 -0
- data/lib/ingenico/connect/sdk/merchant/sessions/sessions_client.rb +55 -0
- data/lib/ingenico/connect/sdk/merchant/tokens/delete_token_params.rb +27 -0
- data/lib/ingenico/connect/sdk/merchant/tokens/tokens_client.rb +192 -0
- data/lib/ingenico/connect/sdk/meta_data_provider.rb +152 -0
- data/lib/ingenico/connect/sdk/modules.rb +130 -0
- data/lib/ingenico/connect/sdk/not_found_exception.rb +19 -0
- data/lib/ingenico/connect/sdk/param_request.rb +33 -0
- data/lib/ingenico/connect/sdk/pooled_connection.rb +21 -0
- data/lib/ingenico/connect/sdk/proxy_configuration.rb +75 -0
- data/lib/ingenico/connect/sdk/reference_exception.rb +14 -0
- data/lib/ingenico/connect/sdk/request_header.rb +25 -0
- data/lib/ingenico/connect/sdk/request_param.rb +24 -0
- data/lib/ingenico/connect/sdk/response.rb +62 -0
- data/lib/ingenico/connect/sdk/response_exception.rb +54 -0
- data/lib/ingenico/connect/sdk/response_header.rb +25 -0
- data/lib/ingenico/connect/sdk/session.rb +39 -0
- data/lib/ingenico/connect/sdk/validation_exception.rb +14 -0
- data/spec/comparable_extension.rb +29 -0
- data/spec/fixtures/resources/defaultimpl/convertAmount.json +3 -0
- data/spec/fixtures/resources/defaultimpl/createPayment.failure.invalidCardNumber.json +11 -0
- data/spec/fixtures/resources/defaultimpl/createPayment.failure.rejected.json +48 -0
- data/spec/fixtures/resources/defaultimpl/createPayment.json +40 -0
- data/spec/fixtures/resources/defaultimpl/idempotence_duplicate_failure.json +8 -0
- data/spec/fixtures/resources/defaultimpl/idempotence_rejected.json +46 -0
- data/spec/fixtures/resources/defaultimpl/idempotence_success.json +39 -0
- data/spec/fixtures/resources/defaultimpl/notFound.html +1 -0
- data/spec/fixtures/resources/defaultimpl/testConnection.json +3 -0
- data/spec/fixtures/resources/defaultimpl/unknownServerError.json +10 -0
- data/spec/fixtures/resources/logging/bodyNoObfuscation.json +17 -0
- data/spec/fixtures/resources/logging/bodyWithBinObfuscated.json +3 -0
- data/spec/fixtures/resources/logging/bodyWithBinOriginal.json +3 -0
- data/spec/fixtures/resources/logging/bodyWithCardObfuscated.json +21 -0
- data/spec/fixtures/resources/logging/bodyWithCardOriginal.json +21 -0
- data/spec/fixtures/resources/logging/bodyWithIbanObfuscated.json +19 -0
- data/spec/fixtures/resources/logging/bodyWithIbanOriginal.json +19 -0
- data/spec/fixtures/resources/payment/duplicate_request.json +8 -0
- data/spec/fixtures/resources/payment/invalid_authorization.json +9 -0
- data/spec/fixtures/resources/payment/invalid_request.json +11 -0
- data/spec/fixtures/resources/payment/method_not_allowed.html +1 -0
- data/spec/fixtures/resources/payment/not_found.html +1 -0
- data/spec/fixtures/resources/payment/pending_approval.json +39 -0
- data/spec/fixtures/resources/payment/rejected.json +46 -0
- data/spec/fixtures/resources/properties.proxy.yml +13 -0
- data/spec/fixtures/resources/properties.yml +7 -0
- data/spec/integration/connection_pooling_spec.rb +78 -0
- data/spec/integration/convert_amount_spec.rb +25 -0
- data/spec/integration/idempotence_spec.rb +59 -0
- data/spec/integration/multiline_header_spec.rb +30 -0
- data/spec/integration/payment_product_groups_spec.rb +23 -0
- data/spec/integration/payment_products_spec.rb +22 -0
- data/spec/integration/risk_assessments_spec.rb +37 -0
- data/spec/integration/sdk_proxy_spec.rb +89 -0
- data/spec/integration/token_spec.rb +42 -0
- data/spec/integration_setup.rb +50 -0
- data/spec/lib/client_spec.rb +69 -0
- data/spec/lib/communicator_configuration_spec.rb +179 -0
- data/spec/lib/communicator_spec.rb +31 -0
- data/spec/lib/defaultimpl/default_authenticator_spec.rb +74 -0
- data/spec/lib/defaultimpl/default_connection_idempotence_spec.rb +142 -0
- data/spec/lib/defaultimpl/default_connection_logger_spec.rb +526 -0
- data/spec/lib/defaultimpl/default_connection_spec.rb +334 -0
- data/spec/lib/defaultimpl/default_marshaller_spec.rb +36 -0
- data/spec/lib/factory_spec.rb +41 -0
- data/spec/lib/logging/header_obfuscator_spec.rb +51 -0
- data/spec/lib/logging/logging_util_spec.rb +143 -0
- data/spec/lib/logging/obfuscator_spec.rb +52 -0
- data/spec/lib/logging/ruby_communicator_logger_spec.rb +84 -0
- data/spec/lib/logging/stdout_communicator_logger_spec.rb +64 -0
- data/spec/lib/logging/value_obfuscator_spec.rb +95 -0
- data/spec/lib/meta_data_provider_spec.rb +71 -0
- data/spec/lib/payments_client_spec.rb +157 -0
- data/spec/lib/requestparams/delete_params_spec.rb +21 -0
- data/spec/lib/requestparams/directory_params_spec.rb +27 -0
- data/spec/lib/requestparams/find_params_spec.rb +58 -0
- data/spec/lib/requestparams/get_params_spec.rb +59 -0
- data/spec/lib/requestparams/param_request_spec.rb +57 -0
- data/spec/spec_helper.rb +23 -0
- metadata +565 -0
@@ -0,0 +1,142 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
require 'securerandom'
|
3
|
+
|
4
|
+
Payments ||= Ingenico::Connect::SDK::Domain::Payment
|
5
|
+
Definitions ||= Ingenico::Connect::SDK::Domain::Definitions
|
6
|
+
|
7
|
+
|
8
|
+
describe 'DefaultConnectionIdempotence' do
|
9
|
+
|
10
|
+
CallContext = Ingenico::Connect::SDK::CallContext
|
11
|
+
base_headers = {'dummy' => 'none'}
|
12
|
+
resource_prefix = 'spec/fixtures/resources/defaultimpl/'
|
13
|
+
|
14
|
+
it 'should be able to send a request with idempotence key' do
|
15
|
+
response_body = IO.read(resource_prefix + 'idempotence_success.json')
|
16
|
+
idempotence_key = SecureRandom.uuid
|
17
|
+
call_context = CallContext.new(idempotence_key)
|
18
|
+
request = create_payment_request
|
19
|
+
|
20
|
+
stub_request(:post, 'https://api-sandbox.globalcollect.com/v1/20000/payments')
|
21
|
+
.with(headers: {'X-GCS-Idempotence-Key' => idempotence_key})
|
22
|
+
.to_return(status: 201, body: response_body,
|
23
|
+
headers: base_headers.merge({'Content-Type' => 'application/json', 'Location' => 'api-sandbox.globalcollect.com/v1/20000/payments/000002000020142549460000100001'}))
|
24
|
+
|
25
|
+
response = CLIENT.merchant('20000').payments.create(request, call_context)
|
26
|
+
|
27
|
+
expect(response).to_not be_nil
|
28
|
+
expect(response.payment).to_not be_nil
|
29
|
+
expect(response.payment.id).to_not be_nil
|
30
|
+
expect(call_context.idempotence_key).to eq(idempotence_key)
|
31
|
+
end
|
32
|
+
|
33
|
+
it 'properly reports when the request has arrived prior' do
|
34
|
+
response_body = IO.read(resource_prefix + 'idempotence_success.json')
|
35
|
+
idempotence_key = SecureRandom.uuid
|
36
|
+
idempotence_timestamp = Time.now.to_f*1000 # Convert time to milliseconds
|
37
|
+
call_context = CallContext.new(idempotence_key)
|
38
|
+
request = create_payment_request
|
39
|
+
|
40
|
+
|
41
|
+
stub_request(:post, 'https://api-sandbox.globalcollect.com/v1/20000/payments')
|
42
|
+
.with(headers: {'X-GCS-Idempotence-Key' => idempotence_key})
|
43
|
+
.to_return(status: 201, body: response_body,
|
44
|
+
headers: base_headers.merge({'Content-Type' => 'application/json',
|
45
|
+
'Location' => 'api-sandbox.globalcollect.com/v1/20000/payments/000002000020142549460000100001',
|
46
|
+
'X-GCS-Idempotence-Request-Timestamp' => idempotence_timestamp}))
|
47
|
+
|
48
|
+
response = CLIENT.merchant('20000').payments.create(request, call_context)
|
49
|
+
|
50
|
+
expect(response).to_not be_nil
|
51
|
+
expect(response.payment).to_not be_nil
|
52
|
+
expect(response.payment.id).to_not be_nil
|
53
|
+
expect(call_context.idempotence_key).to eq(idempotence_key)
|
54
|
+
expect(call_context.idempotence_request_timestamp.to_s).to eq(idempotence_timestamp.to_s)
|
55
|
+
end
|
56
|
+
|
57
|
+
it 'throws an exception when payment is refused' do
|
58
|
+
response_body = IO.read(resource_prefix + 'idempotence_rejected.json')
|
59
|
+
idempotence_key = SecureRandom.uuid
|
60
|
+
call_context = CallContext.new(idempotence_key)
|
61
|
+
request = create_payment_request
|
62
|
+
|
63
|
+
stub_request(:post, 'https://api-sandbox.globalcollect.com/v1/20000/payments')
|
64
|
+
.with(headers: {'X-GCS-Idempotence-Key' => idempotence_key})
|
65
|
+
.to_return(status: 402, body: response_body,
|
66
|
+
headers: base_headers.merge({'Content-Type' => 'application/json'}))
|
67
|
+
|
68
|
+
expect{response = CLIENT.merchant('20000').payments.create(request, call_context)}.
|
69
|
+
to raise_error(Ingenico::Connect::SDK::DeclinedPaymentException){ |err|
|
70
|
+
expect(err.status_code).to be(402)
|
71
|
+
expect(err.response_body).to be(response_body)
|
72
|
+
expect(call_context.idempotence_key).to eq(idempotence_key)
|
73
|
+
expect(call_context.idempotence_request_timestamp).to be_nil
|
74
|
+
}
|
75
|
+
end
|
76
|
+
|
77
|
+
it 'reports idempotence failure when another request has been sent prior' do
|
78
|
+
response_body = IO.read(resource_prefix + 'idempotence_rejected.json')
|
79
|
+
idempotence_key = SecureRandom.uuid
|
80
|
+
idempotence_timestamp = Time.now.to_f*1000 # Convert time to milliseconds
|
81
|
+
call_context = CallContext.new(idempotence_key)
|
82
|
+
request = create_payment_request
|
83
|
+
|
84
|
+
stub_request(:post, 'https://api-sandbox.globalcollect.com/v1/20000/payments')
|
85
|
+
.with(headers: {'X-GCS-Idempotence-Key' => idempotence_key})
|
86
|
+
.to_return(status: 402, body: response_body,
|
87
|
+
headers: base_headers.merge({'Content-Type' => 'application/json',
|
88
|
+
'X-GCS-Idempotence-Request-Timestamp' => idempotence_timestamp}))
|
89
|
+
|
90
|
+
expect{response = CLIENT.merchant('20000').payments.create(request, call_context)}.
|
91
|
+
to raise_error(Ingenico::Connect::SDK::DeclinedPaymentException){ |err|
|
92
|
+
expect(err.status_code).to be(402)
|
93
|
+
expect(err.response_body).to be(response_body)
|
94
|
+
expect(call_context.idempotence_key).to eq(idempotence_key)
|
95
|
+
expect(call_context.idempotence_request_timestamp.to_s).to eq(idempotence_timestamp.to_s)
|
96
|
+
}
|
97
|
+
end
|
98
|
+
|
99
|
+
it 'reports idempotence failure when another request is still in progress' do
|
100
|
+
response_body = IO.read(resource_prefix + 'idempotence_duplicate_failure.json')
|
101
|
+
idempotence_key = SecureRandom.uuid
|
102
|
+
idempotence_timestamp = Time.now.to_f*1000 # Convert time to milliseconds
|
103
|
+
call_context = CallContext.new(idempotence_key)
|
104
|
+
request = create_payment_request
|
105
|
+
|
106
|
+
stub_request(:post, 'https://api-sandbox.globalcollect.com/v1/20000/payments')
|
107
|
+
.with(headers: {'X-GCS-Idempotence-Key' => idempotence_key})
|
108
|
+
.to_return(status: 409, body: response_body,
|
109
|
+
headers: base_headers.merge({'Content-Type' => 'application/json',
|
110
|
+
'X-GCS-Idempotence-Request-Timestamp' => idempotence_timestamp}))
|
111
|
+
|
112
|
+
expect{response = CLIENT.merchant('20000').payments.create(request, call_context)}.
|
113
|
+
to raise_error(Ingenico::Connect::SDK::IdempotenceException){ |err|
|
114
|
+
expect(err.status_code).to be(409)
|
115
|
+
expect(err.response_body).to be(response_body)
|
116
|
+
expect(call_context.idempotence_key).to eq(idempotence_key)
|
117
|
+
expect(call_context.idempotence_request_timestamp.to_s).to eq(idempotence_timestamp.to_s)
|
118
|
+
}
|
119
|
+
end
|
120
|
+
end
|
121
|
+
|
122
|
+
def create_payment_request
|
123
|
+
amount_of_money = Definitions::AmountOfMoney.new
|
124
|
+
amount_of_money.amount = 2345
|
125
|
+
amount_of_money.currency_code = 'CAD'
|
126
|
+
customer = Payments::Customer.new
|
127
|
+
billing_address = Definitions::Address.new
|
128
|
+
billing_address.country_code = 'CA'
|
129
|
+
customer.billing_address = billing_address
|
130
|
+
order = Payments::Order.new
|
131
|
+
order.customer = customer
|
132
|
+
card = Definitions::Card.new
|
133
|
+
card.ccv = '123'
|
134
|
+
card.card_number = '4567350000427977'
|
135
|
+
card.expiry_date = '1220'
|
136
|
+
card_payment_method_specific_input = Payments::CardPaymentMethodSpecificInput.new
|
137
|
+
card_payment_method_specific_input.card = card
|
138
|
+
card_payment_method_specific_input.payment_product_id = 1
|
139
|
+
body = Payments::CreatePaymentRequest.new
|
140
|
+
body.card_payment_method_specific_input = card_payment_method_specific_input
|
141
|
+
body
|
142
|
+
end
|
@@ -0,0 +1,526 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
require 'ingenico/connect/sdk/domain/definitions/amount_of_money'
|
3
|
+
require 'ingenico/connect/sdk/domain/definitions/card'
|
4
|
+
require 'ingenico/connect/sdk/domain/payment/card_payment_method_specific_input'
|
5
|
+
require 'ingenico/connect/sdk/domain/payment/create_payment_request'
|
6
|
+
require 'ingenico/connect/sdk/domain/payment/customer'
|
7
|
+
require 'ingenico/connect/sdk/domain/payment/order'
|
8
|
+
require 'ingenico/connect/sdk/merchant/services/convert_amount_params'
|
9
|
+
require 'httpclient'
|
10
|
+
|
11
|
+
# define module first so we can include them
|
12
|
+
# contains validation methods for messages logged in the tests
|
13
|
+
module ValidationDict
|
14
|
+
REQUEST_START = %r(Outgoing request \(requestId='([-a-zA-Z0-9]+)'\):)
|
15
|
+
RESPONSE_START = %r(Incoming response \(requestId='([-a-zA-Z0-9]+)', \d+.\d* ms\):)
|
16
|
+
GET_METHOD = %r(method: 'GET')
|
17
|
+
POST_METHOD = %r(method: 'POST')
|
18
|
+
DELETE_METHOD = %r(method: 'DELETE')
|
19
|
+
STATUS_200 = %r(status-code: '200')
|
20
|
+
STATUS_201 = %r(status-code: '201')
|
21
|
+
STATUS_204 = %r(status-code: '204')
|
22
|
+
STATUS_400 = %r(status-code: '400')
|
23
|
+
STATUS_402 = %r(status-code: '402')
|
24
|
+
STATUS_404 = %r(status-code: '404')
|
25
|
+
STATUS_500 = %r(status-code: '500')
|
26
|
+
DATEHEADER = %r(Date="[^"]+")
|
27
|
+
META_INFO_HEADER = %r(X-GCS-ServerMetaInfo="[^"]*")
|
28
|
+
AUTHORIZATION_HEADER = %r(Authorization="\*\*\*\*\*\*\*\*"[^']*')
|
29
|
+
DUMMY_HEADER = %r(Dummy="none")
|
30
|
+
DATA_JSON_HEADER = %r(Content-Type="application/json")
|
31
|
+
DATA_JSON = %r(content-type: 'application/json')
|
32
|
+
|
33
|
+
def validate_request_headers(message)
|
34
|
+
expect(message).to match(DATEHEADER)
|
35
|
+
expect(message).to match(META_INFO_HEADER)
|
36
|
+
expect(message).to match(AUTHORIZATION_HEADER)
|
37
|
+
end
|
38
|
+
|
39
|
+
def convertAmount_request(message)
|
40
|
+
expect(message).to match(REQUEST_START)
|
41
|
+
message =~ REQUEST_START
|
42
|
+
id = $1 # capture id from the regular expression above
|
43
|
+
expect(message).to match(GET_METHOD)
|
44
|
+
expect(message).to match(%r(uri: '/v1/1234/services/convert/amount\?source=EUR&amount=1000&target=USD'))
|
45
|
+
validate_request_headers(message)
|
46
|
+
return id
|
47
|
+
end
|
48
|
+
|
49
|
+
def convertAmount_response(message)
|
50
|
+
expect(message).to match(RESPONSE_START)
|
51
|
+
message =~ RESPONSE_START
|
52
|
+
id = $1 # capture id from the regular expression above
|
53
|
+
expect(message).to match(STATUS_200)
|
54
|
+
expect(message).to match(DATA_JSON_HEADER)
|
55
|
+
expect(message).to match(DATEHEADER)
|
56
|
+
# expect(message).to match(DUMMY_HEADER)
|
57
|
+
expect(message).to match(%r(content-type: 'application/json'))
|
58
|
+
# token match to validate that a body is in the message
|
59
|
+
expect(message).to match(%r("convertedAmount" : 4547504))
|
60
|
+
return id
|
61
|
+
end
|
62
|
+
|
63
|
+
def createPayment_failure_invalidCardNumber_request(message)
|
64
|
+
expect(message).to match(REQUEST_START)
|
65
|
+
message =~ REQUEST_START
|
66
|
+
id = $1 # capture id from the regular expression above
|
67
|
+
expect(message).to match(POST_METHOD)
|
68
|
+
expect(message).to match(%r(uri: '/v1/1234/payments'))
|
69
|
+
validate_request_headers(message)
|
70
|
+
expect(message).to match(DATA_JSON_HEADER)
|
71
|
+
expect(message).to match(DATA_JSON)
|
72
|
+
expect(message).to match(%r("cardPaymentMethodSpecificInput":)) # token match to validate that a body is in the message
|
73
|
+
return id
|
74
|
+
end
|
75
|
+
|
76
|
+
def createPayment_failure_invalidCardNumber_response(message)
|
77
|
+
expect(message).to match(RESPONSE_START)
|
78
|
+
message =~ RESPONSE_START
|
79
|
+
id = $1 # capture id from the regular expression above
|
80
|
+
expect(message).to match(STATUS_400)
|
81
|
+
expect(message).to match(DATA_JSON_HEADER)
|
82
|
+
# expect(message).to match(DUMMY_HEADER)
|
83
|
+
expect(message).to match(DATEHEADER)
|
84
|
+
expect(message).to match(DATA_JSON)
|
85
|
+
# token match to validate that a body is in the message
|
86
|
+
expect(message).to match(%r("VALUE \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* OF FIELD CREDITCARDNUMBER DID NOT PASS THE LUHNCHECK"))
|
87
|
+
return id
|
88
|
+
end
|
89
|
+
|
90
|
+
def createPayment_failure_rejected_request(message)
|
91
|
+
expect(message).to match(REQUEST_START)
|
92
|
+
message =~ REQUEST_START
|
93
|
+
id = $1 # capture id from the regular expression above
|
94
|
+
expect(message).to match(POST_METHOD)
|
95
|
+
expect(message).to match(%r(uri: '/v1/1234/payments'))
|
96
|
+
validate_request_headers(message)
|
97
|
+
expect(message).to match(DATA_JSON_HEADER)
|
98
|
+
expect(message).to match(DATA_JSON)
|
99
|
+
# token match to validate that a body is in the message
|
100
|
+
expect(message).to match(%r("cardPaymentMethodSpecificInput":))
|
101
|
+
return id
|
102
|
+
end
|
103
|
+
|
104
|
+
def createPayment_failure_rejected_response(message)
|
105
|
+
expect(message).to match(RESPONSE_START)
|
106
|
+
message =~ RESPONSE_START
|
107
|
+
id = $1 # capture id from the regular expression above
|
108
|
+
expect(message).to match(STATUS_402)
|
109
|
+
expect(message).to match(DATA_JSON_HEADER)
|
110
|
+
# expect(message).to match(DUMMY_HEADER)
|
111
|
+
expect(message).to match(DATEHEADER)
|
112
|
+
expect(message).to match(DATA_JSON)
|
113
|
+
# token match to validate that a body is in the message
|
114
|
+
expect(message).to match(%r("message": "Not authorised"))
|
115
|
+
return id
|
116
|
+
end
|
117
|
+
|
118
|
+
def createPayment_request(message)
|
119
|
+
expect(message).to match(REQUEST_START)
|
120
|
+
message =~ REQUEST_START
|
121
|
+
id = $1 # capture id from the regular expression above
|
122
|
+
expect(message).to match(POST_METHOD)
|
123
|
+
expect(message).to match(%r(uri: '/v1/1234/payments'))
|
124
|
+
validate_request_headers(message)
|
125
|
+
expect(message).to match(DATA_JSON_HEADER)
|
126
|
+
expect(message).to match(DATA_JSON)
|
127
|
+
# token match to validate that a body is in the message
|
128
|
+
expect(message).to match(%r("cardPaymentMethodSpecificInput":))
|
129
|
+
return id
|
130
|
+
end
|
131
|
+
|
132
|
+
def createPayment_response(message)
|
133
|
+
expect(message).to match(RESPONSE_START)
|
134
|
+
message =~ RESPONSE_START
|
135
|
+
id = $1 # capture id from the regular expression above
|
136
|
+
expect(message).to match(STATUS_201)
|
137
|
+
expect(message).to match(%r(Location="api-sandbox\.globalcollect\.com/v1/1234/payments/000000123410000595980000100001"))
|
138
|
+
expect(message).to match(DATA_JSON_HEADER)
|
139
|
+
# expect(message).to match(DUMMY_HEADER)
|
140
|
+
expect(message).to match(DATEHEADER)
|
141
|
+
expect(message).to match(DATA_JSON)
|
142
|
+
# token match to validate that a body is in the message
|
143
|
+
expect(message).to match(%r("cardNumber": "\*\*\*\*\*\*\*\*\*\*\*\*3456"))
|
144
|
+
return id
|
145
|
+
end
|
146
|
+
|
147
|
+
def deleteToken_request(message)
|
148
|
+
expect(message).to match(REQUEST_START)
|
149
|
+
message =~ REQUEST_START
|
150
|
+
id = $1 # capture id from the regular expression above
|
151
|
+
expect(message).to match(DELETE_METHOD)
|
152
|
+
expect(message).to match(%r(uri: '/v1/1234/tokens/5678'))
|
153
|
+
validate_request_headers(message)
|
154
|
+
return id
|
155
|
+
end
|
156
|
+
|
157
|
+
def deleteToken_response(message)
|
158
|
+
expect(message).to match(RESPONSE_START)
|
159
|
+
message =~ RESPONSE_START
|
160
|
+
id = $1 # capture id from the regular expression above
|
161
|
+
expect(message).to match(STATUS_204)
|
162
|
+
# expect(message).to match(DUMMY_HEADER)
|
163
|
+
expect(message).to match(DATEHEADER)
|
164
|
+
return id
|
165
|
+
end
|
166
|
+
|
167
|
+
def notFound_response(message)
|
168
|
+
expect(message).to match(RESPONSE_START)
|
169
|
+
message =~ RESPONSE_START
|
170
|
+
id = $1 # capture id from the regular expression above
|
171
|
+
expect(message).to match(STATUS_404)
|
172
|
+
# expect(message).to match(DUMMY_HEADER)
|
173
|
+
expect(message).to match(DATEHEADER)
|
174
|
+
expect(message).to match(%r(Content-Type="text/html"))
|
175
|
+
expect(message).to match(%r(content-type: 'text/html'))
|
176
|
+
expect(message).to match(%r(body: 'Not Found'))
|
177
|
+
return id
|
178
|
+
end
|
179
|
+
|
180
|
+
def testConnection_request(message)
|
181
|
+
expect(message).to match(REQUEST_START)
|
182
|
+
message =~ REQUEST_START
|
183
|
+
id = $1 # capture id from the regular expression above
|
184
|
+
expect(message).to match(GET_METHOD)
|
185
|
+
expect(message).to match(%r(uri: '/v1/1234/services/testconnection'))
|
186
|
+
validate_request_headers(message)
|
187
|
+
return id
|
188
|
+
end
|
189
|
+
|
190
|
+
def testConnection_response(message)
|
191
|
+
expect(message).to match(RESPONSE_START)
|
192
|
+
message =~ RESPONSE_START
|
193
|
+
id = $1 # capture id from the regular expression above
|
194
|
+
expect(message).to match(STATUS_200)
|
195
|
+
# expect(message).to match(DUMMY_HEADER)
|
196
|
+
expect(message).to match(DATEHEADER)
|
197
|
+
expect(message).to match(DATA_JSON_HEADER)
|
198
|
+
expect(message).to match(DATA_JSON)
|
199
|
+
# token match to validate that a body is in the message
|
200
|
+
expect(message).to match(%r("result": "OK"))
|
201
|
+
return id
|
202
|
+
end
|
203
|
+
|
204
|
+
def unknownServerError_response(message)
|
205
|
+
expect(message).to match(RESPONSE_START)
|
206
|
+
message =~ RESPONSE_START
|
207
|
+
id = $1 # capture id from the regular expression above
|
208
|
+
expect(message).to match(STATUS_500)
|
209
|
+
expect(message).to match(DATA_JSON_HEADER)
|
210
|
+
# expect(message).to match(DUMMY_HEADER)
|
211
|
+
expect(message).to match(DATEHEADER)
|
212
|
+
expect(message).to match(DATA_JSON)
|
213
|
+
# token match to validate that a body is in the message
|
214
|
+
expect(message).to match(%r("message": "UNKNOWN_SERVER_ERROR"))
|
215
|
+
return id
|
216
|
+
end
|
217
|
+
end
|
218
|
+
|
219
|
+
|
220
|
+
# -----test examples-----:
|
221
|
+
|
222
|
+
describe 'DefaultConnectionLogging' do
|
223
|
+
|
224
|
+
include ValidationDict
|
225
|
+
|
226
|
+
let(:logger){TestLogger.new}
|
227
|
+
base_headers = {'dummy' => 'none', 'Date' => 'Mon, 1 Jan 2000 00:00:00 GMT'}
|
228
|
+
resource_prefix = 'spec/fixtures/resources/defaultimpl/'
|
229
|
+
|
230
|
+
# tests testconnection
|
231
|
+
it 'should be able to log a simple request' do
|
232
|
+
response_body = IO.read(resource_prefix + 'testConnection.json')
|
233
|
+
|
234
|
+
stub_request(:get, 'https://api-sandbox.globalcollect.com/v1/1234/services/testconnection')
|
235
|
+
.to_return(status: 200, body: response_body,
|
236
|
+
headers: base_headers.merge({'Content-Type' => 'application/json'}))
|
237
|
+
|
238
|
+
CLIENT.enable_logging(logger)
|
239
|
+
response = CLIENT.merchant('1234').services.testconnection
|
240
|
+
|
241
|
+
expect(response).to_not be_nil
|
242
|
+
expect(response.result).to eq('OK')
|
243
|
+
|
244
|
+
validate_request_and_response(logger.entries[0], logger.entries[1], 'testConnection')
|
245
|
+
end
|
246
|
+
|
247
|
+
# tests convert_amount
|
248
|
+
it 'can log a GET request with parameters' do
|
249
|
+
response_body = IO.read(resource_prefix + 'convertAmount.json')
|
250
|
+
|
251
|
+
stub_request(:get, 'https://api-sandbox.globalcollect.com/v1/1234/services/convert/amount?amount=1000&source=EUR&target=USD')
|
252
|
+
.to_return(status: 200, body: response_body,
|
253
|
+
headers: base_headers.merge({'Content-Type' => 'application/json'}))
|
254
|
+
|
255
|
+
query_params = Ingenico::Connect::SDK::Merchant::Services::ConvertAmountParams.new
|
256
|
+
query_params.amount = 1000
|
257
|
+
query_params.source = 'EUR'
|
258
|
+
query_params.target = 'USD'
|
259
|
+
CLIENT.enable_logging(logger)
|
260
|
+
|
261
|
+
response = CLIENT.merchant('1234').services.convert_amount(query_params)
|
262
|
+
|
263
|
+
expect(response).to_not be_nil
|
264
|
+
expect(response.converted_amount).to_not be_nil
|
265
|
+
|
266
|
+
validate_request_and_response(logger.entries[0], logger.entries[1], 'convertAmount')
|
267
|
+
end
|
268
|
+
|
269
|
+
# tests delete token
|
270
|
+
it 'can log DELETE requests' do
|
271
|
+
stub_request(:delete, 'https://api-sandbox.globalcollect.com/v1/1234/tokens/5678')
|
272
|
+
.to_return(status: 204, headers: base_headers)
|
273
|
+
|
274
|
+
CLIENT.enable_logging(logger)
|
275
|
+
response = CLIENT.merchant('1234').tokens.delete('5678', nil)
|
276
|
+
|
277
|
+
expect(response).to_not be_nil
|
278
|
+
|
279
|
+
validate_request_and_response(logger.entries[0], logger.entries[1], 'deleteToken')
|
280
|
+
end
|
281
|
+
|
282
|
+
# tests create payment
|
283
|
+
it 'can log POST responses' do
|
284
|
+
response_body = IO.read(resource_prefix + 'createPayment.json')
|
285
|
+
request = create_payment_request
|
286
|
+
|
287
|
+
stub_request(:post, 'https://api-sandbox.globalcollect.com/v1/1234/payments')
|
288
|
+
.to_return(status: 201, body: response_body,
|
289
|
+
headers: base_headers.merge({'Content-Type' => 'application/json',
|
290
|
+
'Location' => 'api-sandbox.globalcollect.com/v1/1234/payments/000000123410000595980000100001'}))
|
291
|
+
|
292
|
+
CLIENT.enable_logging(logger)
|
293
|
+
response = CLIENT.merchant('1234').payments.create(request)
|
294
|
+
|
295
|
+
expect(response).to_not be_nil
|
296
|
+
expect(response.payment).to_not be_nil
|
297
|
+
expect(response.payment.id).to_not be_nil
|
298
|
+
|
299
|
+
validate_request_and_response(logger.entries[0], logger.entries[1], 'createPayment')
|
300
|
+
end
|
301
|
+
|
302
|
+
# tests create payment with an invalid card number
|
303
|
+
it 'can log error responses' do
|
304
|
+
response_body = IO.read(resource_prefix + 'createPayment.failure.invalidCardNumber.json')
|
305
|
+
request = create_payment_request
|
306
|
+
|
307
|
+
stub_request(:post, 'https://api-sandbox.globalcollect.com/v1/1234/payments')
|
308
|
+
.to_return(status: 400, body: response_body,
|
309
|
+
headers: base_headers.merge({'Content-Type' => 'application/json'}))
|
310
|
+
|
311
|
+
CLIENT.enable_logging(logger)
|
312
|
+
expect{CLIENT.merchant('1234').payments.create(request)}.to raise_error(Ingenico::Connect::SDK::ValidationException)
|
313
|
+
|
314
|
+
validate_request_and_response(logger.entries[0], logger.entries[1], 'createPayment_failure_invalidCardNumber')
|
315
|
+
end
|
316
|
+
|
317
|
+
# tests create payment with a rejected payment
|
318
|
+
it 'logs rejected payments' do
|
319
|
+
response_body = IO.read(resource_prefix + 'createPayment.failure.rejected.json')
|
320
|
+
request = create_payment_request
|
321
|
+
|
322
|
+
stub_request(:post, 'https://api-sandbox.globalcollect.com/v1/1234/payments')
|
323
|
+
.to_return(status: 402, body: response_body,
|
324
|
+
headers: base_headers.merge({'Content-Type' => 'application/json'}))
|
325
|
+
|
326
|
+
CLIENT.enable_logging(logger)
|
327
|
+
expect{CLIENT.merchant('1234').payments.create(request)}.to raise_error(Ingenico::Connect::SDK::DeclinedPaymentException)
|
328
|
+
|
329
|
+
validate_request_and_response(logger.entries[0], logger.entries[1], 'createPayment_failure_rejected')
|
330
|
+
end
|
331
|
+
|
332
|
+
# tests the unknown server error response
|
333
|
+
it 'logs general HTTP errors' do
|
334
|
+
response_body = IO.read(resource_prefix + 'unknownServerError.json')
|
335
|
+
|
336
|
+
stub_request(:get, 'https://api-sandbox.globalcollect.com/v1/1234/services/testconnection')
|
337
|
+
.to_return(status: 500, body: response_body,
|
338
|
+
headers: base_headers.merge({'Content-Type' => 'application/json'}))
|
339
|
+
|
340
|
+
CLIENT.enable_logging(logger)
|
341
|
+
expect{CLIENT.merchant('1234').services.testconnection}.to raise_error(Ingenico::Connect::SDK::GlobalCollectException)
|
342
|
+
|
343
|
+
validate_request_and_response(logger.entries[0], logger.entries[1], 'testConnection', 'unknownServerError')
|
344
|
+
end
|
345
|
+
|
346
|
+
# tests a not found response
|
347
|
+
it 'logs non-json' do
|
348
|
+
response_body = IO.read(resource_prefix + 'notFound.html')
|
349
|
+
|
350
|
+
stub_request(:get, 'https://api-sandbox.globalcollect.com/v1/1234/services/testconnection')
|
351
|
+
.to_return(status: 404, body: response_body,
|
352
|
+
headers: base_headers.merge({'Content-Type' => 'text/html'}))
|
353
|
+
|
354
|
+
CLIENT.enable_logging(logger)
|
355
|
+
expect{CLIENT.merchant('1234').services.testconnection}.to raise_error(Ingenico::Connect::SDK::NotFoundException)
|
356
|
+
|
357
|
+
validate_request_and_response(logger.entries[0], logger.entries[1], 'testConnection', 'notFound')
|
358
|
+
end
|
359
|
+
|
360
|
+
# tests a read timeout
|
361
|
+
it 'logs timeouts' do
|
362
|
+
response_body = IO.read(resource_prefix + 'notFound.html')
|
363
|
+
|
364
|
+
stub_request(:get, 'https://api-sandbox.globalcollect.com/v1/1234/services/testconnection')
|
365
|
+
.to_raise(HTTPClient::ReceiveTimeoutError)
|
366
|
+
|
367
|
+
CLIENT.enable_logging(logger)
|
368
|
+
expect{CLIENT.merchant('1234').services.testconnection}.to raise_error(Ingenico::Connect::SDK::CommunicationException)
|
369
|
+
|
370
|
+
request = logger.entries[0]
|
371
|
+
expect(request[0]).to_not be_nil
|
372
|
+
expect(request[1]).to be_nil, "Error logged that should not have been thrown:/n#{request[1]}"
|
373
|
+
|
374
|
+
response = logger.entries[1]
|
375
|
+
expect(response[0]).to_not be_nil
|
376
|
+
expect(response[1]).to_not be_nil, 'A timeout error should have been logged'
|
377
|
+
expect(response[1]).to be_a(HTTPClient::TimeoutError)
|
378
|
+
|
379
|
+
validate_request_and_error(logger.entries[0], logger.entries[1], 'testConnection')
|
380
|
+
end
|
381
|
+
|
382
|
+
it 'can log requests individually' do
|
383
|
+
response_body = IO.read(resource_prefix + 'testConnection.json')
|
384
|
+
|
385
|
+
stub_request(:get, 'https://api-sandbox.globalcollect.com/v1/1234/services/testconnection')
|
386
|
+
.to_return{ |request| CLIENT.disable_logging
|
387
|
+
{body: response_body, status: 200, headers: base_headers.merge({'Content-type' => 'application/json'})}}
|
388
|
+
|
389
|
+
CLIENT.enable_logging(logger)
|
390
|
+
response = CLIENT.merchant('1234').services.testconnection
|
391
|
+
|
392
|
+
expect(response.result).to eq('OK')
|
393
|
+
|
394
|
+
request = logger.entries[0]
|
395
|
+
expect(request[0]).to_not be_nil
|
396
|
+
expect(request[1]).to be_nil, "Error logged that should not have been thrown:/n#{request[1]}"
|
397
|
+
|
398
|
+
validate_request(logger.entries[0], 'testConnection')
|
399
|
+
end
|
400
|
+
|
401
|
+
it 'can log responses individually' do
|
402
|
+
response_body = IO.read(resource_prefix + 'testConnection.json')
|
403
|
+
|
404
|
+
stub_request(:get, 'https://api-sandbox.globalcollect.com/v1/1234/services/testconnection')
|
405
|
+
.to_return{ |request| CLIENT.enable_logging(logger)
|
406
|
+
{body: response_body, status: 200, headers: base_headers.merge({'Content-type' => 'application/json'})}}
|
407
|
+
|
408
|
+
response = CLIENT.merchant('1234').services.testconnection
|
409
|
+
|
410
|
+
expect(response.result).to eq('OK')
|
411
|
+
|
412
|
+
response = logger.entries[0]
|
413
|
+
expect(response[0]).to_not be_nil
|
414
|
+
expect(response[1]).to be_nil, "Error logged that should not have been thrown:/n#{response[1]}"
|
415
|
+
|
416
|
+
validate_response(logger.entries[0], 'testConnection')
|
417
|
+
end
|
418
|
+
|
419
|
+
it 'can log errors individually' do
|
420
|
+
response_body = IO.read(resource_prefix + 'notFound.html')
|
421
|
+
|
422
|
+
stub_request(:get, 'https://api-sandbox.globalcollect.com/v1/1234/services/testconnection')
|
423
|
+
.to_return{ |request| CLIENT.enable_logging(logger)
|
424
|
+
raise HTTPClient::ReceiveTimeoutError.new}
|
425
|
+
|
426
|
+
expect{CLIENT.merchant('1234').services.testconnection}.to raise_error(Ingenico::Connect::SDK::CommunicationException)
|
427
|
+
|
428
|
+
response = logger.entries[0]
|
429
|
+
expect(response[0]).to_not be_nil
|
430
|
+
expect(response[1]).to_not be_nil, 'A timeout error should have been logged'
|
431
|
+
expect(response[1]).to be_a(HTTPClient::TimeoutError)
|
432
|
+
|
433
|
+
validate_error(logger.entries[0])
|
434
|
+
end
|
435
|
+
end
|
436
|
+
|
437
|
+
# Asserts that the request and response contain messages and no errors.
|
438
|
+
# Asserts that the request and response messages match the format
|
439
|
+
# in request_resource_prefix.request and response_resource_prefix.response respectively.
|
440
|
+
# If response_resource_prefix is not given it is assumed to be the same as the request_resource_prefix.
|
441
|
+
def validate_request_and_response(request, response,
|
442
|
+
request_resource_prefix, response_resource_prefix=nil)
|
443
|
+
# for request and response, check that the message exists in the logs and there is no error logged
|
444
|
+
expect(request[0]).to_not be_nil
|
445
|
+
expect(request[1]).to be_nil, "Error logged that should not have been thrown:/n#{request[1]}"
|
446
|
+
|
447
|
+
expect(response[0]).to_not be_nil
|
448
|
+
expect(response[1]).to be_nil, "Error logged that should not have been thrown:/n#{response[1]}"
|
449
|
+
|
450
|
+
response_resource_prefix ||= request_resource_prefix
|
451
|
+
request_id = validate_request(request, request_resource_prefix)
|
452
|
+
fail if request_id.nil? # Request_id was not captured
|
453
|
+
validate_response(response, response_resource_prefix, request_id)
|
454
|
+
end
|
455
|
+
|
456
|
+
# Asserts that the request message matches the request format in _resource_prefix.request_
|
457
|
+
# and that the request and error id are the same.
|
458
|
+
# Resource prefix is the location of the request resource, which will be appended with _.request_ to get the file location.
|
459
|
+
def validate_request_and_error(request, response_error, resource_prefix)
|
460
|
+
request_id = validate_request(request, resource_prefix)
|
461
|
+
validate_error(response_error, request_id)
|
462
|
+
end
|
463
|
+
|
464
|
+
# Asserts that the request message matches the request format in _resource_prefix.request_.
|
465
|
+
# Resource prefix is the location of the request resource, which will be appended with _.request_ to get the file location.
|
466
|
+
# Returns the request_id found in the request so it can be matched with a possible response or error
|
467
|
+
def validate_request(request, request_resource_prefix)
|
468
|
+
method = (request_resource_prefix + '_request').to_sym
|
469
|
+
return send(method, request[0])
|
470
|
+
end
|
471
|
+
|
472
|
+
# Asserts that the response message matches the response format in _resource_prefix.response_.
|
473
|
+
# Resource prefix is the location of the response resource, which will be appended with _.response_ to get the file location.
|
474
|
+
# If the parameter _request_id_ is given, it will be matched with the _request_id_ found in the response_message
|
475
|
+
def validate_response(response, response_resource_prefix, request_id=nil)
|
476
|
+
method = (response_resource_prefix + '_response').to_sym
|
477
|
+
response_id = send(method, response[0])
|
478
|
+
expect(response_id).to eq(request_id) unless request_id.nil?
|
479
|
+
end
|
480
|
+
|
481
|
+
# Validates that the error message contains a requestId
|
482
|
+
# If a request_id is provided, it is matched against the error_id found in the error
|
483
|
+
def validate_error(error, request_id=nil)
|
484
|
+
error_pattern_string = %r(Error occurred for outgoing request \(requestId='(?<error_id>[-a-zA-Z0-9]+)', \d+.\d* ms\))
|
485
|
+
expect(error[0]).to match(error_pattern_string)
|
486
|
+
error[0] =~ error_pattern_string # match to capture id
|
487
|
+
error_id = $1
|
488
|
+
expect(error_id).to eq(request_id) unless request_id.nil?
|
489
|
+
end
|
490
|
+
|
491
|
+
|
492
|
+
class TestLogger < Ingenico::Connect::SDK::Logging::CommunicatorLogger
|
493
|
+
|
494
|
+
attr_accessor :entries
|
495
|
+
|
496
|
+
def initialize
|
497
|
+
@entries = []
|
498
|
+
end
|
499
|
+
|
500
|
+
def log(message, thrown = nil)
|
501
|
+
@entries << [message, thrown]
|
502
|
+
end
|
503
|
+
end
|
504
|
+
|
505
|
+
|
506
|
+
def create_payment_request
|
507
|
+
amount_of_money = Ingenico::Connect::SDK::Domain::Definitions::AmountOfMoney.new
|
508
|
+
amount_of_money.amount = 2345
|
509
|
+
amount_of_money.currency_code = 'CAD'
|
510
|
+
customer = Ingenico::Connect::SDK::Domain::Payment::Customer.new
|
511
|
+
billing_address = Ingenico::Connect::SDK::Domain::Definitions::Address.new
|
512
|
+
billing_address.country_code = 'CA'
|
513
|
+
customer.billing_address = billing_address
|
514
|
+
order = Ingenico::Connect::SDK::Domain::Payment::Order.new
|
515
|
+
order.customer = customer
|
516
|
+
card = Ingenico::Connect::SDK::Domain::Definitions::Card.new
|
517
|
+
card.cvv = '123'
|
518
|
+
card.card_number = '4567350000427977'
|
519
|
+
card.expiry_date = '1220'
|
520
|
+
card_payment_method_specific_input = Ingenico::Connect::SDK::Domain::Payment::CardPaymentMethodSpecificInput.new
|
521
|
+
card_payment_method_specific_input.card = card
|
522
|
+
card_payment_method_specific_input.payment_product_id = 1
|
523
|
+
body = Ingenico::Connect::SDK::Domain::Payment::CreatePaymentRequest.new
|
524
|
+
body.card_payment_method_specific_input = card_payment_method_specific_input
|
525
|
+
body
|
526
|
+
end
|