Remove legacy search.
[wolnelektury.git] / src / search / management / commands / reindex.py
diff --git a/src/search/management/commands/reindex.py b/src/search/management/commands/reindex.py
deleted file mode 100644 (file)
index c2fe78e..0000000
+++ /dev/null
@@ -1,105 +0,0 @@
-# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
-# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
-#
-import sys
-import traceback
-
-from django.core.management.base import BaseCommand
-
-
-def query_yes_no(question, default="yes"):
-    """Ask a yes/no question via raw_input() and return their answer.
-
-    "question" is a string that is presented to the user.
-    "default" is the presumed answer if the user just hits <Enter>.
-        It must be "yes" (the default), "no" or None (meaning
-        an answer is required of the user).
-
-    The "answer" return value is one of "yes" or "no".
-    """
-    valid = {"yes": True, "y": True, "ye": True,
-             "no": False, "n": False}
-    if default is None:
-        prompt = " [y/n] "
-    elif default == "yes":
-        prompt = " [Y/n] "
-    elif default == "no":
-        prompt = " [y/N] "
-    else:
-        raise ValueError("invalid default answer: '%s'" % default)
-
-    while True:
-        sys.stdout.write(question + prompt)
-        choice = raw_input().lower()
-        if default is not None and choice == '':
-            return valid[default]
-        elif choice in valid:
-            return valid[choice]
-        else:
-            sys.stdout.write("Please respond with 'yes' or 'no' (or 'y' or 'n').\n")
-
-
-class Command(BaseCommand):
-    help = 'Reindex everything.'
-
-    def add_arguments(self, parser):
-        parser.add_argument(
-                '-n', '--book-id', action='store_true', dest='book_id',
-                default=False, help='book id instead of slugs')
-        parser.add_argument(
-                '-t', '--just-tags', action='store_true', dest='just_tags',
-                default=False, help='just reindex tags')
-        parser.add_argument(
-                '--start', dest='start_from', default=None,
-                help='start from this slug')
-        parser.add_argument(
-                '--stop', dest='stop_after', default=None,
-                help='stop after this slug')
-        parser.add_argument('args', nargs='*', metavar='slug/id')
-
-    def handle(self, **opts):
-        from catalogue.models import Book
-        from search.index import Index
-        idx = Index()
-        
-        if not opts['just_tags']:
-            if opts['args']:
-                books = []
-                for a in opts['args']:
-                    if opts['book_id']:
-                        books += Book.objects.filter(id=int(a)).all()
-                    else:
-                        books += Book.objects.filter(slug=a).all()
-            else:
-                books = list(Book.objects.order_by('slug'))
-            start_from = opts.get('start_from')
-            stop_after = opts.get('stop_after')
-            if start_from:
-                start_from = start_from.replace('-', '')
-            if stop_after:
-                stop_after = stop_after.replace('-', '')
-            while books:
-                try:
-                    b = books[0]
-                    slug = b.slug.replace('-', '')
-                    if stop_after and slug > stop_after:
-                        break
-                    if not start_from or slug >= start_from:
-                        print(b.slug)
-                        idx.index_book(b)
-                        idx.index.commit()
-                    books.pop(0)
-                except:
-                    traceback.print_exc()
-                    try:
-                        # we might not be able to rollback
-                        idx.index.rollback()
-                    except:
-                        pass
-                    retry = query_yes_no("Retry?")
-                    if not retry:
-                        break
-
-        print('Reindexing tags.')
-        idx.index_tags()
-        idx.index.commit()