In this section, we present how to connect Email accounts to MindsDB.
By connecting your email account to MindsDB, you can utilize various AI models available within MindsDB to summarize emails, detect spam, or even automate email replies.
Please note that currently you can connect Gmail and Outlook accounts using this integration.
Connection
This handler was implemented using standard Python libraries: email
, imaplib
, and smtplib
.
The Email handler is initialized with the following required parameters:
email
stores an email address used for authentication.password
stores a password used for authentication.
Additionally, the following optional parameters can be passed:
smtp_server
used to send emails. Defaults tosmtp.gmail.com
.smtp_port
used to send emails. Defaults to587
.imap_server
used to receive emails. Defaults toimap.gmail.com
.
At the moment, the handler has been tested with Gmail and Outlook accounts.
To use the handler on a Gmail account, you must create an app password following this instruction and use its value for the password
parameter.
By default, the Email handler connects to Gmail. If you want to use other email providers as Outlook, add the values for imap_server
and smtp_server
parameters.
Gmail
To connect your Gmail account to MindsDB, use the below CREATE DATABASE
statement:
CREATE DATABASE email_datasource
WITH ENGINE = 'email',
PARAMETERS = {
"email": "youremail@gmail.com",
"password": "yourpassword"
};
It creates a database that comes with the emails
table.
Outlook
To connect your Outlook account to MindsDB, use the below CREATE DATABASE
statement:
CREATE DATABASE email_datasource
WITH ENGINE = 'email',
PARAMETERS = {
"email": "youremail@gmail.com",
"password": "yourpassword",
"smtp_server": "smtp.office365.com",
"smtp_port": "587",
"imap_server": "outlook.office365.com"
};
It creates a database that comes with the emails
table.
Usage
Now you can query for emails like this:
SELECT *
FROM email_datasource.emails;
And you can apply filters like this:
SELECT id, body, subject, to_field, from_field, datetime
FROM email_datasource.emails
WHERE subject = 'MindsDB'
ORDER BY id
LIMIT 5;
Or, write emails like this:
INSERT INTO email_datasource.emails(to_field, subject, body)
VALUES ("toemail@outlook.com", "MindsDB", "Hello from MindsDB!");
Was this page helpful?