4 Wrapper to launch dak functionality
9 # Copyright (C) 2005, 2006 Anthony Towns <ajt@debian.org>
10 # Copyright (C) 2006 James Troup <james@nocrew.org>
12 # This program is free software; you can redistribute it and/or modify
13 # it under the terms of the GNU General Public License as published by
14 # the Free Software Foundation; either version 2 of the License, or
15 # (at your option) any later version.
17 # This program is distributed in the hope that it will be useful,
18 # but WITHOUT ANY WARRANTY; without even the implied warranty of
19 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 # GNU General Public License for more details.
22 # You should have received a copy of the GNU General Public License
23 # along with this program; if not, write to the Free Software
24 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
26 ################################################################################
28 # well I don't know where you're from but in AMERICA, there's a little
29 # thing called "abstinent until proven guilty."
30 # -- http://harrietmiers.blogspot.com/2005/10/wow-i-feel-loved.html
32 # (if James had a blog, I bet I could find a funny quote in it to use!)
34 ################################################################################
40 ################################################################################
43 """Setup the list of modules and brief explanation of what they
48 "Show which suites packages are in"),
50 "Query/change the overrides"),
52 "Archive sanity checks"),
54 "Produce a report on NEW and BYHAND packages"),
56 "Output html for packages in NEW"),
58 "Output html and symlinks for packages in DEFERRED"),
61 "Remove packages from suites"),
64 "Process NEW and BYHAND packages"),
66 "Process packages in queue/unchecked"),
68 "Install packages into the pool"),
70 ("make-suite-file-list",
71 "Generate lists of packages per suite for apt-ftparchive"),
72 ("make-pkg-file-mapping",
73 "Generate package <-> file mapping"),
75 "Generate Release files"),
77 "Generate content files"),
78 ("generate-index-diffs",
79 "Generate .diff/Index files"),
81 "Clean unused/superseded packages from the archive"),
83 "Clean cruft from incoming"),
84 ("clean-proposed-updates",
85 "Remove obsolete .changes from proposed-updates"),
88 "Manage the release transition file"),
90 "Override cruft checks"),
91 ("check-proposed-updates",
92 "Dependency checking for proposed-updates"),
94 "Manipulate/list override entries in bulk"),
96 "Manipulate suites in bulk"),
98 "Check for obsolete or duplicated packages"),
100 "Display contents of a .dak file"),
102 "Show information useful for NEW processing"),
103 ("find-null-maintainers",
104 "Check for users with no packages in the archive"),
106 "Populate fingerprint/uid table based on a new/updated keyring"),
107 ("import-ldap-fingerprints",
108 "Syncs fingerprint and uid tables with Debian LDAP db"),
109 ("import-users-from-passwd",
110 "Sync PostgreSQL users with passwd file"),
112 "Perform administration on the dak database"),
114 "Update the database to match the conf file"),
116 "Updates databae schema to latest revision"),
118 "Initial setup of the archive"),
120 "Generates Maintainers file for BTS etc"),
122 "Generates override files"),
124 "Move packages from dists/ to pool/"),
125 ("new-security-install",
126 "New way to install a security upload into the archive"),
128 "Split queue/done into a date-based hierarchy"),
130 "Generate statistics"),
132 "Categorize uncategorized bugs filed against ftp.debian.org"),
134 "Add a user to the archive"),
138 ################################################################################
140 def usage(functionality, exit_code=0):
141 """Print a usage message and exit with 'exit_code'."""
143 print """Usage: dak COMMAND [...]
144 Run DAK commands. (Will also work if invoked as COMMAND.)
146 Available commands:"""
147 for (command, description) in functionality:
148 print " %-23s %s" % (command, description)
151 ################################################################################
154 """Launch dak functionality."""
156 functionality = init()
157 modules = [ command for (command, _) in functionality ]
159 if len(sys.argv) == 0:
160 daklib.utils.fubar("err, argc == 0? how is that possible?")
161 elif (len(sys.argv) == 1
162 or (len(sys.argv) == 2 and
163 (sys.argv[1] == "--help" or sys.argv[1] == "-h"))):
166 # First see if we were invoked with/as the name of a module
167 cmdname = sys.argv[0]
168 cmdname = cmdname[cmdname.rfind("/")+1:]
169 if cmdname in modules:
171 # Otherwise the argument is the module
173 cmdname = sys.argv[1]
174 sys.argv = [sys.argv[0] + " " + sys.argv[1]] + sys.argv[2:]
175 if cmdname not in modules:
178 if name.startswith(cmdname):
183 daklib.utils.warn("ambiguous command '%s' - could be %s" \
184 % (cmdname, ", ".join(match)))
185 usage(functionality, 1)
187 daklib.utils.warn("unknown command '%s'" % (cmdname))
188 usage(functionality, 1)
191 module = __import__(cmdname.replace("-","_"))
195 ################################################################################
197 if __name__ == "__main__":