# Stripe [Stripe](https://stripe.com/) is a United States-based online payment solution provider allowing businesses to accept **credit cards** and other payment methods. :::{seealso} - [List of countries supported by Stripe](https://stripe.com/global) - [List of payment methods supported by Stripe](https://stripe.com/payments/payment-methods) ::: ## Create your Stripe account with Odoo The method to acquire your credentials depends on your hosting type: ```{eval-rst} .. tabs:: .. group-tab:: Odoo Online #. :ref:`Navigate to the payment provider Stripe ` and click :guilabel:`Connect Stripe`. #. Go through the setup process and confirm your email address when Stripe sends you a confirmation email. #. At the end of the process, click :guilabel:`Agree and submit`. If all requested information has been submitted, you are then redirected to Odoo, and your payment provider is enabled. .. group-tab:: Odoo.sh or On-premise #. :ref:`Navigate to the payment provider Stripe ` and click :guilabel:`Connect Stripe`. #. Go through the setup process and confirm your email address when Stripe sends you a confirmation email. #. At the end of the process, click :guilabel:`Agree and submit`; you are then redirected to the payment provider **Stripe** in Odoo. #. :ref:`Fill in your credentials `. #. :ref:`Generate a webhook `. #. Set the :guilabel:`State` field to :guilabel:`Enabled`. ``` :::{tip} - To use an existing Stripe account, {ref}`activate the Developer mode ` and {ref}`enable Stripe manually `. You can then {ref}`Fill in your credentials `, {ref}`generate a webhook `, and enable the payment provider. - You can also test Stripe using the {ref}`payment_providers/test-mode`. To do so, first, [log into your Stripe dashboard](https://dashboard.stripe.com/dashboard) and switch to the **Test mode**. Then, in Odoo, {ref}`activate the Developer mode `, {ref}`navigate to the payment provider Stripe `, {ref}`fill in your API credentials ` with the test keys, and set the {guilabel}`State` field to {guilabel}`Test Mode`. ::: (stripe-api-keys)= ### Fill in your credentials If your **API credentials** are required to connect with your Stripe account, proceed as follows: 1. Go to [the API keys page on Stripe](https://dashboard.stripe.com/account/apikeys), or log into your Stripe dashboard and go to {menuselection}`Developers --> API Keys`. 2. In the {guilabel}`Standard keys` section, copy the {guilabel}`Publishable key` and the {guilabel}`Secret key` and save them for later. 3. In Odoo, {ref}`navigate to the payment provider Stripe `. 4. In the {guilabel}`Credentials` tab, fill in the {guilabel}`Publishable Key` and {guilabel}`Secret Key` fields with the values you previously saved. (stripe-webhook)= ### Generate a webhook If your **Webhook Signing Secret** is required to connect with your Stripe account, you can create a webhook automatically or manually. ```{eval-rst} .. tabs:: .. tab:: Create the webhook automatically Make sure your :ref:`Publishable and Secret keys ` are filled in, then click :guilabel:`Generate your webhook`. .. tab:: Create the webhook manually #. Go to the `Webhooks page on Stripe `_, or log into your Stripe dashboard and go to :menuselection:`Developers --> Webhooks`. #. In the :guilabel:`Hosted endpoints` section, click :guilabel:`Add endpoint`. Then, in the :guilabel:`Endpoint URL` field, enter your Odoo database's URL, followed by `/payment/stripe/webhook`, e.g., `https://yourcompany.odoo.com/payment/stripe/webhook`. #. Click :guilabel:`Select events` at the bottom of the form, then select the following events: - in the :guilabel:`Charge` section: :guilabel:`charge.refunded` and :guilabel:`charge.refund.updated`; - in the :guilabel:`Payment intent` section: :guilabel:`payment_intent.amount_capturable_updated`, :guilabel:`payment_intent.payment_failed`, :guilabel:`payment_intent.processing`, and :guilabel:`payment_intent.succeeded`; - in the :guilabel:`Setup intent` section: :guilabel:`setup_intent.succeeded`. #. Click :guilabel:`Add events`. #. Click :guilabel:`Add endpoint`, then click :guilabel:`Reveal` and save your :guilabel:`Signing secret` for later. #. In Odoo, :ref:`navigate to the payment provider Stripe `. #. In the :guilabel:`Credentials` tab, fill the :guilabel:`Webhook Signing Secret` field with the value you previously saved. .. note:: You can select other events, but they are currently not processed by Odoo. ``` ## Enable Apple Pay To allow customers to use the Apple Pay button to pay their eCommerce orders, go to the {guilabel}`Configuration` tab, enable {guilabel}`Allow Express Checkout`, and click {guilabel}`Enable Apple Pay`. :::{seealso} - {ref}`Express checkout and Google Pay ` - {doc}`../payment_providers` - {doc}`Use Stripe as a payment terminal in Point of Sale <../../sales/point_of_sale/payment_methods/terminals/stripe>` :::