Oldukça iyi çalışan aşağıdaki yöntemi kullanıyorum:
1) Parolalarınızı ayrı gpg şifreli dosyalarda saklayın. Örneğin~/.passwd/<accountname>.gpg
2) ~/.offlineimap.py
Aşağıdaki içeriğe sahip , seçtiğiniz bir adla (örn. ) Bir python uzantı dosyası oluşturun :
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 dosyanızı python dosyası hakkında ve parolalarınızı nasıl okuyacağınızı anlatacak şekilde değiştirin
[general]
pythonfile = ~/.offlineimap.py
# ...
[Repository <reponame>]
# add this line for each remote repository
remotepasseval = mailpasswd("<accountname>")
Aynı anda kontrol edilen birden fazla hesabınız varsa (ayrı iş parçacıkları) ve gpg-agent kullanıyorsanız, her hesap için parola ister. Bir dosya ( echo "prime" | gpg -e -r foo@bar.com > ~/.passwd/prime.gpg
) oluşturarak ve offlineimap başlatıldığında bu dosyanın şifresini çözerek gpg aracısını hazırlayarak aracıyı hazırlatırım. Bunu yapmak için aşağıdakilerin sonuna ekleyin ~/.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()