PrestaShop-Odoo connector

Technical Name:
Tecnativa, Camptocamp, Akretion, AvanzOSC
  • Odoo Version

Terms and Conditions

Odoo PrestaShop Connector

This module connects Odoo and PrestaShop.

PrestaShop ( is a popular e-commerce platform written in PHP/MySQL and published under the Open Software licence v3.0.

This module allows the synchronization of the following objects from PrestaShop to Odoo:

  • Websites
  • Stores and languages
  • Carriers
  • Product categories
  • Products
  • Combinations of products
  • Partner categories
  • Customers

Once these objects are synchronised, it will allow the import of sales orders, together with the related customers.

As an extra feature, you can also export the stock quantities back to PrestaShop.

If you want to export from Odoo to PrestaShop changes made on the products, product categories or product images, you need to install connector_prestashop_catalog_manager module in this same repository.

This connector supports PrestaShop version up to 1.6.11. Maybe later versions are also supported, but they haven't been tested. It uses the webservices of PrestaShop.


It doesn't require any plug-in in PrestaShop, but requires an extra Python library in Odoo server side, called prestapyt:

You can use pip install system to install it

sudo pip install prestapyt


To configure this module, you need to set several things in both PrestaShop and Odoo:

Steps in PrestaShop

  1. Go to the control panel (usually at <url>/adminps).
  2. Login into the system.
  3. Go to Advanced Parameters > Web service
  4. Add a new entry.
  5. Generate a new API key that will be needed later.
  6. Grant all the needed access according your security policy.

Steps in Odoo

  1. Go to Connectors > PrestaShop > Backends.
  2. Create a new record for registering a PrestaShop backend. You will bind this backend to an specific company and warehouse.
  3. Define the main URL of the PrestaShop web, and the webservice key you got in PrestaShop.
  4. Define other parameters like the discount and shipping products, or if the taxes are included in the price.
  5. Click on "Synchronize Metadata" button. This will bring the basic shop information that you can find on Websites and Stores menus.
  6. Click on "Synchronize Base Data" button. This will import carriers, languages, tax groups and the rest of base data that are needed for the proper work.
  7. Go to Accounting > Configuration > Taxes > Tax Groups, and include for each of the tax definition imported from PrestaShop, the corresponding taxes in Odoo.
  8. Activate the job runner, checking the connector documentation for setting the server correctly for using it in
  9. Alternatively, if you are not able to activate it, you can enable the scheduled job called "Enqueue Jobs".
  10. Activate the scheduled jobs for importing the records you want:
  • PrestaShop - Export Stock Quantities
  • PrestaShop - Import Carriers
  • PrestaShop - Import Customers and Groups
  • PrestaShop - Import Products and Categories
  • PrestaShop - Import Sales Orders
  • PrestaShop - Import suppliers
  • PrestaShop - Payment methods


To use this module, you need to:

  1. Go to Connectors > Queue > Jobs, and check the correct enqueuing of the tasks.
  2. Check on each menu the resulting imported records (Customers, Sales Orders...)
Try me on Runbot

Known issues / Roadmap

  • Work with multiple warehouses.
  • Tests.

Bug Tracker

Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. If you spotted it first, help us smashing it by providing a detailed and welcomed feedback.




Odoo Community Association

This module is maintained by the OCA.

OCA, or the Odoo Community Association, is a nonprofit organization whose mission is to support the collaborative development of Odoo features and promote its widespread use.

To contribute to this module, please visit

This is a preview of the recently viewed products by the user.
Once the user has seen at least one product this snippet will be visible.

Recently viewed Products