aboutsummaryrefslogtreecommitdiffstats
path: root/climl_imap_bridge.py
blob: 8070b86f8eba55d3191205caed0cc6a31ab1a259 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#!/usr/bin/python3

import os
import subprocess
import confparser
import imapclient

import backports.ssl

def connect_to_imap(conf, password):

    cafile = conf.get('imap.tls_ca', None)

    if cafile:
        cafile = os.path.expanduser(cafile)

    ssl_context = imapclient.create_default_context(cafile=cafile)

    if conf.get('imap.tls_nocheck_hostname', 'false').lower() == 'true':
        # don't check if certificate hostname doesn't match target hostname
        ssl_context.check_hostname = False

    if conf.get('imap.tls_nocheck_ca', 'false').lower() == 'true':
        # don't check if the certificate is trusted by a certificate authority
        ssl_context.verify_mode = backports.ssl.CERT_NONE

    connection = imapclient.IMAPClient(host=conf.get('imap.server'),
            ssl=conf.get('imap.tls', 'true').lower() == 'true',
            ssl_context=ssl_context)
    if conf.get('imap.start_tls', 'false').lower() == 'true':
        connection.start_tls(ssl_context=ssl_context)
    print('connection succeed')
    connection.login(username=conf.get('imap.username'), password=password)
    print('successfuly logged')
    return connection

def main():
    confpath = os.path.expanduser('~') + '/temp/conf.cfg'
    conf = confparser.read_conf(confpath)
    print('Read conf:', conf)
    password_command = conf.get('imap.password_command', None)
    if password_command:
        password = subprocess.check_output(password_command, shell=True)
        password = password.rstrip().decode('utf8')
        print('got pasword:', password)
    connection = connect_to_imap(conf, password)



main() # dev mode for now