Source code for oioioi.sioworkers.management.commands.worker

import json

from django.conf import settings
from django.core.management.base import BaseCommand, CommandError
from xmlrpc.client import Server


[docs]class Command(BaseCommand):
[docs] help = 'TODO'
def __init__(self, *args, **kwargs): super(Command, self).__init__(*args, **kwargs) self.server = Server(settings.SIOWORKERSD_URL)
[docs] def add_arguments(self, parser): parser.add_argument( 'command', type=str, nargs='?', default=None, help='Command to be run' ) parser.add_argument('args', type=str, nargs='*', help='Command\' arguments')
[docs] def cmd_list(self, *args, **kwargs): l = self.server.get_workers() if l: self.stdout.write('\n'.join(map(str, l))) else: self.stdout.write('No workers connected.\n')
[docs] def cmd_run(self, *args, **kwargs): if len(args) != 1: self.stdout.write("Required exactly one argument - job env.\n") return self.stdout.write( self.server.run_group( json.dumps( { "workers_jobs": { "worker.py-task": json.loads(args[0]), } } ) ) )
[docs] def cmd_sync_run(self, *args, **kwargs): if len(args) != 1: self.stdout.write("Required exactly one argument - job env.\n") return self.stdout.write( repr( self.server.sync_run_group( json.dumps( { "workers_jobs": { "worker.py-task": json.loads(args[0]), } } ) ) ) )
[docs] def cmd_run_group(self, *args, **kwargs): if len(args) != 1: self.stdout.write("Required exactly one argument - job env.\n") return self.stdout.write(self.server.run_group(args[0]))
[docs] def cmd_sync_run_group(self, *args, **kwargs): if len(args) != 1: self.stdout.write("Required exactly one argument - job env.\n") return self.stdout.write(repr(self.server.sync_run_group(args[0])))
[docs] def cmd_queue(self, *args, **kwargs): q = self.server.get_queue() if not q: self.stdout.write('Empty queue.\n') return self.stdout.write(json.dumps(q))
[docs] def handle(self, *args, **options): if not options['command']: cmds = [i[4:] for i in dir(self) if i.startswith('cmd_')] self.stdout.write('Available commands: %s\n' % ', '.join(cmds)) return cmd = options['command'] try: f = getattr(self, 'cmd_' + cmd) except AttributeError: raise CommandError('Invalid command: %s' % cmd) f(*args, **options)