mailFunctions.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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. typ, data = connection.fetch(num, '(RFC822)')
  46. msg = email.message_from_bytes(data[0][1])
  47. #print(type(msg))
  48. #print(msg)
  49. raw_subject = email.header.decode_header(msg['Subject'])[0]
  50. #raw_body = email.header.decode_header(msg['Body'])[0][0]
  51. '''
  52. if decode[1] == 'utf-8':
  53. subject = decode[0].decode('utf-8')
  54. else:
  55. subject = decode[0]
  56. '''
  57. #print("subject: {}".format(subject))
  58. #input()
  59. #print('Message %s\n%s\n' % (num, data[0][1]))
  60. #print('Message %s\n%s\n' % (num, data[0][1].split()))
  61. #print('%s\n' % (len(data[0][1].split())))
  62. '''
  63. j = 0
  64. for i in range(len(str(msg))):
  65. if str(msg)[i] == "\n":
  66. print(str(msg)[j:i])
  67. j = int(i)
  68. '''
  69. output_list.append(str(raw_subject))
  70. connection.close()
  71. connection.logout()
  72. return output_list
  73. def afetchMails(con):
  74. con.select("Sent")
  75. status, email_ids = con.search(None, "ALL")
  76. if status != 'OK':
  77. raise Exception("Error running imap search for spinvox messages: "
  78. "%s" % status)
  79. print(email_ids[0])
  80. fetch_ids = ','.join(str(email_ids[0]).split())
  81. status, data = con.fetch(3, '(RFC822)')
  82. if status != 'OK':
  83. raise Exception("Error running imap fetch for spinvox message: "
  84. "%s" % status)
  85. for i in range(3,4):
  86. header_msg = email.message_from_string(data[i * 3 + 0][1])
  87. subject = header_msg['Subject'],
  88. print(subject)
  89. date = header_msg['Date'],
  90. print(date)
  91. body = data[i * 3 + 1][1]
  92. print(body)
  93. connection.close()
  94. connection.logout()