Send and receive emails in Odoo with an email server
Odoo Online or Odoo.sh users
Since Odoo sets up its own mail servers for the database, outgoing and incoming emails already work out-of-the-box. So for Odoo Online and Odoo.sh customers, nothing needs to be done!
Unless an external mail server is required to send large batches of mass mailing, simply use the standard online Odoo database normally since it has already been preconfigured for email.
Scope of this documentation
This document is mainly dedicated to Odoo on-premise users who don’t benefit from an out-of-the-box solution to send and receive emails in Odoo, unlike Odoo Online and Odoo.sh.
The following sections below contain information on how to integrate an external email server with Odoo.
Warning
If no one in the company is used to managing email servers, Odoo Online and Odoo.sh are strongly recommended. Those Odoo hosting types’ email systems work instantly and are monitored by professionals. Nevertheless, a company can use their own email server if they want to manage the email server’s reputation themselves.
Note
Office 365 email servers don’t easily allow the sending of external emails from hosts like Odoo. Refer to Microsoft’s documentation to make it work.
Manage outbound messages
As a system admin, go to External Email Servers option. Then, click Save. Next, click Outgoing Email Servers and click Create to create a new outgoing mail server record in Odoo. Reference the SMTP data of the external email server. Once all the information has been filled out, click Test Connection.
in Odoo, and enable theHere is a typical configuration for a G Suite server.
Then, go back to Alias Domain name. Finally, click Save to finish setting up the email server.
and set the email domain name in theNote
If an [AUTHENTICATION FAILED] Invalid credentials (Failure)
warning appears when Test Connection is clicked for a Gmail address, activate the Less secure app access option. A direct link can be accessed here.
In addition to that, enable the IMAP setting on the Gmail account.
Use an Office 365 server
An Office 365 server can be used if the database’s hosting type is Odoo on-premise. Office 365 SMTP relays are not compatible with Odoo Online or Odoo.sh unless Odoo is configured to force the outgoing “From” address.
Please refer to Microsoft’s documentation to configure an SMTP relay for the Odoo database’s IP address.
Use a G Suite server
A G Suite server can be used for any Odoo hosting type. To do so, set up the SMTP relay service. The configuration steps are explained in Google documentation.
Restriction
Please note that port 25 is blocked for security reasons on Odoo Online and Odoo.sh platforms. Try using ports 465, 587, or 2525 instead.
Use a default “From” email address
Sometimes, an email’s “From” (outgoing) address can belong to a different domain, and that can be a problem.
For example, if a customer with the email address mary@customer.example.com responds to a message, Odoo will try to redistribute that same email to the other subscribers in the thread. However, if the domain customer.example.com forbids that kind of usage for security, the email that Odoo is trying to redistribute would get rejected by some recipients’ email servers.
To avoid that problem, make sure all emails use a “From” address from the same authorized domain.
If the MTA supports SRS (Sender Rewriting Scheme), SRS can be enabled to handle these situations. However, that is more complex and requires more technical knowledge that is not meant to be covered by this documentation.
Instead, Odoo can be configured to do something similar by itself:
Set the Alias Domain name in the .
Turn on developer mode.
Go to
.Add one system parameter from the following list:
To use the same “From” address for all outgoing messages, use the key
mail.force.smtp.from
and set that address as value (such asoutgoing@mycompany.example.com
).To keep the original “From” address for emails that use the same domain, but change it for emails that use a different domain, use the key
mail.dynamic.smtp.from
and set the value as the email address that should be used in those cases (such asoutgoing@mycompany.example.com
).
Manage inbound messages
Odoo relies on generic email aliases to fetch incoming messages.
Reply messages of messages sent from Odoo are routed to their original discussion thread (and to the inbox of all its followers) by the catchall alias (catchall@).
Bounced messages are routed to bounce@ in order to track them in Odoo. This is especially used in Odoo Email Marketing to opt-out invalid recipients.
Original messages: Several business objects have their own alias to create new records in Odoo from incoming emails:
Sales Channel (to create Leads or Opportunities in Odoo CRM),
Support Channel (to create Tickets in Odoo Helpdesk),
Projects (to create new Tasks in Odoo Project),
Job Positions (to create Applicants in Odoo Recruitment),
etc.
Depending on the mail server, there might be several methods to fetch emails. The easiest and most recommended method is to manage one email address per Odoo alias in the mail server.
Create the corresponding email addresses in the mail server (catchall@, bounce@, sales@, etc.).
Set the Alias Domain name in .
If the database’s hosting type is Odoo on-premise, create an Incoming Mail Server in Odoo for each alias. This can be done from the General Settings as well. Fill out the form according to the email provider’s settings. Leave the Actions to Perform on Incoming Mails field blank. Once all the information has been filled out, click on TEST & CONFIRM.
If the database’s hosting type is Odoo Online or Odoo.sh, redirecting incoming messages to Odoo’s domain name instead of the external email server is recommended. That way, incoming messages can be received without delay. Odoo Online only fetches incoming messages of external servers once every hour. Redirections for all email addresses should be set to Odoo’s domain name in the email server (e.g. catchall@mydomain.ext to catchall@mycompany.odoo.com).
All the aliases are customizable in Odoo. Object aliases can be edited from their respective configuration view.
Tip
To edit catchall and bounce aliases, first activate the developer mode. Then, go to to customize the aliases (mail.catchall.alias & mail.bounce.alias).
By default, inbound messages are fetched every 5 minutes in Odoo on-premise.
Note
This value can be changed in developer mode. Go to and look for Mail: Fetchmail Service.
Set up different dedicated servers for transactional and mass mails
In Odoo a separate Mail Transfer Agent (MTA) server can be used for transactional emails and mass mailings. Example: Use Postmark or SendinBlue for transactional emails, and Amazon SES, Mailgun or Sendgrid for mass mailings.
Tip
A default outgoing email server is already configured. Do not create an alternative one unless a specific external outgoing email server is needed for technical reasons.
To do this, first activate the developer mode, and then go to email servers. There, create two email MTA server settings; one for the transactional emails and one for the mass mailing server. Make sure to give priority to the transactional server over the mass mailing server by providing a lower priority number for the transactional MTA server.
Now, go to Dedicated Server. With these settings, Odoo uses the server with the lower priority for transactional emails, and the server here selected for mass mails. Note that in this case, the domain’s Sender Policy Framework (SPF) records must be set to include both transactional and mass mail servers.
and enable