/** * @param Request $request * @return BuzzRequest */ protected function prepareRequest(Request $request) { $buzzRequest = new BuzzRequest($request->getMethod(), $request->getUrl()->getResource(), $request->getUrl()->getHost()); $buzzRequest->setProtocolVersion($request->getProtocolVersion()); $buzzRequest->setHeaders(HeaderConverter::convertAssociativeToRaw($this->prepareHeaders($request))); $buzzRequest->setContent($request->getContent()); return $buzzRequest; }
/** * Converts a PSR request into a BuzzRequest request. * * @param RequestInterface $request * * @return BuzzRequest */ private function createRequest(RequestInterface $request) { $buzzRequest = new BuzzRequest(); $buzzRequest->setMethod($request->getMethod()); $buzzRequest->fromUrl($request->getUri()->__toString()); $buzzRequest->setProtocolVersion($request->getProtocolVersion()); $buzzRequest->setContent((string) $request->getBody()); $this->addPsrHeadersToBuzzRequest($request, $buzzRequest); return $buzzRequest; }
public function __construct(Response $response, Request $request, Curl $client) { $this->response = $response; $request->setProtocolVersion(1.1); $request->addHeader('Content-Type: application/json'); $this->request = $request; $client->setTimeout(5); $client->setIgnoreErrors(true); $this->client = $client; }
public function testToStringFormatsTheRequest() { $request = new Request('POST', '/resource/123', 'http://example.com'); $request->setProtocolVersion(1.1); $request->addHeader('Content-Type: application/x-www-form-urlencoded'); $request->setContent('foo=bar&bar=baz'); $expected = "POST /resource/123 HTTP/1.1\r\n"; $expected .= "Host: http://example.com\r\n"; $expected .= "Content-Type: application/x-www-form-urlencoded\r\n"; $expected .= "\r\n"; $expected .= "foo=bar&bar=baz\r\n"; $this->assertEquals($expected, (string) $request); }
public function testDigestAuthHeader() { $request = new Message\Request(); $request->setMethod('GET'); $request->setResource('/auth-digest'); $request->setHost('http://test.webdav.org'); $request->setProtocolVersion('1.1'); $response = new Message\Response(); $response->setHeaders(array("Date: Wed, 24 Jun 2015 21:49:39 GMT", "Server: Apache/2.0.54 (Debian GNU/Linux) DAV/2 SVN/1.3.2", "WWW-Authenticate: Digest realm=\"test\", nonce=\"5PvRe0oZBQA=874ad6aea3519069f30dfc704e594dde6e01b2a6\", algorithm=MD5, domain=\"/auth-digest/\", qop=\"auth\"", "Content-Length: 401", "Content-Type: text/html; charset=iso-8859-1")); $response->setContent("<!DOCTYPE HTML PUBLIC \"-//IETF//DTD HTML 2.0//EN\">\n<html><head>\n<title>401 Authorization Required</title>\n</head><body>\n<h1>Authorization Required</h1>\n<p>This server could not verify that you\nare authorized to access the document\nrequested. Either you supplied the wrong\ncredentials (e.g., bad password), or your\nbrowser doesn\\'t understand how to supply\nthe credentials required.</p>\n</body></html>"); // Simulate the First Request/Response, where the server returns 401 $listener = new DigestAuthListener('user1', 'user1'); $listener->preSend($request); $listener->postSend($request, $response); // Simulate sending the second Request using the calculated Authorization Header $request = new Message\Request(); $request->setMethod('GET'); $request->setResource('/auth-digest'); $request->setHost('http://test.webdav.org'); $request->setProtocolVersion('1.1'); $this->assertEmpty($request->getHeader('Authorization')); $listener->preSend($request); $this->assertEquals('Digest username="******", realm="test", nonce="5PvRe0oZBQA=874ad6aea3519069f30dfc704e594dde6e01b2a6", response="b2cf05a5d3f51d84a8866309aed6cb5d", uri="/auth-digest"', $request->getHeader('Authorization')); }