Пример #1
0
 def locateChild(self, ctx, segments):
     from hack.web2.server import parsePOSTData
     request = iweb.IRequest(ctx)
     if request.method == "POST":
         return parsePOSTData(request).addCallback(
             lambda x: self.__original.locateChild(ctx, segments))
     return self.__original.locateChild(ctx, segments)
Пример #2
0
 def locateChild(self, ctx, segments):
     from hack.web2.server import parsePOSTData
     request = iweb.IRequest(ctx)
     if request.method == "POST":
         return parsePOSTData(request).addCallback(
             lambda x: self.__original.locateChild(ctx, segments))
     return self.__original.locateChild(ctx, segments)
Пример #3
0
    def test_maxFields(self):
        """
        Check that the C{maxSize} parameter makes the parsing raise an
        exception if the data contains too many fields.
        """
        ctype = http_headers.MimeType("multipart", "form-data", (("boundary", "---xyz"),))
        content = """-----xyz\r
Content-Disposition: form-data; name="foo"\r
\r
Foo Bar\r
-----xyz\r
Content-Disposition: form-data; name="foo"\r
\r
Baz\r
-----xyz\r
Content-Disposition: form-data; name="file"; filename="filename"\r
Content-Type: text/html\r
\r
blah\r
-----xyz\r
Content-Disposition: form-data; name="file"; filename="filename"\r
Content-Type: text/plain\r
\r
bleh\r
-----xyz--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", http_headers.Headers({"content-type": ctype}), content)

        def cb(res):
            self.assertEquals(res.response.description, "Maximum number of fields 3 exceeded")

        return self.assertFailure(server.parsePOSTData(request, maxFields=3), http.HTTPError).addCallback(cb)
Пример #4
0
    def test_multipart(self):
        """
        Test parsing data in multipart format: it should fill the C{files}
        attribute.
        """
        ctype = http_headers.MimeType("multipart", "form-data", (("boundary", "---weeboundary"),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", http_headers.Headers({"content-type": ctype}), content)

        def cb(ign):
            self.assertEquals(request.args, {})
            self.assertEquals(request.files.keys(), ["FileNameOne"])
            self.assertEquals(
                request.files.values()[0][0][:2], ("myfilename", http_headers.MimeType("text", "html", {}))
            )
            f = request.files.values()[0][0][2]
            self.assertEquals(f.read(), "my great content wooo")

        return server.parsePOSTData(request).addCallback(cb)
Пример #5
0
    def test_multipartMaxSize(self):
        """
        Check that the C{maxSize} parameter makes the parsing raise an
        exception if the data is too big.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'), ))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo
and even more and more\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/",
                                http_headers.Headers({'content-type': ctype}),
                                content)

        def cb(res):
            self.assertEquals(res.response.description,
                              "Maximum length of 10 bytes exceeded.")

        return self.assertFailure(server.parsePOSTData(request, maxSize=10),
                                  http.HTTPError).addCallback(cb)
Пример #6
0
    def test_multipart(self):
        """
        Test parsing data in multipart format: it should fill the C{files}
        attribute.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'), ))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/",
                                http_headers.Headers({'content-type': ctype}),
                                content)

        def cb(ign):
            self.assertEquals(request.args, {})
            self.assertEquals(request.files.keys(), ['FileNameOne'])
            self.assertEquals(
                request.files.values()[0][0][:2],
                ('myfilename', http_headers.MimeType('text', 'html', {})))
            f = request.files.values()[0][0][2]
            self.assertEquals(f.read(), "my great content wooo")

        return server.parsePOSTData(request).addCallback(cb)
Пример #7
0
 def test_wrongContentType(self):
     """
     Check that a content-type not handled raise a C{http.HTTPError}.
     """
     ctype = http_headers.MimeType("application", "foobar")
     content = "key=value&multiple=two+words&multiple=more%20words"
     root = resource.Resource()
     request = SimpleRequest(server.Site(root), "GET", "/", http_headers.Headers({"content-type": ctype}), content)
     return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
Пример #8
0
    def http_POST(self, request):
        """
        Respond to a POST request.
        Reads and parses the incoming body data then calls L{render}.

        @param request: the request to process.
        @return: an object adaptable to L{iweb.IResponse}.
        """
        return server.parsePOSTData(request,
            self.maxMem, self.maxFields, self.maxSize
            ).addCallback(lambda res: self.render(request))
Пример #9
0
 def test_wrongContentType(self):
     """
     Check that a content-type not handled raise a C{http.HTTPError}.
     """
     ctype = http_headers.MimeType('application', 'foobar')
     content = "key=value&multiple=two+words&multiple=more%20words"
     root = resource.Resource()
     request = SimpleRequest(server.Site(root), "GET", "/",
                             http_headers.Headers({'content-type': ctype}),
                             content)
     return self.assertFailure(server.parsePOSTData(request),
                               http.HTTPError)
Пример #10
0
    def test_noContentType(self):
        """
        Parsing a request without content-type should succeed but should not
        fill the C{args} and C{files} attributes of the request.
        """
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", content="foo")

        def cb(ign):
            self.assertEquals(request.args, {})
            self.assertEquals(request.files, {})

        return server.parsePOSTData(request).addCallback(cb)
Пример #11
0
    def test_noContentType(self):
        """
        Parsing a request without content-type should succeed but should not
        fill the C{args} and C{files} attributes of the request.
        """
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", content="foo")

        def cb(ign):
            self.assertEquals(request.args, {})
            self.assertEquals(request.files, {})

        return server.parsePOSTData(request).addCallback(cb)
Пример #12
0
    def test_urlencoded(self):
        """
        Test parsing data in urlencoded format: it should end in the C{args}
        attribute.
        """
        ctype = http_headers.MimeType("application", "x-www-form-urlencoded")
        content = "key=value&multiple=two+words&multiple=more%20words"
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", http_headers.Headers({"content-type": ctype}), content)

        def cb(ign):
            self.assertEquals(request.files, {})
            self.assertEquals(request.args, {"multiple": ["two words", "more words"], "key": ["value"]})

        return server.parsePOSTData(request).addCallback(cb)
Пример #13
0
    def test_otherErrors(self):
        """
        Test that errors durign parsing other than C{MimeFormatError} are
        propagated.
        """
        ctype = http_headers.MimeType("multipart", "form-data", (("boundary", "---weeboundary"),))
        # XXX: maybe this is not a good example
        # parseContentDispositionFormData could handle this problem
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename and invalid data \r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", http_headers.Headers({"content-type": ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), ValueError)
Пример #14
0
    def test_multipartWithNoBoundary(self):
        """
        If the boundary type is not specified, parsing should fail with a
        C{http.HTTPError}.
        """
        ctype = http_headers.MimeType("multipart", "form-data")
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", http_headers.Headers({"content-type": ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
Пример #15
0
    def test_mimeParsingError(self):
        """
        A malformed content should result in a C{http.HTTPError}.
        
        The tested content has an invalid closing boundary.
        """
        ctype = http_headers.MimeType("multipart", "form-data", (("boundary", "---weeboundary"),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeoundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", http_headers.Headers({"content-type": ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
Пример #16
0
    def test_otherErrors(self):
        """
        Test that errors durign parsing other than C{MimeFormatError} are
        propagated.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'), ))
        # XXX: maybe this is not a good example
        # parseContentDispositionFormData could handle this problem
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename and invalid data \r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/",
                                http_headers.Headers({'content-type': ctype}),
                                content)
        return self.assertFailure(server.parsePOSTData(request), ValueError)
Пример #17
0
    def test_multipartWithNoBoundary(self):
        """
        If the boundary type is not specified, parsing should fail with a
        C{http.HTTPError}.
        """
        ctype = http_headers.MimeType('multipart', 'form-data')
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/",
                                http_headers.Headers({'content-type': ctype}),
                                content)
        return self.assertFailure(server.parsePOSTData(request),
                                  http.HTTPError)
Пример #18
0
    def test_urlencoded(self):
        """
        Test parsing data in urlencoded format: it should end in the C{args}
        attribute.
        """
        ctype = http_headers.MimeType('application', 'x-www-form-urlencoded')
        content = "key=value&multiple=two+words&multiple=more%20words"
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/",
                                http_headers.Headers({'content-type': ctype}),
                                content)

        def cb(ign):
            self.assertEquals(request.files, {})
            self.assertEquals(request.args, {
                'multiple': ['two words', 'more words'],
                'key': ['value']
            })

        return server.parsePOSTData(request).addCallback(cb)
Пример #19
0
    def test_multipartMaxSize(self):
        """
        Check that the C{maxSize} parameter makes the parsing raise an
        exception if the data is too big.
        """
        ctype = http_headers.MimeType("multipart", "form-data", (("boundary", "---weeboundary"),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo
and even more and more\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/", http_headers.Headers({"content-type": ctype}), content)

        def cb(res):
            self.assertEquals(res.response.description, "Maximum length of 10 bytes exceeded.")

        return self.assertFailure(server.parsePOSTData(request, maxSize=10), http.HTTPError).addCallback(cb)
Пример #20
0
    def test_mimeParsingError(self):
        """
        A malformed content should result in a C{http.HTTPError}.
        
        The tested content has an invalid closing boundary.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'), ))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeoundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/",
                                http_headers.Headers({'content-type': ctype}),
                                content)
        return self.assertFailure(server.parsePOSTData(request),
                                  http.HTTPError)
Пример #21
0
    def test_maxFields(self):
        """
        Check that the C{maxSize} parameter makes the parsing raise an
        exception if the data contains too many fields.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---xyz'), ))
        content = """-----xyz\r
Content-Disposition: form-data; name="foo"\r
\r
Foo Bar\r
-----xyz\r
Content-Disposition: form-data; name="foo"\r
\r
Baz\r
-----xyz\r
Content-Disposition: form-data; name="file"; filename="filename"\r
Content-Type: text/html\r
\r
blah\r
-----xyz\r
Content-Disposition: form-data; name="file"; filename="filename"\r
Content-Type: text/plain\r
\r
bleh\r
-----xyz--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/",
                                http_headers.Headers({'content-type': ctype}),
                                content)

        def cb(res):
            self.assertEquals(res.response.description,
                              "Maximum number of fields 3 exceeded")

        return self.assertFailure(server.parsePOSTData(request, maxFields=3),
                                  http.HTTPError).addCallback(cb)
Пример #22
0
 def renderHTTP(self, ctx):
     from hack.web2.server import parsePOSTData
     request = iweb.IRequest(ctx)
     if request.method == "POST":
         return parsePOSTData(request).addCallback(self.__reallyRender, ctx)
     return self.__reallyRender(None, ctx)
Пример #23
0
 def renderHTTP(self, ctx):
     from hack.web2.server import parsePOSTData
     request = iweb.IRequest(ctx)
     if request.method == "POST":
         return parsePOSTData(request).addCallback(self.__reallyRender, ctx)
     return self.__reallyRender(None, ctx)