1 | <?php |
||
20 | class Curl extends AbstractTransport |
||
21 | { |
||
22 | /** |
||
23 | * cURL error map. |
||
24 | * |
||
25 | * @var array |
||
26 | */ |
||
27 | protected static $errorCategoryMap = [ |
||
28 | CURLE_FTP_WEIRD_SERVER_REPLY => 'FTP', |
||
29 | CURLE_FTP_ACCESS_DENIED => 'FTP', |
||
30 | CURLE_FTP_USER_PASSWORD_INCORRECT => 'FTP', |
||
31 | CURLE_FTP_WEIRD_PASS_REPLY => 'FTP', |
||
32 | CURLE_FTP_WEIRD_USER_REPLY => 'FTP', |
||
33 | CURLE_FTP_WEIRD_PASV_REPLY => 'FTP', |
||
34 | CURLE_FTP_WEIRD_227_FORMAT => 'FTP', |
||
35 | CURLE_FTP_CANT_GET_HOST => 'FTP', |
||
36 | CURLE_FTP_CANT_RECONNECT => 'FTP', |
||
37 | CURLE_FTP_COULDNT_SET_BINARY => 'FTP', |
||
38 | CURLE_FTP_COULDNT_RETR_FILE => 'FTP', |
||
39 | CURLE_FTP_WRITE_ERROR => 'FTP', |
||
40 | CURLE_FTP_QUOTE_ERROR => 'FTP', |
||
41 | CURLE_FTP_COULDNT_STOR_FILE => 'FTP', |
||
42 | CURLE_FTP_COULDNT_SET_ASCII => 'FTP', |
||
43 | CURLE_FTP_PORT_FAILED => 'FTP', |
||
44 | CURLE_FTP_COULDNT_USE_REST => 'FTP', |
||
45 | CURLE_FTP_COULDNT_GET_SIZE => 'FTP', |
||
46 | CURLE_FTP_BAD_DOWNLOAD_RESUME => 'FTP', |
||
47 | CURLE_FTP_SSL_FAILED => 'FTP', |
||
48 | CURLE_SSL_CONNECT_ERROR => 'SSL', |
||
49 | CURLE_SSL_PEER_CERTIFICATE => 'SSL', |
||
50 | CURLE_SSL_ENGINE_NOTFOUND => 'SSL', |
||
51 | CURLE_SSL_ENGINE_SETFAILED => 'SSL', |
||
52 | CURLE_SSL_CERTPROBLEM => 'SSL', |
||
53 | CURLE_SSL_CIPHER => 'SSL', |
||
54 | CURLE_SSL_CACERT => 'SSL', |
||
55 | CURLE_LDAP_CANNOT_BIND => 'LDAP', |
||
56 | CURLE_LDAP_SEARCH_FAILED => 'LDAP', |
||
57 | CURLE_LDAP_INVALID_URL => 'LDAP', |
||
58 | CURLE_COULDNT_RESOLVE_PROXY => 'proxy', |
||
59 | ]; |
||
60 | |||
61 | /** |
||
62 | * Default options. |
||
63 | * |
||
64 | * @var array |
||
65 | */ |
||
66 | protected static $defaultOptions = [ |
||
67 | CURLOPT_VERBOSE => false, |
||
68 | CURLOPT_HTTP_VERSION => 1.1, |
||
69 | CURLOPT_USERAGENT => self::class, |
||
70 | CURLOPT_CONNECTTIMEOUT => 60, |
||
71 | CURLOPT_TIMEOUT => 60, |
||
72 | CURLOPT_CRLF => false, |
||
73 | CURLOPT_SSLVERSION => 0, |
||
74 | CURLOPT_SSL_VERIFYPEER => true, |
||
75 | CURLOPT_SSL_VERIFYHOST => 2, |
||
76 | CURLOPT_AUTOREFERER => true, |
||
77 | CURLOPT_FOLLOWLOCATION => true, |
||
78 | CURLOPT_MAXREDIRS => 10, |
||
79 | CURLOPT_UNRESTRICTED_AUTH => false, |
||
80 | CURLOPT_RETURNTRANSFER => true, |
||
81 | CURLOPT_HEADER => true, |
||
82 | CURLOPT_FORBID_REUSE => false, |
||
83 | CURLOPT_FRESH_CONNECT => false, |
||
84 | CURLOPT_MAXCONNECTS => 5, |
||
85 | ]; |
||
86 | |||
87 | /** |
||
88 | * cURL resource handler. |
||
89 | * |
||
90 | * @var resource |
||
91 | */ |
||
92 | private $handler; |
||
93 | |||
94 | /** |
||
95 | * Create cURL transport manager. |
||
96 | * |
||
97 | * @param array $options |
||
98 | * |
||
99 | * @throws \Jgut\Spiral\Exception\OptionException |
||
100 | */ |
||
101 | public function __construct(array $options = []) |
||
105 | |||
106 | /** |
||
107 | * Create cURL transport manager with default options. |
||
108 | * |
||
109 | * @return static |
||
110 | */ |
||
111 | public static function createFromDefaults() |
||
115 | |||
116 | /** |
||
117 | * {@inheritdoc} |
||
118 | * |
||
119 | * @throws TransportException |
||
120 | */ |
||
121 | public function request($method, $uri, array $headers = [], $requestBody = null) |
||
152 | |||
153 | /** |
||
154 | * Create or reuse existing handle. |
||
155 | * |
||
156 | * @return resource |
||
157 | */ |
||
158 | protected function resetHandler() |
||
177 | |||
178 | /** |
||
179 | * Isolate curl execution. |
||
180 | * |
||
181 | * @return string |
||
182 | */ |
||
183 | protected function execute() |
||
187 | |||
188 | /** |
||
189 | * Set HTTP method on handler. |
||
190 | * |
||
191 | * @param string $method |
||
192 | */ |
||
193 | protected function setMethod($method) |
||
213 | |||
214 | /** |
||
215 | * Set cURL options on handler. |
||
216 | * |
||
217 | * @param OptionInterface[] $options |
||
218 | */ |
||
219 | protected function forgeOptions(array $options) |
||
229 | |||
230 | /** |
||
231 | * Set HTTP headers on handler. |
||
232 | * |
||
233 | * @param array $headers |
||
234 | */ |
||
235 | protected function forgeHeaders(array $headers) |
||
245 | |||
246 | /** |
||
247 | * {@inheritdoc} |
||
248 | */ |
||
249 | public function responseInfo($option = null) |
||
261 | |||
262 | /** |
||
263 | * Always free resources on destruction. |
||
264 | */ |
||
265 | public function __destruct() |
||
269 | |||
270 | /** |
||
271 | * {@inheritdoc} |
||
272 | */ |
||
273 | public function close() |
||
281 | } |
||
282 |