X-Git-Url: https://git.decadent.org.uk/gitweb/?p=dak.git;a=blobdiff_plain;f=dak%2Fadmin.py;h=60428cfb2afa0e5a761170ce49beeb98bcefd2ae;hp=43e20ecfe9209b6f87c2237e8a620f650740618a;hb=98d086ddda3772fb58c1bfa97478e8044596b569;hpb=fdbd2401e920b8aaf762fe90b312603baa4d64b8 diff --git a/dak/admin.py b/dak/admin.py index 43e20ecf..60428cfb 100755 --- a/dak/admin.py +++ b/dak/admin.py @@ -101,6 +101,8 @@ Perform administrative work on the dak database. s add-all-arches SUITE VERSION... as "s add" but adds suite-architecture relationships for all architectures + s add-build-queue SUITE BUILD-QUEUE BUILD-QUEUE-CODENAME BUILD-QUEUE-ARCHIVE + add a build queue for an existing suite suite-architecture / s-a: s-a list show the architectures for all suites @@ -320,6 +322,9 @@ def __suite_add(d, args, addallarches=False): version = args[3] rest = args[3:] + if len(version) == 0: + version = None + def get_field(field): for varval in args: if varval.startswith(field + '='): @@ -384,6 +389,56 @@ def __suite_rm(d, args): die("E: Error removing suite {0} ({1})".format(name, e)) print "Suite {0} removed".format(name) +def __suite_add_build_queue(d, args): + session = d.session() + + die_arglen(args, 6, "E: Adding a build queue needs four parameters.") + + suite_name = args[2] + build_queue_name = args[3] + build_queue_codename = args[4] + build_queue_archive_name = args[5] + try: + suite = session.query(Suite).filter_by(suite_name=suite_name).one() + except NoResultFound: + die("E: Unknown suite '{0}'".format(suite_name)) + try: + build_queue_archive = session.query(Archive).filter_by(archive_name=build_queue_archive_name).one() + except NoResultFound: + die("E: Unknown archive '{0}'".format(build_queue_archive_name)) + + # Create suite + s = Suite() + s.suite_name = build_queue_name + s.origin = suite.origin + s.label = suite.label + s.description = "buildd {0} incoming".format(suite_name) + s.codename = build_queue_codename + s.notautomatic = suite.notautomatic + s.overridesuite = suite.overridesuite or suite.suite_name + s.butautomaticupgrades = suite.butautomaticupgrades + s.signingkeys = suite.signingkeys + s.include_long_description = False + + s.archive = build_queue_archive + s.architectures.extend(suite.architectures) + s.components.extend(suite.components) + s.srcformats.extend(suite.srcformats) + + session.add(s) + session.flush() + + bq = BuildQueue() + bq.queue_name = build_queue_codename + bq.suite = s + + session.add(bq) + session.flush() + + suite.copy_queues.append(bq) + + session.commit() + def suite(command): args = [str(x) for x in command] Cnf = utils.get_conf() @@ -403,6 +458,8 @@ def suite(command): __suite_add(d, args, False) elif mode == 'add-all-arches': __suite_add(d, args, True) + elif mode == 'add-build-queue': + __suite_add_build_queue(d, args) else: die("E: suite command unknown")