DropBox Odoo Integration v.11

The tool to automatically synchronize Odoo attachments with DropBox files in both ways

394€

The price already includes all necessary dependencies = 149€ (own price) + 245€ (Cloud Storage Solutions).
Current version: 11.0.2.0.4

Enterprise
Community
Odoo.sh
Odoo document system is clear and comfortable to use. However, it is not designed to work with files as DropBox does. To process attachments users need to download a file, to change it, and to upload back. Documents are not synced locally and Odoo doesn't have powerful previewers. DropBox doesn't have such disadvantages. This is the tool to integrate its features into your Odoo business work flow. The app automatically stores all Odoo attachments in DropBox and provides an instant access to them via web links. In such a way users work with files comfortably in the cloud storage, while the results are fully available in Odoo.

Synchronization is bilateral. All Odoo attachments are put in DropBox regularly. DropBox files create attachments in Odoo in case they are placed in a correct folder. Look at the sections From Odoo to DropBox and From DropBox to Odoo

Integration is automatic in both ways. Based on scheduled jobs, Odoo send attachments to DropBox and retrieve files from there

Any Odoo document might be synced: customers, opportunities, sale or purchase orders, tasks or issues, employees or users, etc. You decide by your own which records should be in DropBox, and which should be left in Odoo

Synchronization works for any DropBox tariff, including Personal DropBox (Basic, Plus, Family) and business DropBox (Professional, Standard, Advanced)

All synced files are easily accessible though clicking on an attachment. You might also open a whole document folder by clicking on 'Open folder' on the attachment widget. This feature migth be optionally turned off: look at the section DropBox URLs

All sync activities might be logged. Control over files and folders creations, moves, name changes and removals. Just turn on the option 'Log sync activities' and access history through the button 'Sync logs'

New For each document of this type you may create a default directories' structure. When this folder is firstly synced, Odoo would generate default folders. For example, for all employees you may have pre-defined folders 'Scans', 'Scans/Official', 'Photos', etc.

The tool is compatible with Odoo reporting and mailing apps. If such an app faces a synced file, it retrieves a real content from DropBox. In particular, the reports 'always reload' feature and messages & mass mailing attachments work properly

Integration is based on a single user endpoint. It means that a single user login/password of DropBox is used. Afterwards for integrations Odoo would use that credentials disregarding an actual Odoo user

From Odoo to DropBox

Direct synchronization has 2 prime aims:
  • Prepare and keep updated folders' structure in DropBox
  • Upload new attachments to a correct folder
Folders

Odoo creates a convenient directory structure in DropBox: Odoo / Document type name / Document name / Files, where:

  • Odoo is a central directory for Odoo Sync in your cloud storage.
  • Document type is a synced Odoo model, for example, 'Sale orders', 'Opportunities', 'Customers'
    • You select document types by yourself. It might be any document type
    • Moreover, you might have a few folders for a single document type. Use Odoo domains to have not global 'Partners, but 'Customers' and 'Suppliers', not just 'Sale orders' but 'Commercial offers', 'To deliver', and 'Done orders'
    • With each sync Odoo would try to update document types' folders. Add a new document type at any moment. It will appear in DropBox with a next sync
    • You are welcome to introduce or change document types folder names at any moment in Odoo. Take into account: renaming in DropBox will be recovered to Odoo names
    • If you remove a model from integration, it will not be deleted from DropBox to keep already synced files safe. However, new documents of this type would not be synced
    • In case you removed a directory in DropBox, but it is still configured in Odoo, with a next sync a folder structure is going to be recovered (not files, surely).
  • Document is an exact object to sync. For instance, 'Agrolait' or 'SO019'
    • Documents are synced in case they relate to a synced document type and satisfy its filters. For example, you are not obliged to sync all partners, you may integrate only 'Customers' and 'Vendors' or only 'Companies', not 'Contacts'
    • Odoo would generate a folder in DropBox for each suitable document even for documents without attachments. It is needed for a backward sync to easily add new files
    • DropBox folder name equals a real document name. It relies upon Odoo name_get method. Thus, Odoo 'Michael Fletcher' (a contact of 'Agrolait') would be DropBox 'Agrolait, Michael Fletcher'
    • If an exact document changes its document type (e.g. a quotation is now confirmed), Odoo will automatically relocate its related folder to a proper parent directory (in the example: from 'Commercial offers' to 'To deliver')
    • In case a document relates to a few types (for instance, you have 'Vendors' and 'Customers', while Agrolait is both), this document folder would be put into the most prioritized document type. A document type priority is higher as closer to the top in Odoo interfaces it is
    • If an Odoo document is removed, the next sync will remove a corresponding DropBox directory
    • In case you remove a directory in DropBox, but it still exists in Odoo, DropBox folder structure would be recovered (while files would be unlinked in both Odoo and DropBox)
    • Folders renaming in DropBox will be replaced with Odoo names, Odoo document names are more important
  • Files are real files taken from Odoo attachments

The resulted path would be, for example, 'Odoo / Quotations / SO019 / commercial offer.png'.

The only exclusion of the rule are stand alone attachments which do not relate to any Odoo documents (their document type is 'ir.attachment'). Such attachments' path is 'Odoo / Stand Alone Attachments / image.png'.

The direct sync might take quite a long, since a lot of folders should be created. It is not recommended to make sync too frequent: once an hour or two hours is fine.

Files

With each direct sync, Odoo tries to find not yet synced attachments. If such attachments suit any document type to sync, a file will be uploaded to DropBox to a proper folder. In Odoo such attachments will become of 'url' type (look also at the section DropBox URLs). It means that a file is not any more kept in Odoo server space, but now it is in DropBox. Until sync is done, Odoo attachment remains binary and stores an actual file. Such approach helps Odoo to work faster.

If you unlinked an attachment from Odoo, it would be deleted in DropBox as well.

Take into account that file names should be managed in DropBox: each backward sync would recover DropBox names, Odoo is here less important.

From DropBox to Odoo

Backward integration aims to sync new files from DropBox to Odoo:
  • If a new file is added to a proper document folder (e.g. to 'Odoo / Customers / Agrolait'), the same attachment will be added to Odoo document (in the example – to 'Agrolait')
  • In document folders you can put not only files but also child folders. In that case a link for this folder (not its content) is kept in attachments
  • In case you rename a file in DropBox, it will be renamed in Odoo as well
  • Files' removal from DropBox leads to related Odoo attachments' removal
  • If you move a file to another document folder, in Odoo a related attachment would be re-attached to this new document. Take into account: if you move a file for a not document folder, this Odoo attachment will be deleted as it has been removed from DropBox
  • If you deleted a document type or document folder, their child files are deleted as well. Thus, Odoo would remove related attachments. The folders, however, will be recovered with a next direct sync. Folders' move to another directory is also considered as a removal. Avoid such situations by following the simple rule: folders are managed mostly by Odoo, files – mostly by DropBox.

Backward DropBox might take quite much time, since each folder should be checked (the more folders, the more time the backward sync requires). It is recommended to make frequency oftener than once an hour or two hours.

DropBox URLs

DropBox has a specific way to generate links for existing files and folders. In particular, there are no concepts of internal or private URLs. Instead, each DropBox item might get so-called shared URLs. Such shared links are either public or team-only. Moreover, the latter feature is available only for DropBox business account.

This tool relies upon share links' mechanics. It means, that each attachment link is either public (all personal DropBox accounts) or team-only (all business DropBox accounts).

Sometimes it is considered to be not fully safe. Although website URLs will be hardly known by external users, there is a slight chance that they become available as a result of some user actions. Besides, sharing links generation is not super fast and might make a sync process slower. That is why the feature to switch off sharing urls is introduced.

If checked, all DropBox urls in Odoo will be of type https://www.dropbox.com/home/Odoo/[PATH]. Such links will not work in quite a many cases. Thus, if you need to open DropBox files / folders from Odoo, do not switch off the feature 'No links to DropBox from Odoo'.

Misc peculiarities

  • Try to avoid the following symbols in folders' and files' names: *, ?, ", ', :, <, >, |, +, %, !, @, \, /,. Direct sync will replace such symbols with '-'. It is done to avoid conflicts with file systems.

Preliminary steps

The tool depends on external libraries 'dropbox'. Install this library for your Odoo server through the commands: pip install urllib3,pip install dropbox

Configuration and Login

  1. Follow the url https://www.dropbox.com/developers/apps/create
  2. Choose an API as 'Scoped access'
  3. Choose the type of access as 'Full Dropbox'
  4. Select any suitable name for the app and push the button 'Create app'
  5. Add the redirect URI as YOURODOOSITENAME]/dropbox_token (e.g. https://faotools.com/dropbox_token). A valid SSL certificate (https) is required
  6. Grant permissions to the app: 'Account Info (Read)', 'Files and folders Metadata (Write)', 'Files Content (Write)', 'Collaboration (Write)'. For team DropBox assign also 'Team Data Members', 'Members (Read)'. Make sure no other permissions are assigned.
  7. Submit App
  8. Go to Odoo general settings - DropBox
  9. Copy App Key, App secret, and redirect URI to the Odoo configuration page
  10. For team DropBoxes only
    1. Check the box 'DropBox Team'
    2. Set an email of DropBox user. Inside this user folder all Odoo related items would be created and only after that they are shared to all other users. Under this user all files and folders are created, changed, moved, and deleted
  11. Choose a suitable name for the root Odoo folder, e.g. 'Odoo' or 'ERP'
  12. Press Save
  13. Press 'Login and Confirm'

Create a DropBox app

DropBox API app to connect to Odoo

Set up DropBox App: redirection URL

Dropbox app settings

DropBox permissions for personal accounts

Odoo Dropbox app personal permissions

DropBox permissions for business accounts

Odoo Dropbox app business permissions

Set up Odoo for DropBox integration

Odoo settings for DropBox

Odoo server configuration and cron job configuration

To make sure the synchronization works correctly apply proper timeouts to the Odoo configuration file: LIMIT_TIME_CPU, LIMIT_TIME_REAL should be more than 900 seconds.

For Odoo.sh this should not be done, since timeouts are predefined and are not configurable.

Then, timeout should be entered to your Odoo. To that goal find the section 'Settings' on the app configuration page and copy the number there.

Afterwards, it is needed to make the cron jobs suit the applied timeouts. In the debug mode go to the Settings > Technical > Automation > Scheduled Jobs:

  • Set up the job 'Synchronize attachments with cloud' as (a) frequency - 2*timeout; (b) the next execution as the next hour +timeout. For example, for 900seconds timeout: frequency - as 30minutes; the next execution - at 08:15
  • Set up the job 'Synchronize attachments from cloud' as (a) frequency - 2*timeout; (b) the next execution as the next hour + timeout*2. For example, for 900seconds timeout: frequency - as 30minutes; the next execution- at 08:30.

Reconnection

Reconnection might be required for the case a refresh token is expired and when you migrate the app from previous versions. In such a case:

  1. Press the button 'Reconnect'
  2. Press the button 'Login and confirm'

Bug reporting

In case you have faced any bugs or inconsistent behavior, do not hesitate to contact us. We guarantee to provide fixes within 60 days after the purchase, while even after this period we are strongly interested to improve our tools.

No phone number or credit card is required to contact us: only a short email sign up which does not take more than 30 seconds.

Please include in your request as many details as possible: screenshots, Odoo server logs, a full description of how to reproduce your problem, and so on. Usually, it takes a few business days to prepare a working plan for an issue (if a bug is confirmed) or provide you with guidelines on what should be done (otherwise).

Public features requests and module ideas (free development)

We are strongly motivated to improve our tools and would be grateful for any sort of feedback. In case your requirements are of public use and might be efficiently implemented, the team would include those in our to-do list.

Such a to-do list is processed on a regular basis and does not assume extra fees. Although we cannot promise deadlines and final design, it might be a good way to get desired features without investments and risks.

No phone number or credit card is required to contact us: only a short email sign up which does not take more than 30 seconds.

You may also like the tools
KnowSystem: Knowledge Base System

The tool to build deep and structured knowledge base for internal and external use. Knowledge System. KMS

298€
Universal Appointments and Time Reservations

The tool for time-based service management from booking appointments to sales and reviews

398€ 358€
Password Manager

The tool to safely keep passwords for shared use

198€ 178€
KPI Balanced Scorecard

The tool to set up KPI targets and control their fulfillment by periods. KPI dashboards. Dashboard designer. KPI charts

198€
Cloud Storage Solutions

The technical core to synchronize your cloud storage solution with Odoo

245€
OneDrive / SharePoint Odoo Integration

The tool to automatically synchronize Odoo attachments with OneDrive files in both ways

394€
Google Drive Odoo Integration

The tool to automatically synchronize Odoo attachments with Google Drive files in both ways

394€
OwnCloud / NextCloud Odoo Integration

The tool to automatically synchronize Odoo attachments with OwnCloud / NextCloud files in both ways

394€