currency-fair/integration-brazilian-bank

The integration example with a Brazilian bank.

dev-master 2020-01-26 23:15 UTC

This package is auto-updated.

Last update: 2024-12-27 11:29:32 UTC


README

CircleCI

Integration with an Brazilian bank (example for transactions in Euro)

Description

This is a package created by me for making transactions with an Brazilian bank. All transactions in Euro are processed by the Brazilian bank.

The files follow the same structure as Integration Irish Bank. The idea was to create an easier structure for all developers in a team to integrate with another platform/API quickly, easy to test, easy to extend and change the behavior while also using design patterns and object orientation.

Files` Structure

Integration: All files of the integration are in this folder.

Integration\Contract: The main interefaces of the project are in this folder. In a real project, we should have another package as a main package in which we could centralize some interfaces.

Integration\Entity: These classes are representations of the objects sent or retrieved by the API. They are the only thing known by the project that are using it. We could say that it is an implementation of the famous DTO (Data transfer object).

Integration\Exception: Exceptions created specifically by this integration. They could be caught by who is using it.

Integration\Factory: This folder has all the factories to simplify the creation of the "parser", "formatter" and "requester". They are implementations of the "Simple Factory", and they are really simple (with switches), however, I don't think it was necessary to implement the "Factory method", it would increase the complexity (with loads of classes) and I am sure that the number of the parsers, formatters, and requesters won't increase so much.

Integration\Formatter: The idea behind a formatter is to convert an object (Entity) to JSON, XML or any form you would like. These formatted objects will be sent by the API.

Integration\Parser: The idea behind a parser is almost the same as the formatters, however, the parsers are for converting the response of the API to Entities known by the client that uses these packages as a dependency.

Integration\Requester: Requesters are classes responsible for making the requests with the APIs, we should have one for each endpoint. They have an instance of the Guzzle Http, but this part would be improved (unfortunately I didn't have time for implementing it). I think the HTTP client should be in the main package of the integration (not implemented).

Client: This class works as a Facade, it is through this class that the package is used. It is exactly as a Facade pattern, we call methods that group the parsers, formatters, and requesters.

tests: It's here all unit tests for this package. I think it is with a good coverage.

How do i use it?:

composer require gabrielanhaia/currency-integration-brazilian-bank

Note: It will not be necessary to do that, I had already added as a dependency.

Running the unit tests

composer install
php vendor/bin/phpunit

Notes

  1. I had already develop a structure similar to that, but much bigger. This structure is working today in a E-commerce that integrates with more than 200 different kinds of API's.
  2. The CircleCi is running the build and the Unit tests.