python-tools/gmail/email_count.py

69 lines
2.5 KiB
Python

import os
import imaplib
import json
from time import strftime
import influxdb_client
from influxdb_client.client.write_api import SYNCHRONOUS
from dotenv import load_dotenv, dotenv_values
load_dotenv()
# dotenv_file = os.path.realpath(os.path.dirname(__file__)) + "/.env"
# config = dotenv_values(dotenv_file)
EMAIL_ACCOUNTS = json.loads(os.environ.get("MAIL_ACCOUNTS"))
EMAIL_PASSWORDS = json.loads(os.environ.get("MAIL_PASSWORDS"))
# using zip()
# to convert lists to dictionary
accounts = dict(zip(EMAIL_ACCOUNTS, EMAIL_PASSWORDS))
# print(accounts)
# Influx DB
client = influxdb_client.InfluxDBClient(
url=os.environ.get('DB_URL'),
token=os.environ.get('DB_TOKEN'),
org=os.environ.get('DB_ORG')
)
################ IMAP SSL ##############################
for account in accounts:
with imaplib.IMAP4_SSL(host="imap.gmail.com", port=imaplib.IMAP4_SSL_PORT) as imap_ssl:
print("Connection Object : {}".format(imap_ssl))
print(f"Logging into mailbox {account}...")
try:
resp_code, response = imap_ssl.login(account, accounts[account])
except Exception as e:
print("ErrorType : {}, Error : {}".format(type(e).__name__, e))
resp_code, response = None, None
print("Response Code : {}".format(resp_code))
#print("Response : {}\n".format(response[0].decode()))
imap_ssl.select('inbox')
resp_code, messages = imap_ssl.search(None, 'UnSeen')
if resp_code == 'OK':
if len(messages[0].split()) > 0:
# print('True')
# print(messages[0].split())
unread_messages = len(messages[0].split())
else:
print('No unread emails?!')
unread_messages = 0
############### Logout of Mailbox ######################
print(f"\nLogging Out of {account}....")
imap_ssl.close()
if unread_messages is not None:
message = f"{account} has {unread_messages} messages."
date = strftime("%Y-%m-%d")
time = strftime("%H:%M:%S")
timestamp = date + "T" + time + "Z"
write_api = client.write_api(write_options=SYNCHRONOUS)
point = influxdb_client.Point("unread_emails").time(timestamp).tag("account", account)\
.field("count", unread_messages)
write_api.write(bucket="personal_data",
org=os.environ.get('DB_ORG'), record=point)
print(message)