author | Dan Price <dp@eng.sun.com> |
Thu, 11 Dec 2008 15:04:23 -0800 | |
changeset 775 | d1e7d18ae37b |
parent 765 | 3cc1f2dff092 |
child 791 | 123e9401e939 |
permissions | -rwxr-xr-x |
409
713e20963dc2
2314 shebang lines should use minimum python version
Shawn Walker <swalker@opensolaris.org>
parents:
404
diff
changeset
|
1 |
#!/usr/bin/python2.4 |
20
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
2 |
# |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
3 |
# CDDL HEADER START |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
4 |
# |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
5 |
# The contents of this file are subject to the terms of the |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
6 |
# Common Development and Distribution License (the "License"). |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
7 |
# You may not use this file except in compliance with the License. |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
8 |
# |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
9 |
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
10 |
# or http://www.opensolaris.org/os/licensing. |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
11 |
# See the License for the specific language governing permissions |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
12 |
# and limitations under the License. |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
13 |
# |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
14 |
# When distributing Covered Code, include this CDDL HEADER in each |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
15 |
# file and include the License file at usr/src/OPENSOLARIS.LICENSE. |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
16 |
# If applicable, add the following below this CDDL HEADER, with the |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
17 |
# fields enclosed by brackets "[]" replaced with your own identifying |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
18 |
# information: Portions Copyright [yyyy] [name of copyright owner] |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
19 |
# |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
20 |
# CDDL HEADER END |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
21 |
# |
260
a1b77322abb2
255 Symbolic HTTP response codes should be used
Shawn Walker <swalker@opensolaris.org>
parents:
258
diff
changeset
|
22 |
# Copyright 2008 Sun Microsystems, Inc. All rights reserved. |
20
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
23 |
# Use is subject to license terms. |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
24 |
# |
e5e53bc1c4d1
Cleaned up the build and install process. Turn the pkg directory into a
Danek Duvall <danek.duvall@sun.com>
parents:
14
diff
changeset
|
25 |
|
22
379f0f6809ff
pkgsend open, pkgsend add file, pkgsend close; Transaction object
"Stephen Hahn <sch@sun.com>"
parents:
21
diff
changeset
|
26 |
# pkg.depotd - package repository daemon |
0
f08899079fb4
implemented open, add (file case), close for transactions
"Stephen Hahn <sch@sun.com>"
parents:
diff
changeset
|
27 |
|
50 | 28 |
# XXX The prototype pkg.depotd combines both the version management server that |
29 |
# answers to pkgsend(1) sessions and the HTTP file server that answers to the |
|
30 |
# various GET operations that a pkg(1) client makes. This split is expected to |
|
31 |
# be made more explicit, by constraining the pkg(1) operations such that they |
|
32 |
# can be served as a typical HTTP/HTTPS session. Thus, pkg.depotd will reduce |
|
33 |
# to a special purpose HTTP/HTTPS server explicitly for the version management |
|
34 |
# operations, and must manipulate the various state files--catalogs, in |
|
35 |
# particular--such that the pkg(1) pull client can operately accurately with |
|
36 |
# only a basic HTTP/HTTPS server in place. |
|
37 |
||
38 |
# XXX We should support simple "last-modified" operations via HEAD queries. |
|
39 |
||
40 |
# XXX Although we pushed the evaluation of next-version, etc. to the pull |
|
41 |
# client, we should probably provide a query API to do same on the server, for |
|
42 |
# dumb clients (like a notification service). |
|
43 |
||
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
44 |
# The default authority for the depot. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
45 |
AUTH_DEFAULT = "opensolaris.org" |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
46 |
# The default repository path. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
47 |
REPO_PATH_DEFAULT = "/var/pkg/repo" |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
48 |
# The default path for static and other web content. |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
49 |
CONTENT_PATH_DEFAULT = "/usr/share/lib/pkg" |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
50 |
# The default port to serve data from. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
51 |
PORT_DEFAULT = 80 |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
52 |
# The minimum number of threads allowed. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
53 |
THREADS_MIN = 1 |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
54 |
# The default number of threads to start. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
55 |
THREADS_DEFAULT = 10 |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
56 |
# The maximum number of threads that can be started. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
57 |
THREADS_MAX = 100 |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
58 |
# The default server socket timeout in seconds. We want this to be longer than |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
59 |
# the normal default of 10 seconds to accommodate clients with poor quality |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
60 |
# connections. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
61 |
SOCKET_TIMEOUT_DEFAULT = 60 |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
62 |
# Whether modify operations should be allowed. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
63 |
READONLY_DEFAULT = False |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
64 |
# Whether the repository catalog should be rebuilt on startup. |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
65 |
REBUILD_DEFAULT = False |
429
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
66 |
# Whether the indexes should be rebuilt |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
67 |
REINDEX_DEFAULT = False |
461
37cf3ac75e37
1018 actions with payloads should include all sizes and hashes
johansen <johansen@sun.com>
parents:
452
diff
changeset
|
68 |
# Not in mirror mode by default |
37cf3ac75e37
1018 actions with payloads should include all sizes and hashes
johansen <johansen@sun.com>
parents:
452
diff
changeset
|
69 |
MIRROR_DEFAULT = False |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
70 |
|
26 | 71 |
import getopt |
689
1cb7154e1592
4489 depot traceback for info operation due to changeset 660
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
617
diff
changeset
|
72 |
import gettext |
1cb7154e1592
4489 depot traceback for info operation due to changeset 660
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
617
diff
changeset
|
73 |
import locale |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
74 |
import logging |
0
f08899079fb4
implemented open, add (file case), close for transactions
"Stephen Hahn <sch@sun.com>"
parents:
diff
changeset
|
75 |
import os |
468
20250d58c2ab
2309 pkg.depotd fails when -d argument is a relative pathname
Tom Mueller <Tom.Mueller@sun.com>
parents:
466
diff
changeset
|
76 |
import os.path |
52
d7c452ef7ae1
Sanitize getopt exception handling
Danek Duvall <danek.duvall@sun.com>
parents:
50
diff
changeset
|
77 |
import sys |
451
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
78 |
import urlparse |
0
f08899079fb4
implemented open, add (file case), close for transactions
"Stephen Hahn <sch@sun.com>"
parents:
diff
changeset
|
79 |
|
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
80 |
try: |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
81 |
import cherrypy |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
82 |
version = cherrypy.__version__.split('.') |
452
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
83 |
if map(int, version) < [3, 1, 0]: |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
84 |
raise ImportError |
452
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
85 |
elif map(int, version) >= [3, 2, 0]: |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
86 |
raise ImportError |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
87 |
except ImportError: |
751
b68bf0bec185
5466 depot should give a clear failure message if unable to import mako templates
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
742
diff
changeset
|
88 |
print >> sys.stderr, """cherrypy 3.1.0 or greater (but less than """ \ |
b68bf0bec185
5466 depot should give a clear failure message if unable to import mako templates
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
742
diff
changeset
|
89 |
"""3.2.0) is required to use this program.""" |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
90 |
sys.exit(2) |
22
379f0f6809ff
pkgsend open, pkgsend add file, pkgsend close; Transaction object
"Stephen Hahn <sch@sun.com>"
parents:
21
diff
changeset
|
91 |
|
26 | 92 |
import pkg.server.config as config |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
93 |
import pkg.server.depot as depot |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
94 |
import pkg.server.repository as repo |
428
e011e45fe2cd
2239 repository attribute system needed
Shawn Walker <shawn.walker@sun.com>
parents:
409
diff
changeset
|
95 |
import pkg.server.repositoryconfig as rc |
617
d146e7256c65
4048 A PartialIndexingException on the depot shouldn't stack trace or cause usage to be displayed
Brock Pytlik <bpytlik@sun.com>
parents:
612
diff
changeset
|
96 |
import pkg.search_errors as search_errors |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
97 |
from pkg.misc import port_available, msg, emsg |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
98 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
99 |
class LogSink(object): |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
100 |
"""This is a dummy object that we can use to discard log entries |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
101 |
without relying on non-portable interfaces such as /dev/null.""" |
23
51b8b48fea32
begin server source reorganization
"Stephen Hahn <sch@sun.com>"
parents:
22
diff
changeset
|
102 |
|
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
103 |
def write(self, *args, **kwargs): |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
104 |
"""Discard the bits.""" |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
105 |
pass |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
106 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
107 |
def flush(self, *args, **kwargs): |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
108 |
"""Discard the bits.""" |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
109 |
pass |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
110 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
111 |
def usage(text): |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
112 |
if text: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
113 |
emsg(text) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
114 |
|
26 | 115 |
print """\ |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
116 |
Usage: /usr/lib/pkg.depotd [-d repo_dir] [-p port] [-s threads] |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
117 |
[-t socket_timeout] [--content-root] [--log-access dest] |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
118 |
[--log-errors dest] [--mirror] [--proxy-base url] [--readonly] |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
119 |
[--rebuild] |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
120 |
|
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
121 |
--content-root The file system path to the directory containing the |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
122 |
the static and other web content used by the depot's |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
123 |
browser user interface. The default value is |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
124 |
'/usr/share/lib/pkg'. |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
125 |
--log-access The destination for any access related information |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
126 |
logged by the depot process. Possible values are: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
127 |
stderr, stdout, none, or an absolute pathname. The |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
128 |
default value is stdout if stdout is a tty; otherwise |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
129 |
the default value is none. |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
130 |
--log-errors The destination for any errors or other information |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
131 |
logged by the depot process. Possible values are: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
132 |
stderr, stdout, none, or an absolute pathname. The |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
133 |
default value is stderr. |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
134 |
--mirror Package mirror mode; publishing and metadata operations |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
135 |
disallowed. Cannot be used with --readonly or |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
136 |
--rebuild. |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
137 |
--proxy-base The url to use as the base for generating internal |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
138 |
redirects and content. |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
139 |
--readonly Read-only operation; modifying operations disallowed. |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
140 |
Cannot be used with --mirror or --rebuild. |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
141 |
--rebuild Re-build the catalog from pkgs in depot. Cannot be |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
142 |
used with --mirror or --readonly. |
26 | 143 |
""" |
135
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
144 |
sys.exit(2) |
14
969c85e852af
start pkg graph management, annotate pkgsend with server states
"Stephen Hahn <sch@sun.com>"
parents:
3
diff
changeset
|
145 |
|
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
146 |
class OptionError(Exception): |
429
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
147 |
"""Option exception. """ |
14
969c85e852af
start pkg graph management, annotate pkgsend with server states
"Stephen Hahn <sch@sun.com>"
parents:
3
diff
changeset
|
148 |
|
404
e5329e84b9a8
2331 depot command-line parsing errors cause traceback
Shawn Walker <swalker@opensolaris.org>
parents:
386
diff
changeset
|
149 |
def __init__(self, *args): |
e5329e84b9a8
2331 depot command-line parsing errors cause traceback
Shawn Walker <swalker@opensolaris.org>
parents:
386
diff
changeset
|
150 |
Exception.__init__(self, *args) |
30 | 151 |
|
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
152 |
if __name__ == "__main__": |
30 | 153 |
|
689
1cb7154e1592
4489 depot traceback for info operation due to changeset 660
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
617
diff
changeset
|
154 |
locale.setlocale(locale.LC_ALL, "") |
1cb7154e1592
4489 depot traceback for info operation due to changeset 660
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
617
diff
changeset
|
155 |
gettext.install("pkg", "/usr/share/locale") |
1cb7154e1592
4489 depot traceback for info operation due to changeset 660
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
617
diff
changeset
|
156 |
|
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
157 |
port = PORT_DEFAULT |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
158 |
threads = THREADS_DEFAULT |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
159 |
socket_timeout = SOCKET_TIMEOUT_DEFAULT |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
160 |
readonly = READONLY_DEFAULT |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
161 |
rebuild = REBUILD_DEFAULT |
429
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
162 |
reindex = REINDEX_DEFAULT |
451
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
163 |
proxy_base = None |
461
37cf3ac75e37
1018 actions with payloads should include all sizes and hashes
johansen <johansen@sun.com>
parents:
452
diff
changeset
|
164 |
mirror = MIRROR_DEFAULT |
258
b3b7592412ec
270 Need ability to rename packages
johansen <johansen@sun.com>
parents:
239
diff
changeset
|
165 |
|
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
166 |
if "PKG_REPO" in os.environ: |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
167 |
repo_path = os.environ["PKG_REPO"] |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
168 |
else: |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
169 |
repo_path = REPO_PATH_DEFAULT |
30 | 170 |
|
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
171 |
try: |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
172 |
content_root = os.environ["PKG_DEPOT_CONTENT"] |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
173 |
except KeyError: |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
174 |
try: |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
175 |
content_root = os.path.join(os.environ['PKG_HOME'], |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
176 |
'share/lib/pkg') |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
177 |
except KeyError: |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
178 |
content_root = CONTENT_PATH_DEFAULT |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
179 |
|
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
180 |
# By default, if the destination for a particular log type is not |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
181 |
# specified, this is where we will send the output. |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
182 |
log_routes = { |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
183 |
"access": "none", |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
184 |
"errors": "stderr" |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
185 |
} |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
186 |
log_opts = ["--log-%s" % log_type for log_type in log_routes] |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
187 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
188 |
# If stdout is a tty, then send access output there by default instead |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
189 |
# of discarding it. |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
190 |
if os.isatty(sys.stdout.fileno()): |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
191 |
log_routes["access"] = "stdout" |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
192 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
193 |
opt = None |
54
a0c517c20618
Don't throw an exception if the depot can't find a file
Danek Duvall <danek.duvall@sun.com>
parents:
52
diff
changeset
|
194 |
try: |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
195 |
long_opts = ["content-root=", "mirror", "proxy-base=", |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
196 |
"readonly", "rebuild", "refresh-index"] |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
197 |
for opt in log_opts: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
198 |
long_opts.append("%s=" % opt.lstrip('--')) |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
199 |
opts, pargs = getopt.getopt(sys.argv[1:], "d:np:s:t:", |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
200 |
long_opts) |
135
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
201 |
for opt, arg in opts: |
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
202 |
if opt == "-n": |
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
203 |
sys.exit(0) |
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
204 |
elif opt == "-d": |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
205 |
repo_path = arg |
135
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
206 |
elif opt == "-p": |
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
207 |
port = int(arg) |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
208 |
elif opt == "-s": |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
209 |
threads = int(arg) |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
210 |
if threads < THREADS_MIN: |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
211 |
raise OptionError, \ |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
212 |
"minimum value is %d" % THREADS_MIN |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
213 |
if threads > THREADS_MAX: |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
214 |
raise OptionError, \ |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
215 |
"maximum value is %d" % THREADS_MAX |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
216 |
elif opt == "-t": |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
217 |
socket_timeout = int(arg) |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
218 |
elif opt == "--content-root": |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
219 |
if arg == "": |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
220 |
raise OptionError, "You must specify " \ |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
221 |
"a directory path." |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
222 |
content_root = arg |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
223 |
elif opt in log_opts: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
224 |
if arg is None or arg == "": |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
225 |
raise OptionError, \ |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
226 |
"You must specify a log " \ |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
227 |
"destination." |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
228 |
log_routes[opt.lstrip("--log-")] = arg |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
229 |
elif opt == "--mirror": |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
230 |
mirror = True |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
231 |
elif opt == "--proxy-base": |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
232 |
# Attempt to decompose the url provided into |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
233 |
# its base parts. This is done so we can |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
234 |
# remove any scheme information since we |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
235 |
# don't need it. |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
236 |
scheme, netloc, path, params, query, \ |
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
237 |
fragment = urlparse.urlparse(arg, |
765
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
238 |
"http", allow_fragments=0) |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
239 |
|
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
240 |
if not netloc: |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
241 |
raise OptionError, "Unable to " \ |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
242 |
"determine the hostname from " \ |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
243 |
"the provided URL; please use a " \ |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
244 |
"fully qualified URL." |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
245 |
|
765
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
246 |
scheme = scheme.lower() |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
247 |
if scheme not in ("http", "https"): |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
248 |
raise OptionError, "Invalid URL; http " \ |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
249 |
"and https are the only supported " \ |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
250 |
"schemes." |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
251 |
|
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
252 |
# Rebuild the url with the sanitized components. |
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
253 |
proxy_base = urlparse.urlunparse((scheme, netloc, |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
254 |
path, params, query, fragment) |
765
3cc1f2dff092
5668 proxy base should allow https
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
751
diff
changeset
|
255 |
) |
135
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
256 |
elif opt == "--readonly": |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
257 |
readonly = True |
157
504b9e6d213c
Catalog should be on-disk instead of in memory
johansen <johansen@sun.com>
parents:
146
diff
changeset
|
258 |
elif opt == "--rebuild": |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
259 |
rebuild = True |
429
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
260 |
elif opt == "--refresh-index": |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
261 |
# Note: This argument is for internal use |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
262 |
# only. It's used when pkg.depotd is reexecing |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
263 |
# itself and needs to know that's the case. |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
264 |
# This flag is purposefully omitted in usage. |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
265 |
# The supported way to forcefully reindex is to |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
266 |
# kill any pkg.depot using that directory, |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
267 |
# remove the index directory, and restart the |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
268 |
# pkg.depot process. The index will be rebuilt |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
269 |
# automatically on startup. |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
270 |
reindex = True |
135
a1e20e9a9845
add CLI test suite, correct bugs found by test suite, ration out CLI options
Stephen Hahn <sch@Sun.COM>
parents:
119
diff
changeset
|
271 |
except getopt.GetoptError, e: |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
272 |
usage("pkg.depotd: %s" % e.msg) |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
273 |
except OptionError, e: |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
274 |
usage("pkg.depotd: option: %s -- %s" % (opt, e)) |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
275 |
except (ArithmeticError, ValueError): |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
276 |
usage("pkg.depotd: illegal option value: %s specified " \ |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
277 |
"for option: %s" % (arg, opt)) |
451
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
278 |
|
445
76b03dd5a4ac
2693 Indexing code and catalog code should respect --read-only
Brock Pytlik <bpytlik@sun.com>
parents:
429
diff
changeset
|
279 |
if rebuild and reindex: |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
280 |
usage("--refresh-index cannot be used with --rebuild") |
461
37cf3ac75e37
1018 actions with payloads should include all sizes and hashes
johansen <johansen@sun.com>
parents:
452
diff
changeset
|
281 |
if rebuild and (readonly or mirror): |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
282 |
usage("--readonly and --mirror cannot be used with --rebuild") |
461
37cf3ac75e37
1018 actions with payloads should include all sizes and hashes
johansen <johansen@sun.com>
parents:
452
diff
changeset
|
283 |
if reindex and (readonly or mirror): |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
284 |
usage("--readonly and --mirror cannot be used with " \ |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
285 |
"--refresh-index") |
451
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
286 |
|
429
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
287 |
# If the program is going to reindex, the port is irrelevant since |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
288 |
# the program will not bind to a port. |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
289 |
if not reindex: |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
290 |
available, msg = port_available(None, port) |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
291 |
if not available: |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
292 |
print "pkg.depotd: unable to bind to the specified " \ |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
293 |
"port: %d. Reason: %s" % (port, msg) |
6c9cbb6e6600
983 pkg search returns just one action per package/token-type combo
Brock Pytlik <bpytlik@sun.com>
parents:
428
diff
changeset
|
294 |
sys.exit(1) |
612
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
295 |
else: |
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
296 |
# Not applicable for reindexing operations. |
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
297 |
content_root = None |
386
5cd680466abe
2147 depot should check port instead of showing traceback if port binding fails
Shawn Walker <swalker@opensolaris.org>
parents:
382
diff
changeset
|
298 |
|
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
299 |
scfg = config.SvrConfig(repo_path, content_root, AUTH_DEFAULT) |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
300 |
|
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
301 |
if rebuild: |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
302 |
scfg.destroy_catalog() |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
303 |
|
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
304 |
if readonly: |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
305 |
scfg.set_read_only() |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
306 |
|
461
37cf3ac75e37
1018 actions with payloads should include all sizes and hashes
johansen <johansen@sun.com>
parents:
452
diff
changeset
|
307 |
if mirror: |
37cf3ac75e37
1018 actions with payloads should include all sizes and hashes
johansen <johansen@sun.com>
parents:
452
diff
changeset
|
308 |
scfg.set_mirror() |
37cf3ac75e37
1018 actions with payloads should include all sizes and hashes
johansen <johansen@sun.com>
parents:
452
diff
changeset
|
309 |
|
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
310 |
try: |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
311 |
scfg.init_dirs() |
589
2480ab0274d1
242 desire ability to set content root
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
468
diff
changeset
|
312 |
except (RuntimeError, EnvironmentError), e: |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
313 |
print "pkg.depotd: an error occurred while trying to " \ |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
314 |
"initialize the depot repository directory " \ |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
315 |
"structures:\n%s" % e |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
316 |
sys.exit(1) |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
317 |
|
452
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
318 |
# Setup our global configuration. |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
319 |
# Global cherrypy configuration |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
320 |
gconf = { |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
321 |
"environment": "production", |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
322 |
"checker.on": True, |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
323 |
"log.screen": False, |
452
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
324 |
"server.socket_host": "0.0.0.0", |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
325 |
"server.socket_port": port, |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
326 |
"server.thread_pool": threads, |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
327 |
"server.socket_timeout": socket_timeout, |
775
d1e7d18ae37b
5756 cherrypy can take a long time to shutdown-- depot needs an intelligent stop method
Dan Price <dp@eng.sun.com>
parents:
765
diff
changeset
|
328 |
"server.shutdown_timeout": 0, |
742
909b912fa942
3011 new depot index page desired
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
689
diff
changeset
|
329 |
"tools.log_headers.on": True, |
909b912fa942
3011 new depot index page desired
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
689
diff
changeset
|
330 |
"tools.encode.on": True |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
331 |
} |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
332 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
333 |
log_type_map = { |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
334 |
"errors": { |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
335 |
"param": "log.error_file", |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
336 |
"attr": "error_log" |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
337 |
}, |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
338 |
"access": { |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
339 |
"param": "log.access_file", |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
340 |
"attr": "access_log" |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
341 |
} |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
342 |
} |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
343 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
344 |
for log_type in log_type_map: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
345 |
dest = log_routes[log_type] |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
346 |
if dest in ("stdout", "stderr", "none"): |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
347 |
if dest == "none": |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
348 |
h = logging.StreamHandler(LogSink()) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
349 |
else: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
350 |
h = logging.StreamHandler(eval("sys.%s" % \ |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
351 |
dest)) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
352 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
353 |
h.setLevel(logging.DEBUG) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
354 |
h.setFormatter(cherrypy._cplogging.logfmt) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
355 |
log_obj = eval("cherrypy.log.%s" % \ |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
356 |
log_type_map[log_type]["attr"]) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
357 |
log_obj.addHandler(h) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
358 |
# Since we've replaced cherrypy's log handler with our |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
359 |
# own, we don't want the output directed to a file. |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
360 |
dest = "" |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
361 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
362 |
gconf[log_type_map[log_type]["param"]] = dest |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
363 |
|
612
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
364 |
cherrypy.config.update(gconf) |
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
365 |
|
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
366 |
# Now that our logging, etc. has been setup, it's safe to perform any |
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
367 |
# remaining preparation. |
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
368 |
if reindex: |
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
369 |
scfg.acquire_catalog(rebuild=False) |
617
d146e7256c65
4048 A PartialIndexingException on the depot shouldn't stack trace or cause usage to be displayed
Brock Pytlik <bpytlik@sun.com>
parents:
612
diff
changeset
|
370 |
try: |
d146e7256c65
4048 A PartialIndexingException on the depot shouldn't stack trace or cause usage to be displayed
Brock Pytlik <bpytlik@sun.com>
parents:
612
diff
changeset
|
371 |
scfg.catalog.run_update_index() |
d146e7256c65
4048 A PartialIndexingException on the depot shouldn't stack trace or cause usage to be displayed
Brock Pytlik <bpytlik@sun.com>
parents:
612
diff
changeset
|
372 |
except search_errors.IndexingException, e: |
d146e7256c65
4048 A PartialIndexingException on the depot shouldn't stack trace or cause usage to be displayed
Brock Pytlik <bpytlik@sun.com>
parents:
612
diff
changeset
|
373 |
cherrypy.log(str(e), "INDEX") |
d146e7256c65
4048 A PartialIndexingException on the depot shouldn't stack trace or cause usage to be displayed
Brock Pytlik <bpytlik@sun.com>
parents:
612
diff
changeset
|
374 |
sys.exit(1) |
612
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
375 |
sys.exit(0) |
353fef98c569
4102 test suite fails if /usr/share/lib/pkg doesn't exist
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
589
diff
changeset
|
376 |
|
451
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
377 |
# Now build our site configuration. |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
378 |
conf = { |
452
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
379 |
"/": { |
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
380 |
# We have to override cherrypy's default response_class so that |
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
381 |
# we have access to the write() callable to stream data |
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
382 |
# directly to the client. |
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
383 |
"wsgi.response_class": depot.DepotResponse, |
01f53c6381af
2714 image-update failure during update phase
Shawn Walker <shawn.walker@sun.com>
parents:
451
diff
changeset
|
384 |
}, |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
385 |
"/robots.txt": { |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
386 |
"tools.staticfile.on": True, |
742
909b912fa942
3011 new depot index page desired
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
689
diff
changeset
|
387 |
"tools.staticfile.filename": os.path.join(scfg.web_root, |
382
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
388 |
"robots.txt") |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
389 |
}, |
95304bd3b365
1854 rework depot to use higher-level framework
Shawn Walker <swalker@opensolaris.org>
parents:
374
diff
changeset
|
390 |
} |
145
08bee7fd13f6
Add versioning to the protocols
Danek Duvall <danek.duvall@sun.com>
parents:
135
diff
changeset
|
391 |
|
451
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
392 |
if proxy_base: |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
393 |
# This changes the base URL for our server, and is primarily |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
394 |
# intended to allow our depot process to operate behind Apache |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
395 |
# or some other webserver process. |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
396 |
# |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
397 |
# Visit the following URL for more information: |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
398 |
# http://cherrypy.org/wiki/BuiltinTools#tools.proxy |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
399 |
proxy_conf = { |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
400 |
"tools.proxy.on": True, |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
401 |
"tools.proxy.local": "", |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
402 |
"tools.proxy.base": proxy_base |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
403 |
} |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
404 |
|
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
405 |
# Now merge or add our proxy configuration information into the |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
406 |
# existing configuration. |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
407 |
for entry in proxy_conf: |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
408 |
conf["/"][entry] = proxy_conf[entry] |
74f1fe85fe2d
1324 RSS / Atom feeds of repository updates
Shawn Walker <shawn.walker@sun.com>
parents:
445
diff
changeset
|
409 |
|
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
410 |
scfg.acquire_in_flight() |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
411 |
scfg.acquire_catalog() |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
412 |
|
217
a53bcf30c049
279 catalog_update should cope with HTTPError
johansen <johansen@sun.com>
parents:
215
diff
changeset
|
413 |
try: |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
414 |
root = cherrypy.Application(repo.Repository(scfg)) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
415 |
except rc.InvalidAttributeValueError, e: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
416 |
emsg("pkg.depotd: repository.conf error: %s" % e) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
417 |
sys.exit(1) |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
418 |
|
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
419 |
try: |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
420 |
cherrypy.quickstart(root, config=conf) |
742
909b912fa942
3011 new depot index page desired
Shawn Walker <Shawn.Walker@Sun.COM>
parents:
689
diff
changeset
|
421 |
except Exception: |
466
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
422 |
usage("pkg.depotd: unknown error starting depot, illegal " \ |
7cfb6502ff1b
2333 control over access / error log destination desired
Shawn Walker <shawn.walker@sun.com>
parents:
461
diff
changeset
|
423 |
"option value specified?") |
217
a53bcf30c049
279 catalog_update should cope with HTTPError
johansen <johansen@sun.com>
parents:
215
diff
changeset
|
424 |