mailFunctions.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. import imaplib, email, os
  2. def errorMsgExit(error_msg):
  3. print("Error: " + error_msg)
  4. def checkConnection(host, username, password, port):
  5. try:
  6. connection = imaplib.IMAP4_SSL(host, port)
  7. connection.login(username, password)
  8. connection.logout()
  9. return True
  10. except Exception as e:
  11. print(str(e))
  12. return False
  13. def connect(host, username, password, port):
  14. connect = imaplib.IMAP4_SSL(host, port)
  15. connect.login(username, password)
  16. connect.enable("UTF8=ACCEPT")
  17. return connect
  18. def listMailboxes(connection):
  19. mailboxes = connection.list()
  20. formatted_mailbox_list = []
  21. for items in mailboxes:
  22. if type(items) == list:
  23. for raw_box_string in items:
  24. box_string = str(raw_box_string)
  25. # TODO: handle cases when folder contains subfolders
  26. modified_box_string = (box_string[box_string.find('"/" ')+4:-1])
  27. # strip unneeded "'s surrounding the folder name
  28. if modified_box_string.startswith('"') and modified_box_string.endswith('"'):
  29. modified_box_string = modified_box_string[1:-1]
  30. formatted_mailbox_list.append(modified_box_string)
  31. connection.logout()
  32. return formatted_mailbox_list
  33. def fetchMails(connection, inbox):
  34. status, messages = connection.select(inbox)
  35. print("status-------\n" + status)
  36. print("messages-------\n" + str(messages))
  37. # number of top emails to fetch
  38. N = 3
  39. # total number of emails
  40. messages_int = int(messages[0])
  41. print("message_int------\n" + str(messages_int))
  42. typ, data = connection.search(None, 'ALL')
  43. output_list = []
  44. for num in data[0].split():
  45. output_dict = {}
  46. typ, data = connection.fetch(num, '(RFC822)')
  47. msg = email.message_from_bytes(data[0][1])
  48. #print(msg)
  49. raw_string = email.header.decode_header(msg['Subject'])[0]
  50. raw_from = email.header.decode_header(msg['From'])[0]
  51. raw_to = email.header.decode_header(msg['To'])[0]
  52. raw_date = email.header.decode_header(msg['Date'])[0]
  53. raw_msg = str(msg)
  54. primitive_body = raw_msg[raw_msg.find('\n\n'):].strip()
  55. #raw_body = email.header.decode_header(msg['Body'])[0][0]
  56. # set subject to an empty string when not found
  57. try:
  58. if raw_string[1] == 'utf-8':
  59. subject = raw_string[0].raw_string('utf-8')
  60. else:
  61. subject = raw_string[0]
  62. except AttributeError:
  63. subject=""
  64. #print("subject: {}".format(subject))
  65. output_dict['subject'] = subject
  66. output_dict['from'] = raw_from[0]
  67. output_dict['to'] = raw_to[0]
  68. output_dict['date'] = raw_date[0]
  69. output_dict['content'] = primitive_body
  70. output_list.append(output_dict)
  71. connection.close()
  72. connection.logout()
  73. return output_list
  74. def afetchMails(con):
  75. con.select("Sent")
  76. status, email_ids = con.search(None, "ALL")
  77. if status != 'OK':
  78. raise Exception("Error running imap search for spinvox messages: "
  79. "%s" % status)
  80. print(email_ids[0])
  81. fetch_ids = ','.join(str(email_ids[0]).split())
  82. status, data = con.fetch(3, '(RFC822)')
  83. if status != 'OK':
  84. raise Exception("Error running imap fetch for spinvox message: "
  85. "%s" % status)
  86. for i in range(3,4):
  87. header_msg = email.message_from_string(data[i * 3 + 0][1])
  88. subject = header_msg['Subject'],
  89. print(subject)
  90. date = header_msg['Date'],
  91. print(date)
  92. body = data[i * 3 + 1][1]
  93. print(body)
  94. connection.close()
  95. connection.logout()