2011-04-13 19:00:31 +02:00
|
|
|
import sys
|
2012-06-22 11:31:15 +02:00
|
|
|
import logging
|
2011-04-13 19:00:31 +02:00
|
|
|
from optparse import make_option
|
|
|
|
|
2012-04-28 18:16:05 +02:00
|
|
|
from django.core.management.base import BaseCommand
|
2012-06-22 11:31:15 +02:00
|
|
|
|
|
|
|
from djeuscan.processing import set_verbosity_level
|
2012-07-02 18:16:59 +02:00
|
|
|
from djeuscan.processing.scan import scan_portage
|
2011-08-25 15:39:54 +02:00
|
|
|
|
2012-06-22 11:31:15 +02:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2012-03-14 14:07:06 +01:00
|
|
|
|
2012-05-28 21:16:38 +02:00
|
|
|
class Command(BaseCommand):
|
|
|
|
_overlays = {}
|
2012-03-14 14:07:06 +01:00
|
|
|
|
2012-05-28 21:16:38 +02:00
|
|
|
option_list = BaseCommand.option_list + (
|
|
|
|
make_option('--all',
|
|
|
|
action='store_true',
|
|
|
|
dest='all',
|
|
|
|
default=False,
|
|
|
|
help='Scan all packages'),
|
2012-07-02 09:43:31 +02:00
|
|
|
make_option('--category',
|
|
|
|
action='store',
|
|
|
|
dest='category',
|
|
|
|
default=None,
|
|
|
|
help='Scan only this category'),
|
2012-05-28 21:16:38 +02:00
|
|
|
make_option('--purge-packages',
|
|
|
|
action='store_true',
|
|
|
|
dest='purge-packages',
|
|
|
|
default=False,
|
|
|
|
help='Purge old packages'),
|
|
|
|
make_option('--purge-versions',
|
|
|
|
action='store_true',
|
|
|
|
dest='purge-versions',
|
|
|
|
default=False,
|
|
|
|
help='Purge old versions'),
|
2012-09-14 17:22:18 +02:00
|
|
|
make_option('--upstream',
|
|
|
|
action='store_true',
|
|
|
|
dest='upstream',
|
|
|
|
default=False,
|
|
|
|
help='Scan upstream for updated packages in Portage'),
|
2012-05-28 21:16:38 +02:00
|
|
|
make_option('--no-log',
|
|
|
|
action='store_true',
|
|
|
|
dest='no-log',
|
|
|
|
default=False,
|
|
|
|
help='Don\'t store logs'),
|
|
|
|
make_option('--prefetch',
|
|
|
|
action='store_true',
|
|
|
|
dest='prefetch',
|
|
|
|
default=False,
|
|
|
|
help=('Prefetch all versions and packages from DB to '
|
|
|
|
'speedup full scan process.')),
|
|
|
|
)
|
|
|
|
args = '[package package ...]'
|
|
|
|
help = 'Scans portage tree and fills database'
|
2012-03-14 14:07:06 +01:00
|
|
|
|
2012-05-28 21:16:38 +02:00
|
|
|
def handle(self, *args, **options):
|
2012-06-22 11:31:15 +02:00
|
|
|
set_verbosity_level(logger, options.get("verbosity", 1))
|
|
|
|
|
2012-07-02 09:43:31 +02:00
|
|
|
if options['all'] or options['category']:
|
2012-06-22 09:32:39 +02:00
|
|
|
packages = None
|
2012-05-28 21:16:38 +02:00
|
|
|
elif len(args):
|
2012-06-22 09:32:39 +02:00
|
|
|
packages = [pkg for pkg in args]
|
2012-05-28 21:16:38 +02:00
|
|
|
else:
|
2012-06-22 09:32:39 +02:00
|
|
|
packages = [pkg[:-1] for pkg in sys.stdin.readlines()]
|
|
|
|
|
|
|
|
scan_portage(
|
|
|
|
packages=packages,
|
2012-07-02 09:43:31 +02:00
|
|
|
category=options['category'],
|
2012-06-22 09:32:39 +02:00
|
|
|
no_log=options["no-log"],
|
|
|
|
purge_packages=options["purge-packages"],
|
|
|
|
purge_versions=options["purge-versions"],
|
|
|
|
prefetch=options["prefetch"],
|
2012-09-14 17:22:18 +02:00
|
|
|
upstream=options["upstream"],
|
2012-06-22 11:31:15 +02:00
|
|
|
logger=logger,
|
2012-06-22 09:32:39 +02:00
|
|
|
)
|