vanilo/netopia

Netopia Payment Gateway Support for Vanilo (Laravel)

2.1.1 2023-12-17 13:55 UTC

This package is auto-updated.

Last update: 2024-04-15 19:22:15 UTC


README

Tests Packagist Stable Version StyleCI Packagist downloads MIT Software License

This library implements the Netopia Payment Processor for Vanilo Payments.

Being a Concord Module it is intended to be used by Laravel Applications.

IMPORTANT

Netopia uses the RC4 cipher algo for its messages. In recent (~2023) OpenSSL installations this cipher is disabled by default.

In order to use this library you must enable legacy options for OpenSSL 3:

  1. Find and open the file at /etc/ssl/openssl.cnf
  2. At the [default_sect] section change it to the following:
    [default_sect]
    activate = 1
    [legacy_sect]
    activate = 1
  3. Then find the [provider_sect] and change it to the following:
    [provider_sect]
    default = default_sect
    legacy = legacy_sect

Documentation

Refer to the markdown files in the docs folder.

To-do

The library works but there's space for improvement.

1. Recurring Payments

It's completely untested at the moment, thus it may or may not work

2. Usage of Loyalty Points

It's completely untested at the moment.

3. Add More Specific Error Test Cases

  • Use the test cards from the doc to generate scenarios for various failed cases
  • Catch the XML responses, add them to unit tests and check them specifically

Cases:

  • Successful Payment. Covered.
  • Expired Card. Covered.
  • Partial refund. Covered.
  • Complete refund. Covered.
  • Transaction Declined. Covered.
  • Insufficient funds. No unit test coverage.
  • Incorrect CVV2/CCV. No unit test coverage.
  • Transaction not permitted (eg. card not enrolled). No unit test coverage.
  • Risky card detected (eg. stolen card). No unit test coverage.
  • Error at the origin Bank (eg. can't connect to the Bank). No unit test coverage.

4. Test With Real Netopia Keys

During tests, I created a test account at Netopia and generated test keys, to establish close to real life scenarios during unit tests.

There were issues with simulating the encrypted messages generated by Netopia using the actual keys. The tests use a locally generated RSA key pair for this functionality. It seems to do the job, but if we find to cause of the issue, let's use actual Netopia keys.

5. Record More Response Details

Netopia returns the following data which we should record locally:

  • pan_masked (card number digits eg. 4****2806)

6. SMS Payment

Netopia supports SMS payments. Likely won't be implemented here as it's more for micro payments, but hell, who knows 🤷