public function testCurlException() { $request = HttpRequest::create()->setUrl(HttpUrl::create()->parse('http://nonexistentdomain.xyz'))->setMethod(HttpMethod::get()); try { $response = CurlHttpClient::create()->setTimeout(3)->send($request); $this->fail(); } catch (NetworkException $e) { $this->assertContains('curl error', $e->getMessage()); } }
public function testSendingNotExistsFile() { $files = array('file' => $this->getFileNotExists()); $request = $this->spawnRequest(HttpMethod::post())->setFiles($files); try { $this->spawnClient()->send($request); $this->fail('expected exception about not exists file'); } catch (WrongArgumentException $e) { $this->assertStringStartsWith('couldn\'t access to file with path:', $e->getMessage()); } }
/** * @return HttpRequest **/ public static function createFromGlobals() { $request = static::create()->setGet($_GET)->setPost($_POST)->setServer($_SERVER)->setCookie($_COOKIE)->setFiles($_FILES); if (isset($_SESSION)) { $request->setSession($_SESSION); } foreach ($_SERVER as $name => $value) { if (strpos($name, 'HTTP_') === 0) { $name = str_replace('_', '-', substr($name, 5)); $request->setHeaderVar($name, $value); } } if ($request->hasServerVar('CONTENT_TYPE') && $request->getServerVar('CONTENT_TYPE') !== 'application/x-www-form-urlencoded') { $request->setBody(file_get_contents('php://input')); } $request->setMethod(HttpMethod::createByName($request->getServerVar('REQUEST_METHOD'))); return $request; }
protected function loadXRDS($url) { $response = $this->httpClient->send(HttpRequest::create()->setHeaderVar('Accept', self::HEADER_ACCEPT)->setMethod(HttpMethod::get())->setUrl(HttpUrl::create()->parse($url))); if ($response->getStatus()->getId() != 200) { throw new OpenIdException('can\'t fetch document'); } $this->parseXRDS($response->getBody()); return $this; }
/** * check_authentication mode request **/ private function checkAuthentication(array $parameters, $manager = null) { $credentials = new OpenIdCredentials(HttpUrl::create()->parse($parameters['openid.identity']), $this->httpClient); $request = HttpRequest::create()->setMethod(HttpMethod::post())->setUrl($credentials->getServer()); if (isset($parameters['openid.invalidate_handle']) && $manager) { $request->setPostVar('openid.invalidate_handle', $parameters['openid.invalidate_handle']); } foreach (explode(',', $parameters['openid.signed']) as $key) { $key = 'openid.' . $key; $request->setPostVar($key, $parameters[$key]); } $request->setPostVar('openid.mode', 'check_authentication')->setPostVar('openid.assoc_handle', $parameters['openid.assoc_handle'])->setPostVar('openid.sig', $parameters['openid.sig'])->setPostVar('openid.signed', $parameters['openid.signed']); $response = $this->httpClient->send($request); if ($response->getStatus()->getId() != HttpStatus::CODE_200) { throw new OpenIdException('bad response code from server'); } $result = $this->parseKeyValueFormat($response->getBody()); if (!isset($result['is_valid']) || $result['is_valid'] !== 'true' && $result['is_valid'] !== 'false') { throw new OpenIdException('strange response given'); } if ($result['is_valid'] === 'true') { if (isset($result['invalidate_handle']) && $manager) { $manager->purgeByHandle($result['invalidate_handle']); } return true; } elseif ($result['is_valid'] === 'false') { return false; } Assert::isUnreachable(); }