Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/phpcurl/curlwrapper
The simplest OOP cURL wrapper for PHP
https://github.com/phpcurl/curlwrapper
curl curl-multi curlwrapper dependency-injection injectable oop
Last synced: 2 months ago
JSON representation
The simplest OOP cURL wrapper for PHP
- Host: GitHub
- URL: https://github.com/phpcurl/curlwrapper
- Owner: phpcurl
- License: mit
- Created: 2016-02-03T05:46:41.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2020-01-31T07:29:44.000Z (almost 5 years ago)
- Last Synced: 2024-08-10T11:28:29.418Z (5 months ago)
- Topics: curl, curl-multi, curlwrapper, dependency-injection, injectable, oop
- Language: PHP
- Homepage: https://packagist.org/packages/phpcurl/curlwrapper
- Size: 48.8 KB
- Stars: 11
- Watchers: 3
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# CurlWrapper for PHP
[![Total Downloads](https://img.shields.io/packagist/dt/phpcurl/curlwrapper.svg)](https://packagist.org/packages/phpcurl/curlwrapper)
[![Latest Stable Version](https://img.shields.io/packagist/v/phpcurl/curlwrapper.svg)](https://packagist.org/packages/phpcurl/curlwrapper)
[![Travis Build](https://travis-ci.org/phpcurl/curlwrapper.svg?branch=master)](https://travis-ci.org/phpcurl/curlwrapper)
[![SensioLabs Insight](https://img.shields.io/sensiolabs/i/f6dd716c-7729-46f2-903f-12a53e427841.svg)](https://insight.sensiolabs.com/projects/f6dd716c-7729-46f2-903f-12a53e427841)The simplest OOP-style wrapper for the standard php curl functions with no external dependencies.
The main purpose is to make code that uses curl calls testable.
We do it by injecting the Curl object as a dependency instead of calling curl functions directly.Hard-coded dependencies. Not testable.
```php
class MyApiClient {
...
function call($url)
{
$ch = curl_init($url);
curl_set_opt($ch, /*...*/)
return curl_exec($ch);
}
}
```Testable code. Curl object is injected, so can be easily mocked in PHPUnit.
```php
class MyApiClient {
private $curl;
function __construct(\PHPCurl\CurlWrapper\CurlInterface $curl)
{
$this->curl = $curl;
}
//...
function call($url)
{
$this->curl->init($url);
$this->curl->setOpt(/*...*/)
return $this->curl->exec();
}
}
```## Install
Via [composer](https://getcomposer.org):
`$ composer require "phpcurl/curlwrapper"`## Basic usage examples. Classic vs OOP style
### Curl
| Classic | OOP |
| --- | --- |
| `$h = curl_init($url)` | `$curl = new Curl(); $curl->init($url)` |
| `curl_close($h)` | `unset($curl)` |
| `$e = curl_errno($h)` | `$e = $curl->errno()` |
| `$e = curl_error($h)` | `$e = $curl->error()` |
| `$i = curl_getinfo($h, $opt)` | `$i = $curl->getInfo($opt)` |
| `curl_setopt($h, $opt, $val)` | `$curl->setOpt($opt, $val)` |
| `curl_setopt_array($h, $array)` | `$curl->setOptArray($array)` |
| `curl_version($age)` | `$curl->version($age)` |
| `curl_strerror($errornum)` | `$curl->strerror($errornum)` |
| `$h2 = curl_copy_handle($h)` | `$curl2 = clone($curl)` |
| `$result = curl_exec($h)` | `$result = $curl->exec()` |
| `$res = curl_pause($h, $mask)` | `$res = $curl->pause($mask)` |
| `$res = curl_escape($h, $str)` | `$res = $curl->escape($str)` |
| `$res = curl_unescape($h, $str)` | `$res = $curl->unescape($str)` |### CurlMulti
| Classic | OOP |
| --- | --- |
| `curl_multi_init()` | `$cm = new CurlMulti(); $cm->init()` |
| `curl_multi_close($h)` | `unset($cm)` |
| `$i = curl_multi_add_handle($mh, $ch)` | `$i = $cm->add($curl)` |
| `$i = curl_multi_remove_handle($mh, $ch)` | `$i = $cm->remove($curl)` |
| `$i = curl_multi_exec($mh, $running)` | `$i = $cm->exec($running)` |
| `$s = curl_multi_getcontent($ch)` | `$s = $cm->getContent($curl)` |
| `$a = curl_multi_info_read($mh, $msgs)` | `$a = $cm->infoRead($msgs)` |
| `$i = curl_multi_select($mh, $timeout)` | `$i = $cm->select($timeout)` |
| `$r = curl_multi_setopt($h, $opt, $val)` | `$r = $cm->setOpt($opt, $val)` |### CurlShare
| Classic | OOP |
| --- | --- |
| `curl_share_init()` | `$cs = new CurlShare(); $cs->init()` |
| `curl_share_close($h)` | `unset($cs)` |
| `$r = curl_multi_setopt($h, $opt, $val)` | `$r = $cs->setOpt($opt, $val)` |