* The JavaScript library to manage payouts, transfers and cards withoutsaving sensitive information in your django application. (Giving us the reliefof not having to make our Django system [PCI Compliant][pci-wiki-page])

This package includes JSX and JS files to be able to use the JavaScript librarywithout further delay.

To use the JSX files, you should have Webpack or Gulp installed to compile theJSX to ES5 or ES6. But due to my inexperience for including NPM dependenciesin pip packages, you will require to install `react` and `react-dom` byhand. Although we could have used the Node package of Openpay and prevent somemanual configuration, we have no idea of how the security is managed insidethe Node package to be used directly from front-end.

This package requires to have knowledge of your Openpay's public, private andmerchant keys. To do this you just have to put your keys inside the`settings.py` file of your Django project using the following variables:

The `AbstractCustomer` model is a model which can be inherited from. This wasdone because you may want to make your `User` model the customer, or manage ateam of users as one customer. It is up to you, just remember to use all thefields described in the abstract, or (in case you want to rename the fields)set them to `None` and overwrite the `pull` and `push` methods.

Then you will have to run the `python manage.py makemigrations` command. Thisis necessary due to the problem that there is no default `Customer` model,until you inherit from the `AbstractCustomer` and declare it inside thesettings.py variable `OPENPAY_CUSTOMER_MODEL`.

In order to be able to use the Webhooks feature, you need to link your Openpayproject to a specific url of your project (which calls the`'django_openpay.views.webhook'` view), inside the Openpay system. Rememberthat this package tries to make everything as secure as possible and, for thatsame reason, you need to activate the BasicAuth option in the Openpay systemwhen you are creating the webhook, using a username and a password (it must NOTbe a Django user). That same username and password will be added directly inyour django settings file inside the the variable `OPENPAY_BASICAUTH_USERS`.This variable should be used like:

**django-openpay** doesn't save critical information in its django models.All the information that can be saved inside the models without needing to bePCI Compliant is being saved. The most sensitive information is being accessedfrom the Openpay servers by using access tokens.

**django-openpay** has not been tested for security vulnerabilities yet and doesnot have an SSL certificate preconfiguration, this is the reason behind ourdecision to be able to create cards only in the front-end.