diff options
| author | bwarsaw | 1999-01-08 06:04:22 +0000 |
|---|---|---|
| committer | bwarsaw | 1999-01-08 06:04:22 +0000 |
| commit | a34762ab857cc7e2fd37ac84ca5ccf58b2cfcbe6 (patch) | |
| tree | 3bf72d161e6610085b2a1ec0b350a6530b9f777e /Mailman/pythonlib/cgi.py | |
| parent | 52ee9e7e8c15e50a5be19b1a7fa0247270e0d516 (diff) | |
| download | mailman-a34762ab857cc7e2fd37ac84ca5ccf58b2cfcbe6.tar.gz mailman-a34762ab857cc7e2fd37ac84ca5ccf58b2cfcbe6.tar.zst mailman-a34762ab857cc7e2fd37ac84ca5ccf58b2cfcbe6.zip | |
Changes to workaround some bogus clients which either don't include a
content-type header, or include a bogus one.
cgi.py
FieldStorage.__init__(): if there is no content-type header, use
text/plain for inner parts, but application/x-www-form-urlencoded
for outer parts. Honor any existing content-type header.
Lower down, if the content-type header is something we don't
understand, default to text/plain for inner parts, but
application/x-www-form-urlencoded for outer parts.
This patch will be proposed for Python 1.5.2
driver
run_main(): Play some games to get Mailman's special cgi.py
module. We import it from Mailman.pythonlib.cgi, but then we jam
this module into sys.modules['cgi'] so all those imports in all
those Mailman.Cgi scripts get our special one (without having to
hack all those scripts!)
Diffstat (limited to 'Mailman/pythonlib/cgi.py')
| -rwxr-xr-x | Mailman/pythonlib/cgi.py | 26 |
1 files changed, 24 insertions, 2 deletions
diff --git a/Mailman/pythonlib/cgi.py b/Mailman/pythonlib/cgi.py index 108310ebd..ab6dda843 100755 --- a/Mailman/pythonlib/cgi.py +++ b/Mailman/pythonlib/cgi.py @@ -828,9 +828,23 @@ class FieldStorage: self.filename = pdict['filename'] # Process content-type header - ctype, pdict = "text/plain", {} + # + # Honor any existing content-type header. But if there is no + # content-type header, use some sensible defaults. Assume + # outerboundary is "" at the outer level, but something non-false + # inside a multi-part. The default for an inner part is text/plain, + # but for an outer part it should be urlencoded. This should catch + # bogus clients which erroneously forget to include a content-type + # header. + # + # See below for what we do if there does exist a content-type header, + # but it happens to be something we don't understand. if self.headers.has_key('content-type'): ctype, pdict = parse_header(self.headers['content-type']) + elif self.outerboundary: + ctype, pdict = "text/plain", {} + else: + ctype, pdict = 'application/x-www-form-urlencoded', {} self.type = ctype self.type_options = pdict self.innerboundary = "" @@ -853,8 +867,16 @@ class FieldStorage: self.read_urlencoded() elif ctype[:10] == 'multipart/': self.read_multi(environ, keep_blank_values, strict_parsing) - else: + elif self.outerboundary: + # we're in an inner part, but the content-type wasn't something we + # understood. default to read_single() because the resulting + # FieldStorage won't be a mapping (and doesn't need to be). self.read_single() + else: + # we're in an outer part, but the content-type wasn't something we + # understood. we still want the resulting FieldStorage to be a + # mapping, so parse it as if it were urlencoded + self.read_urlencoded() def __repr__(self): """Return a printable representation.""" |
