====== PayPal ====== `Paypal `_ is an American online payment provider available worldwide and one of the few that does not charge a subscription fee. .. note:: While PayPal is available in `over 200 countries/regions `_, only `a selection of currencies are supported `_. .. _payment_providers/paypal/configuration-paypal: Configuration in PayPal ======================= #. `Log into your PayPal Developer Dashboard `_. #. Click :guilabel:`Apps & Credentials` and click :guilabel:`Create App`. #. Enter an :guilabel:`App Name` and click :guilabel:`Create App`. #. Copy the :guilabel:`Client ID` and :guilabel:`Secret` and save them for :ref:`later `. .. important:: If you use customer names or addresses that include accented or non-Latin characters, you **must** configure the encoding format of the payment request sent by Odoo to PayPal to avoid transaction failures without notice. To do so, access the `PayPal button language encoding setting `_, click :guilabel:`More Options`, and set the :guilabel:`Encoding` field to :guilabel:`UTF-8`. If you are trying PayPal as a test, access your :ref:`PayPal Sandbox account ` and `configure the encoding format for your sandbox account `_. .. tip:: For encrypted website payments & EWP_SETTINGS errors, please check the `PayPal documentation `_. .. _payment_providers/paypal/configuration-odoo: Configuration in Odoo ===================== #. :ref:`Navigate to the payment provider PayPal `. #. In the :guilabel:`Credentials` tab, enter the :guilabel:`Email` linked to your PayPal account, then fill in the :guilabel:`Client ID` and :guilabel:`Client Secret` fields with the values you saved at the step :ref:`payment_providers/paypal/configuration-paypal`. #. Click :guilabel:`Generate your webhook` to create the :guilabel:`Webhook ID`. #. Set the :guilabel:`State` field to :guilabel:`Enabled`, and make sure the PayPal payment provider is :guilabel:`Published`. #. Configure the remaining options as desired. .. _payment_providers/paypal/testing: Testing ======= PayPal provides two sandbox accounts that you can use to simulate live transactions: - A business account (to use as the merchant account, e.g., `ab-1abc12345678@business.example.com`); - A default personal account (to use as the shopper account, e.g., `ba-9cba87654321@personal.example.com`). To test the PayPal payment workflow in Odoo: #. Log into the `Paypal Developer Site `_ using your PayPal credentials and go to :menuselection:`Testing Tools --> Sandbox Accounts`. #. Click the :icon:`fa-ellipsis-v` (:guilabel:`ellipsis`) icon next to the sandbox business account and select :guilabel:`View/Edit account`. #. Copy the :guilabel:`Email`, :guilabel:`Client ID`, and :guilabel:`Secret` and save them for the next step. #. In Odoo, :ref:`configure the PayPal payment provider ` with the values saved at the previous step and set the :guilabel:`State` field to :guilabel:`Test Mode`. You can then run a test transaction from Odoo using the sandbox personal account. .. seealso:: - :ref:`payment_providers/test-mode` - :doc:`../payment_providers`