2007-07-05 13:05:06 +02:00
|
|
|
# Copyright (C) 2007 John Goerzen
|
|
|
|
# <jgoerzen@complete.org>
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
|
|
|
import offlineimap.version
|
2007-07-05 15:21:33 +02:00
|
|
|
import urllib, sys, re, time, traceback, threading, thread
|
|
|
|
from UIBase import UIBase
|
2007-07-05 13:05:06 +02:00
|
|
|
from threading import *
|
|
|
|
|
2007-07-05 15:21:33 +02:00
|
|
|
protocol = '6.0.0'
|
|
|
|
|
|
|
|
class MachineUI(UIBase):
|
2007-07-05 13:05:06 +02:00
|
|
|
def __init__(s, config, verbose = 0):
|
|
|
|
UIBase.__init__(s, config, verbose)
|
2007-07-05 15:22:57 +02:00
|
|
|
s.safechars=" ;,./-_=+()[]"
|
2007-07-05 13:05:06 +02:00
|
|
|
s.iswaiting = 0
|
|
|
|
s.outputlock = Lock()
|
2007-07-05 15:21:33 +02:00
|
|
|
s._printData('__init__', protocol)
|
2007-07-05 13:05:06 +02:00
|
|
|
|
|
|
|
def isusable(s):
|
|
|
|
return True
|
|
|
|
|
|
|
|
def _printData(s, command, data, dolock = True):
|
2007-07-05 15:21:33 +02:00
|
|
|
s._printDataOut('msg', command, data, dolock)
|
2007-07-05 13:05:06 +02:00
|
|
|
|
|
|
|
def _printWarn(s, command, data, dolock = True):
|
2007-07-05 15:21:33 +02:00
|
|
|
s._printDataOut('warn', command, data, dolock)
|
2007-07-05 13:05:06 +02:00
|
|
|
|
|
|
|
def _printDataOut(s, datatype, command, data, dolock = True):
|
|
|
|
if dolock:
|
|
|
|
s.outputlock.acquire()
|
|
|
|
try:
|
2007-07-05 15:21:33 +02:00
|
|
|
print "%s:%s:%s:%s" % \
|
2007-07-05 13:05:06 +02:00
|
|
|
(datatype,
|
2007-07-05 15:21:33 +02:00
|
|
|
urllib.quote(command, s.safechars),
|
|
|
|
urllib.quote(currentThread().getName(), s.safechars),
|
|
|
|
urllib.quote(data, s.safechars))
|
2007-07-05 13:05:06 +02:00
|
|
|
sys.stdout.flush()
|
|
|
|
finally:
|
|
|
|
if dolock:
|
|
|
|
s.outputlock.release()
|
|
|
|
|
2007-07-05 15:21:33 +02:00
|
|
|
def _display(s, msg):
|
|
|
|
s._printData('_display', msg)
|
|
|
|
|
|
|
|
def warn(s, msg, minor):
|
|
|
|
s._printData('warn', '%s\n%d' % (msg, int(minor)))
|
|
|
|
|
2007-07-05 15:49:54 +02:00
|
|
|
def registerthread(s, threadname, accountname):
|
|
|
|
UIBase.registerthread(s, threadname, accountname)
|
|
|
|
s._printData('registerthread', accountname)
|
2007-07-05 15:21:33 +02:00
|
|
|
|
2007-07-05 15:49:54 +02:00
|
|
|
def unregisterthread(s, threadname):
|
|
|
|
UIBase.unregisterthread(s, threadname)
|
|
|
|
s._printData('unregisterthread', threadname)
|
2007-07-05 15:21:33 +02:00
|
|
|
|
|
|
|
def debugging(s, debugtype):
|
|
|
|
s._printData('debugging', debugtype)
|
|
|
|
|
2007-07-05 15:49:54 +02:00
|
|
|
def print_debug(s, debugtype, msg):
|
|
|
|
s._printData('print_debug', "%s\n%s" % (debugtype, msg))
|
|
|
|
|
2007-07-05 13:05:06 +02:00
|
|
|
def acct(s, accountname):
|
|
|
|
s._printData('acct', accountname)
|
|
|
|
|
2007-07-05 15:21:33 +02:00
|
|
|
def acctdone(s, accountname):
|
|
|
|
s._printData('acctdone', accountname)
|
|
|
|
|
|
|
|
def validityproblem(s, folder):
|
|
|
|
s._printData('validityproblem', "%s\n%s\n%s\n%s" % \
|
|
|
|
(folder.getname(), folder.getrepository().getname(),
|
|
|
|
folder.getsaveduidvalidity(), folder.getuidvalidity()))
|
|
|
|
|
2007-07-05 13:05:06 +02:00
|
|
|
def connecting(s, hostname, port):
|
|
|
|
s._printData('connecting', "%s\n%s" % (hostname, str(port)))
|
|
|
|
|
|
|
|
def syncfolders(s, srcrepos, destrepos):
|
|
|
|
s._printData('syncfolders', "%s\n%s" % (s.getnicename(srcrepos),
|
|
|
|
s.getnicename(destrepos)))
|
|
|
|
|
|
|
|
def syncingfolder(s, srcrepos, srcfolder, destrepos, destfolder):
|
|
|
|
s._printData('syncingfolder', "%s\n%s\n%s\n%s\n" % \
|
|
|
|
(s.getnicename(srcrepos), srcfolder.getname(),
|
|
|
|
s.getnicename(destrepos), destfolder.getname()))
|
|
|
|
|
|
|
|
def loadmessagelist(s, repos, folder):
|
|
|
|
s._printData('loadmessagelist', "%s\n%s" % (s.getnicename(repos),
|
|
|
|
folder.getvisiblename()))
|
|
|
|
|
2007-07-05 15:21:33 +02:00
|
|
|
def messagelistloaded(s, repos, folder, count):
|
|
|
|
s._printData('messagelistloaded', "%s\n%s\n%d" % \
|
|
|
|
(s.getnicename(repos), folder.getname(), count))
|
|
|
|
|
2007-07-05 13:05:06 +02:00
|
|
|
def syncingmessages(s, sr, sf, dr, df):
|
|
|
|
s._printData('syncingmessages', "%s\n%s\n%s\n%s\n" % \
|
|
|
|
(s.getnicename(sr), sf.getname(), s.getnicename(dr),
|
|
|
|
df.getname()))
|
|
|
|
|
|
|
|
def copyingmessage(s, uid, src, destlist):
|
|
|
|
ds = s.folderlist(destlist)
|
|
|
|
s._printData('copyingmessage', "%d\n%s\n%s\n%s" % \
|
2007-07-05 15:21:33 +02:00
|
|
|
(uid, s.getnicename(src), src.getname(), ds))
|
2007-07-05 13:05:06 +02:00
|
|
|
|
|
|
|
def folderlist(s, list):
|
|
|
|
return ("\f".join(["%s\t%s" % (s.getnicename(x), x.getname()) for x in list]))
|
|
|
|
|
|
|
|
def deletingmessage(s, uid, destlist):
|
|
|
|
s.deletingmessages(s, [uid], destlist)
|
|
|
|
|
|
|
|
def uidlist(s, list):
|
|
|
|
return ("\f".join([str(u) for u in list]))
|
|
|
|
|
|
|
|
def deletingmessages(s, uidlist, destlist):
|
|
|
|
ds = s.folderlist(destlist)
|
|
|
|
s._printData('deletingmessages', "%s\n%s" % (s.uidlist(uidlist), ds))
|
|
|
|
|
|
|
|
def addingflags(s, uidlist, flags, destlist):
|
|
|
|
ds = s.folderlist(destlist)
|
|
|
|
s._printData("addingflags", "%s\n%s\n%s" % (s.uidlist(uidlist),
|
|
|
|
"\f".join(flags),
|
|
|
|
ds))
|
|
|
|
|
|
|
|
def deletingflags(s, uidlist, flags, destlist):
|
|
|
|
ds = s.folderlist(destlist)
|
|
|
|
s._printData('deletingflags', "%s\n%s\n%s" % (s.uidlist(uidlist),
|
|
|
|
"\f".join(flags),
|
|
|
|
ds))
|
|
|
|
|
|
|
|
def threadException(s, thread):
|
2007-07-05 15:22:57 +02:00
|
|
|
print s.getThreadExceptionString(thread)
|
2007-07-05 13:05:06 +02:00
|
|
|
s._printData('threadException', "%s\n%s" % \
|
|
|
|
(thread.getName(), s.getThreadExceptionString(thread)))
|
|
|
|
s.delThreadDebugLog(thread)
|
|
|
|
s.terminate(100)
|
|
|
|
|
2007-07-05 15:21:33 +02:00
|
|
|
def terminate(s, exitstatus = 0, errortitle = '', errormsg = ''):
|
|
|
|
s._printData('terminate', "%d\n%s\n%s" % (exitstatus, errortitle, errormsg))
|
|
|
|
sys.exit(exitstatus)
|
|
|
|
|
2007-07-05 13:05:06 +02:00
|
|
|
def mainException(s):
|
|
|
|
s._printData('mainException', s.getMainExceptionString())
|
|
|
|
|
|
|
|
def threadExited(s, thread):
|
|
|
|
s._printData('threadExited', thread.getName())
|
|
|
|
UIBase.threadExited(s, thread)
|
|
|
|
|
|
|
|
def sleeping(s, sleepsecs, remainingsecs):
|
|
|
|
s._printData('sleeping', "%d\n%d" % (sleepsecs, remainingsecs))
|
|
|
|
if sleepsecs > 0:
|
|
|
|
time.sleep(sleepsecs)
|
|
|
|
return 0
|
|
|
|
|
|
|
|
|
2007-07-05 15:49:54 +02:00
|
|
|
def getpass(s, accountname, errmsg = None):
|
2007-07-05 13:05:06 +02:00
|
|
|
s.outputlock.acquire()
|
|
|
|
try:
|
|
|
|
if errmsg:
|
|
|
|
s._printData('getpasserror', "%s\n%s" % (accountname, errmsg),
|
|
|
|
False)
|
|
|
|
s._printData('getpass', accountname, False)
|
|
|
|
return (sys.stdin.readline()[:-1])
|
|
|
|
finally:
|
|
|
|
s.outputlock.release()
|
|
|
|
|
2007-07-05 15:21:33 +02:00
|
|
|
def init_banner(s):
|
|
|
|
s._printData('initbanner', offlineimap.version.banner)
|
2007-07-05 13:05:06 +02:00
|
|
|
|
2007-07-05 15:49:54 +02:00
|
|
|
def msgtoreadonly(s, destfoldernice, destfoldername, uid):
|
|
|
|
s._printData('msgtoreadonly', "%s\n%s\n%d" % (destfoldernice, destfoldername, uid))
|
|
|
|
|
|
|
|
def flagstoreadonly(s, destfoldernice, destfoldername, uidlist):
|
|
|
|
s._printData('flagstoreadonly', "%s\n%s\n%s" % (destfoldernice, destfoldername, "\f".join(
|
|
|
|
|
|
|
|
|