pretorien / request
RequestBundle allows you to send public HTTP requests or through a proxy
Installs: 3
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- nyholm/psr7: ^1.2
- psr/log: ^1.1
- symfony/browser-kit: ^5.0
- symfony/config: ^5.0
- symfony/dom-crawler: ^5.0
- symfony/http-client: ^5.0
- symfony/options-resolver: ^5.0
- symfony/orm-pack: ^1.0
This package is auto-updated.
Last update: 2025-03-08 17:58:02 UTC
README
This repository contains Request bundle which helps you to send requests in a public way or behind a proxy. Several commands allow you to fetching and checking proxies.
This bundle based on Symfony HttpClient Component
Installation
Installation using composer :
composer require pretorien/request
Then, enable the bundle by adding it to the list of registered bundles in the config/bundles.php
file of your project:
<?php return [ // ... Pretorien\RequestBundle\RequestBundle::class => ['all' => true], ];
It's necessary to create a Proxy entity extending the bundle one.
<?php // src/Entity/Proxy.php namespace App\Entity; use Doctrine\ORM\Mapping as ORM; use Pretorien\RequestBundle\Entity\Proxy as BaseProxy; /** * @ORM\Entity * @ORM\ChangeTrackingPolicy("DEFERRED_EXPLICIT") */ class Proxy extends BaseProxy { /** * @ORM\Id * @ORM\Column(type="integer") * @ORM\GeneratedValue(strategy="AUTO") */ protected $id; }
Finally, you must update your database :
php bin/console doctrine:schema:update --force
Configuration
request: proxy: nordvpn: username: ~ password: ~ api: 'https://api.nordvpn.com/v1/servers/recommendations?filters\[servers_groups\]=5&filters\[servers_technologies\]=9&filters\[country_id\]=74' class: model: proxy: App\Entity\Proxy
Usage
This bundle provides several commands under the pretorien:proxy: namespace. List them all executing this command:
php bin/console list pretorien:proxy pretorien:proxy:check Check proxies latency pretorien:proxy:fetch Fetch proxies pretorien:proxy:list List proxies
Fetching Proxies
First of all, you must initialize the proxy list with the pretorien:proxy:fetch
command.
This is based on fetchers allowing to retrieve data from provides. Currently there is only one : NordVPN.
You must therefore configure your cretendials as indicated above.
This command has several options :
--fetcher=FETCHER Which provider do you want to use? [default: ["nordvpn"]] (multiple values allowed) --force-check Force latency check after fetching --renew Delete old proxies before fetching --drop-failed[=DROP-FAILED] Drop proxies with more than failures ? [default: 10]
Checking Latency
The pretorien:proxy:check
command checks existing proxies health and checks if these are anonymous.
Making Requests
RequestService contains all the methods allowing to sending private or public requests. You can use this service directly in your controllers via Autowiring :
use Pretorien\RequestBundle\Service\RequestService; /* ... */ public function myFunction(RequestService $requestService) { /* ... */ }
Sending public and private Requests
RequestService provides a single request() method to perform all kinds of HTTP requests. All private requests are automatically configured with a proxy.
use Pretorien\RequestBundle\Service\RequestService; use Pretorien\RequestBundle\Http\Request\Request; /* ... */ public function myFunction(RequestService $requestService) { $url = "http://www.example.com"; $options = []; $response = $requestService->request($url, Request::METHOD_GET, Request::TYPE_PUBLIC, $options); $response = $requestService->request($url, Request::METHOD_POST, Request::TYPE_PUBLIC, $options); $response = $requestService->request($url, Request::METHOD_GET, Request::TYPE_PRIVATE, $options); $response = $requestService->request($url, Request::METHOD_POST, Request::TYPE_PRIVATE, $options); /* ... */ }
Two aliases make it easier to send requests
use Pretorien\RequestBundle\Service\RequestService; use Pretorien\RequestBundle\Http\Request\Request; /* ... */ public function myFunction(RequestService $requestService) { $url = "http://www.example.com"; $options = []; $response = $requestService->publicRequest($url, Request::METHOD_GET, $options); $response = $requestService->privateRequest($url, Request::METHOD_GET, $options); /* ... */ }
These methods return an ResponseInterface object. Responses are always asynchronous, so that the call to the method returns immediately instead of waiting to receive the response:
use Pretorien\RequestBundle\Service\RequestService; /* ... */ public function myFunction(RequestService $requestService) { $url = "http://www.example.com"; $response = $requestService->privateRequest($url, [$method, $options]); // getting the response headers waits until they arrive $contentType = $response->getHeaders()['content-type'][0]; // trying to get the response contents will block the execution until // the full response contents are received $contents = $response->getContent(); }
Sending concurrent Requests
Many requests can be sent simultaneously thanks to PoolRequest. RequestService provides a single createPoolRequest() method to create a new PoolRequest object having an addRequest method. This allows you to add requests (private or public) to the pool.
Finally, the sendPoolRequest method will allow you to send this pool.
Creating Pool Request
use Pretorien\RequestBundle\Service\RequestService; use Pretorien\RequestBundle\Http\Response\PoolResponse; use Pretorien\RequestBundle\Http\Request\PrivateRequest; use Pretorien\RequestBundle\Http\Request\PublicRequest; /* ... */ public function myFunction(RequestService $requestService) { $url = "http://www.example.com"; $pool = $requestService->createPoolRequest(); $privateRequest = new PrivateRequest($url); $publicRequest = new PublicRequest($url); $pool->addRequest($privateRequest); $pool->addRequest($publicRequest); $poolResponse = $requestService->sendPoolRequest($pool); }
Processing Responses
The response returned by sendPoolRequest method is an object of type PoolResponse which is iterable and provide ResponseInterface object.
use Pretorien\RequestBundle\Service\RequestService; use Pretorien\RequestBundle\Http\Response\PoolResponse; use Pretorien\RequestBundle\Http\Request\PrivateRequest; use Pretorien\RequestBundle\Http\Request\PublicRequest; /* ... */ public function myFunction(RequestService $requestService) { $url = "http://www.example.com"; $pool = $requestService->createPoolRequest(); $privateRequest = new PrivateRequest($url); $publicRequest = new PublicRequest($url); $pool->addRequest($privateRequest); $pool->addRequest($publicRequest); $poolResponse = $requestService->sendPoolRequest($pool); $responses = $poolResponse->getContents(); foreach ($responses[PoolResponse::RESPONSES_SUCCESSFUL] as $response) { $content = $response['content']; $request = $response['request']; $httpClientResponse = $response['response']; } foreach ($responses[PoolResponse::RESPONSES_FAILED] as $response) { $exception = $response['exception']; $request = $response['request']; $httpClientResponse = $response['response']; } }
License and contributors
Published under the MIT, read the LICENSE file for more information.