config/emacs: add my gmail accounts or something

This commit is contained in:
Sakooooo 2024-09-24 19:59:17 +04:00
parent dead68f5da
commit e25dfc791a
Signed by: sako
GPG key ID: FE52FD65B76E4751
2 changed files with 60 additions and 5 deletions

View file

@ -25,13 +25,17 @@ def hydroxide(path):
def get_client_id(account): def get_client_id(account):
cmd = check_output("pass " + account, shell=True) cmd = check_output("pass " + account, shell=True)
return re.search(rb"client_id: (.*)", cmd, flags=0).group(1) output = re.search("client_id: (.*)", cmd.decode(), flags=0).group(1)
return output
def get_client_secret(account): def get_client_secret(account):
cmd = check_output("pass " + account, shell=True) cmd = check_output("pass " + account, shell=True)
return re.search(rb"client_secret: (.*)", cmd, flags=0).group(1) output = re.search("client_secret: (.*)", cmd.decode(), flags=0).group(1)
return output
def get_client_refresh_token(account): def get_client_refresh_token(account):

View file

@ -1,7 +1,8 @@
[general] [general]
pythonfile = ~/.offlineimap.py pythonfile = ~/.offlineimap.py
accounts = Proton, Outlook accounts = Proton, Outlook, Gmail-personal-1
socktimeout = 10 socktimeout = 60
maxsyncaccounts = 3
[Account Proton] [Account Proton]
localrepository = Proton-local localrepository = Proton-local
@ -37,7 +38,57 @@ remotehost = outlook.office365.com
remoteport = 993 remoteport = 993
auth_mechanisms = XOAUTH2 auth_mechanisms = XOAUTH2
oauth2_request_url = https://login.microsoftonline.com/common/oauth2/v2.0/token oauth2_request_url = https://login.microsoftonline.com/common/oauth2/v2.0/token
# Thunderbird client_id below
oauth2_client_id = 9e5f94bc-e8a4-4e73-b8be-63364c29d753 oauth2_client_id = 9e5f94bc-e8a4-4e73-b8be-63364c29d753
# Do not need client_secret :D
oauth2_client_secret = oauth2_client_secret =
oauth2_refresh_token_eval = get_client_refresh_token("Microsoft") oauth2_refresh_token_eval = get_client_refresh_token("Microsoft")
folderfilter = lambda folder: not folder.startswith('Calendar') and not folder.startswith('Contacts') folderfilter = lambda folder: not folder.startswith('Calendar') and not folder.startswith('Contacts')
[Account Gmail-personal-1]
localrepository = Gmail-personal-1-local
remoterepository = Gmail-personal-1-remote
[Repository Gmail-personal-1-local]
type = GmailMaildir
localfolders = ~/Mail/Gmail-Personal-1
# Google IMAP weirdness
nametrans = lambda f: '[Gmail]/' + f if f in ['Drafts', 'Starred', 'Important', 'Spam', 'Trash', 'All Mail', 'Sent Mail'] else f
[Repository Gmail-personal-1-remote]
ssl = yes
sslcacertfile = /etc/ssl/certs/ca-certificates.crt
type = Gmail
remotehost = imap.gmail.com
auth_mechanisms = XOAUTH2
remoteusereval = get_user("accounts.google.com/one")
oauth2_request_url = https://accounts.google.com/o/oauth2/token
oauth2_client_id_eval = get_client_id("email/oauth/gmail")
oauth2_client_secret_eval = get_client_secret("email/oauth/gmail")
oauth2_refresh_token_eval = get_client_refresh_token("accounts.google.com/one")
# Google IMAP weirdness
nametrans = lambda f: f.replace('[Gmail]/', '') if f.startswith('[Gmail]/') else f
[Account Gmail-personal-2]
localrepository = Gmail-personal-2-local
remoterepository = Gmail-personal-2-remote
[Repository Gmail-personal-2-local]
type = GmailMaildir
localfolders = ~/Mail/Gmail-Personal-2
# Google IMAP weirdness
nametrans = lambda f: '[Gmail]/' + f if f in ['Drafts', 'Starred', 'Important', 'Spam', 'Trash', 'All Mail', 'Sent Mail'] else f
[Repository Gmail-personal-2-remote]
ssl = yes
sslcacertfile = /etc/ssl/certs/ca-certificates.crt
type = Gmail
remotehost = imap.gmail.com
auth_mechanisms = XOAUTH2
remoteusereval = get_user("accounts.google.com/two")
oauth2_request_url = https://accounts.google.com/o/oauth2/token
oauth2_client_id_eval = get_client_id("email/oauth/gmail")
oauth2_client_secret_eval = get_client_secret("email/oauth/gmail")
oauth2_refresh_token_eval = get_client_refresh_token("accounts.google.com/two")
# Google IMAP weirdness
nametrans = lambda f: f.replace('[Gmail]/', '') if f.startswith('[Gmail]/') else f