使用isync或offlineimap离线同步和读取Gmail

时间:2015-12-13 00:15:55

标签: ssl-certificate gmail-imap mu

我的目标是从Gmail帐户同步我的电子邮件并将其编入索引,以便在Emacs中进行搜索和阅读。后者尚不相关,因为我无法将电子邮件同步到我的笔记本电脑。

我正在运营小牛队,所以在Mac终端工作。

我跟着SO accepted answer and the answer in the same thread尝试使用 offlineimap ,以及this (more promising) tutorial on using isync中的第二种方法(以及 mbsync )。两种方式最终都使用 mu 和Emacs的界面: mu4e

未正确读取/解释证书。我不知道为什么我不理解错误信息。这是 offlineimap

中的一个
> OfflineIMAP 6.5.7
  Licensed under the GNU GPL v2 or any later version (with an OpenSSL exception)
Account sync Gmail:
 *** Processing account Gmail
 Establishing connection to imap.gmail.com:993
 PLAIN authentication failed: [ALERT] Please log in via your web browser: https://support.google.com/mail/accounts/answer/78754 (Failure)
 LOGIN authentication failed: [ALERT] Please log in via your web browser: https://support.google.com/mail/accounts/answer/78754 (Failure)
 ERROR: All authentication types failed:
    PLAIN: [ALERT] Please log in via your web browser: https://support.google.com/mail/accounts/answer/78754 (Failure)
    LOGIN: [ALERT] Please log in via your web browser: https://support.google.com/mail/accounts/answer/78754 (Failure)
 *** Finished account 'Gmail' in 0:01
ERROR: Exceptions occurred during the run!
ERROR: All authentication types failed:
    PLAIN: [ALERT] Please log in via your web browser: https://support.google.com/mail/accounts/answer/78754 (Failure)
    LOGIN: [ALERT] Please log in via your web browser: https://support.google.com/mail/accounts/answer/78754 (Failure)
> 
> Traceback:   File
> "/usr/local/Cellar/offline-imap/6.5.7/libexec/offlineimap/accounts.py",
> line 263, in syncrunner
>     self.__sync()   File "/usr/local/Cellar/offline-imap/6.5.7/libexec/offlineimap/accounts.py",
> line 326, in __sync
>     remoterepos.getfolders()   File "/usr/local/Cellar/offline-imap/6.5.7/libexec/offlineimap/repository/IMAP.py",
> line 351, in getfolders
>     imapobj = self.imapserver.acquireconnection()   File "/usr/local/Cellar/offline-imap/6.5.7/libexec/offlineimap/imapserver.py",
> line 451, in acquireconnection
>     self.__authn_helper(imapobj)   File "/usr/local/Cellar/offline-imap/6.5.7/libexec/offlineimap/imapserver.py",
> line 366, in __authn_helper
>     "failed:\n\t%s"% msg, OfflineImapError.ERROR.REPO)

以下是 mbsync

中的一个
> C: 0/3  B: 0/2  M: +0/0 *0/0 #0/0  S: +0/0 *0/0 #0/0
Error while loading certificate file '/usr/local/etc/openssl/certs/Equifax.crt': error:00000000:lib(0):func(0):reason(0)
C: 3/3  B: 0/2  M: +0/0 *0/0 #0/0  S: +0/0 *0/0 #0/0

我已经使用Homebrew安装了所有内容,并按照教程使用文件夹。问题来自证书,但我不知道问题可能是什么。我在Gmail中设置了允许IMAP的设置,并允许连接不太安全的应用。

我如何以不同方式处理证书?

1 个答案:

答案 0 :(得分:3)

对于offlineimap错误,Google抱怨您没有使用Oauth2。我在这里解释后遇到了同样的offlineimap问题:https://github.com/OfflineIMAP/offlineimap/issues/228

您需要将.offlineimaprc配置为使用Oauth2,而不是指定用户名/密码。以下是有关如何生成令牌的模板和说明: https://github.com/OfflineIMAP/offlineimap/blob/master/offlineimap.conf#L764

以下是重要设置:

auth_mechanisms = GSSAPI, CRAM-MD5, XOAUTH2, PLAIN, LOGIN
oauth2_client_secret = ...
oauth2_client_id = ...
oauth2_refresh_token = ...