diff options
author | Folker Bernitt <fbernitt@thoughtworks.com> | 2016-01-25 10:27:39 +0100 |
---|---|---|
committer | Folker Bernitt <fbernitt@thoughtworks.com> | 2016-01-25 10:27:39 +0100 |
commit | 10117a698e5ffb1f74017129824b4c1b6a4ec73e (patch) | |
tree | 2a609fd980a6d8bd1319c5d7e188708af6bf17f6 | |
parent | fd7f55a40ba1c5b32dd22e7856c37484f81d8789 (diff) |
Add integrity-check maintenance command
-rw-r--r-- | service/pixelated/config/arguments.py | 1 | ||||
-rw-r--r-- | service/pixelated/config/leap.py | 2 | ||||
-rw-r--r-- | service/pixelated/maintenance.py | 45 |
3 files changed, 46 insertions, 2 deletions
diff --git a/service/pixelated/config/arguments.py b/service/pixelated/config/arguments.py index d8a18c16..6a609b73 100644 --- a/service/pixelated/config/arguments.py +++ b/service/pixelated/config/arguments.py @@ -52,6 +52,7 @@ def parse_maintenance_args(): subparsers.add_parser('dump-soledad', help='dump the soledad database') subparsers.add_parser('sync', help='sync the soledad database') subparsers.add_parser('repair', help='repair database if possible') + subparsers.add_parser('integrity-check', help='run integrity check on database') return parser.parse_args() diff --git a/service/pixelated/config/leap.py b/service/pixelated/config/leap.py index 30964f28..dd475629 100644 --- a/service/pixelated/config/leap.py +++ b/service/pixelated/config/leap.py @@ -65,7 +65,7 @@ def initialize_leap_single_user(leap_provider_cert, config, provider = initialize_leap_provider(provider, leap_provider_cert, leap_provider_cert_fingerprint, leap_home) - leap_session = yield authenticate_user(provider, username, password) + leap_session = yield authenticate_user(provider, username, password, initial_sync=initial_sync) defer.returnValue(leap_session) diff --git a/service/pixelated/maintenance.py b/service/pixelated/maintenance.py index 5e1edac3..693e4075 100644 --- a/service/pixelated/maintenance.py +++ b/service/pixelated/maintenance.py @@ -17,6 +17,8 @@ from os.path import isfile from mailbox import Maildir, mbox, MaildirMessage import random + +from leap.mail.adaptors.soledad import MetaMsgDocWrapper from twisted.internet import reactor, defer from twisted.internet.threads import deferToThread from pixelated.adapter.mailstore.maintenance import SoledadMaintenance @@ -28,6 +30,8 @@ from leap.mail.constants import MessageFlags from pixelated.support.mail_generator import MailGenerator REPAIR_COMMAND = 'repair' +INTEGRITY_CHECK_COMMAND = 'integrity-check' + log = logging.getLogger(__name__) @@ -54,13 +58,17 @@ def initialize(): def _do_initial_sync(args): - return not _is_repair_command(args) + return (not _is_repair_command(args)) and (not _is_integrity_check_command(args)) def _is_repair_command(args): return args.command == REPAIR_COMMAND +def _is_integrity_check_command(args): + return args.command == INTEGRITY_CHECK_COMMAND + + def execute_command(args, leap_session): def init_soledad(): @@ -110,6 +118,9 @@ def add_command_callback(args, prepareDeferred, finalizeDeferred): elif args.command == 'sync': # nothing to do here, sync is already part of the chain prepareDeferred.chainDeferred(finalizeDeferred) + elif args.command == INTEGRITY_CHECK_COMMAND: + prepareDeferred.addCallback(integrity_check) + prepareDeferred.chainDeferred(finalizeDeferred) elif args.command == REPAIR_COMMAND: prepareDeferred.addCallback(repair) prepareDeferred.chainDeferred(finalizeDeferred) @@ -258,6 +269,38 @@ def dump_soledad(args): @defer.inlineCallbacks +def integrity_check(args): + leap_session, soledad = args + + generation, docs = yield soledad.get_all_docs() + + known_docs = {} + + print 'Analysing %d docs\n' % len(docs) + + # learn about all docs + for doc in docs: + known_docs[doc.doc_id] = doc + + for doc in docs: + if doc.doc_id.startswith('M-'): + meta = MetaMsgDocWrapper(doc_id=doc.doc_id, **doc.content) + + # validate header doc + if meta.hdoc not in known_docs: + print 'Error: Could not find header doc %s for meta %s' % (meta.hdoc, doc.doc_id) + + if meta.fdoc not in known_docs: + print 'Error: Could not find flags doc %s for meta %s' % (meta.fdoc, doc.doc_id) + + for cdoc in meta.cdocs: + if cdoc not in known_docs: + print 'Error: Could not find content doc %s for meta %s' % (cdoc, meta.doc_id) + + defer.returnValue(args) + + +@defer.inlineCallbacks def repair(args): leap_session, soledad = args |