Я использую следующий метод, который работает довольно хорошо:
1) Храните ваши пароли в отдельных зашифрованных файлах gpg. Например~/.passwd/<accountname>.gpg
2) Создайте файл расширения Python с именем по вашему выбору (например, ~/.offlineimap.py
), со следующим содержанием:
def mailpasswd(acct):
acct = os.path.basename(acct)
path = "/home/<username>/.passwd/%s.gpg" % acct
args = ["gpg", "--use-agent", "--quiet", "--batch", "-d", path]
try:
return subprocess.check_output(args).strip()
except subprocess.CalledProcessError:
return ""
3) Измените свой файл .offlineimaprc, чтобы сообщить ему о файле python и рассказать, как читать ваши пароли.
[general]
pythonfile = ~/.offlineimap.py
# ...
[Repository <reponame>]
# add this line for each remote repository
remotepasseval = mailpasswd("<accountname>")
Если у вас есть несколько учетных записей, которые проверяются одновременно (отдельные потоки), и вы используете gpg-agent, он запросит у вас парольную фразу для каждой учетной записи. Я заполняю агент, создавая file ( echo "prime" | gpg -e -r foo@bar.com > ~/.passwd/prime.gpg
), и запуская агент gpg, расшифровывая этот файл при запуске offlineimap. Для этого добавьте следующее в конец ~/.offlineimap.py
:
def prime_gpg_agent():
ret = False
i = 1
while not ret:
ret = (mailpasswd("prime") == "prime")
if i > 2:
from offlineimap.ui import getglobalui
sys.stderr.write("Error reading in passwords. Terminating.\n")
getglobalui().terminate()
i += 1
return ret
prime_gpg_agent()