1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
# Copyright 2009-2011 Canonical Ltd. This software is licensed under the
# GNU Affero General Public License version 3 (see the file LICENSE).
"""A configuration class describing the Launchpad web service."""
__metaclass__ = type
__all__ = [
'LaunchpadWebServiceConfiguration',
]
from lazr.restful.simple import BaseWebServiceConfiguration
from zope.component import getUtility
from canonical.config import config
from canonical.launchpad.webapp.interfaces import ILaunchBag
from canonical.launchpad.webapp.servers import (
WebServiceClientRequest,
WebServicePublication,
)
from lp.app import versioninfo
class LaunchpadWebServiceConfiguration(BaseWebServiceConfiguration):
path_override = "api"
active_versions = ["beta", "1.0", "devel"]
last_version_with_mutator_named_operations = "beta"
first_version_with_total_size_link = "devel"
view_permission = "launchpad.View"
require_explicit_versions = True
compensate_for_mod_compress_etag_modification = True
service_description = """The Launchpad web service allows automated
clients to access most of the functionality available on the
Launchpad web site. For help getting started, see
<a href="https://help.launchpad.net/API/">the help wiki.</a>"""
version_descriptions = {
"beta": """This is the first version of the web service ever
published. Its end-of-life date is April 2011, the same as the
Ubuntu release "Karmic Koala".""",
"1.0": """This version of the web service removes unnecessary
named operations. It was introduced in March 2010, and its
end-of-life date is April 2015, the same as the server version
of the Ubuntu release "Lucid Lynx".""",
"devel": """This version of the web service reflects the most
recent changes made. It may abruptly change without
warning. Periodically, these changes are bundled up and given a
permanent version number.""",
}
@property
def use_https(self):
return config.vhosts.use_https
@property
def code_revision(self):
return str(versioninfo.revno)
def createRequest(self, body_instream, environ):
"""See `IWebServiceConfiguration`."""
# The request is going to try to decode the 'PATH_INFO' using utf-8,
# so if it is currently unicode, encode it.
if isinstance(environ.get('PATH_INFO'), unicode):
environ['PATH_INFO'] = environ['PATH_INFO'].encode('utf-8')
request = WebServiceClientRequest(body_instream, environ)
request.setPublication(WebServicePublication(None))
return request
@property
def enable_server_side_representation_cache(self):
return config.vhost.api.enable_server_side_representation_cache
@property
def default_batch_size(self):
return config.launchpad.default_batch_size
@property
def max_batch_size(self):
return config.launchpad.max_batch_size
@property
def show_tracebacks(self):
"""See `IWebServiceConfiguration`.
People who aren't developers shouldn't be shown any
information about the exception that caused an internal server
error. It might contain private information.
"""
is_developer = getUtility(ILaunchBag).developer
return (is_developer or config.canonical.show_tracebacks)
def get_request_user(self):
"""See `IWebServiceConfiguration`."""
return getUtility(ILaunchBag).user
|