27 Commits
1.0.8 ... 1.1.1

Author SHA1 Message Date
Junade
a3a346ccb2 Merge pull request #62 from powerkent/fix-refresh-cache
fix: Cloudflare Api doesn't like empty tags
2018-08-28 15:01:57 +01:00
Junade
deb420d087 Update Zones.php 2018-08-28 14:58:25 +01:00
Junade
640b787540 Merge branch 'master' into fix-refresh-cache 2018-08-28 14:53:47 +01:00
Junade
8df0ec5511 Merge pull request #63 from maximivanov/feature/purgeCacheHosts
Add support for host-based cache purge
2018-08-28 14:49:49 +01:00
Junade
938065cdf3 Merge pull request #64 from mjrider/patch-1
Fixes issue with creating a MX record
2018-08-28 14:49:11 +01:00
Robbert Müller
9076d714f4 Fixes problem with creating an MX record
Fixes #60
php api expects a string and cloudflare api expects a int
this keeps everybody happy without changing API's
2018-08-28 08:47:50 +02:00
Max Ivanov
c9d2782b88 Add support for host-based cache purge 2018-08-23 16:13:56 +01:00
Lemoine
1cca3e0724 fix: Cloudflare Api doesn't like empty tags 2018-08-23 14:54:21 +02:00
Junade
63be6cf154 Merge pull request #54 from darinrandal/refactor-clean
Cleanup, refactoring, and removal of duplicate code
2018-05-19 21:23:57 +01:00
Darin Randal
c06fe79ad0 Removed more object casting 2018-04-12 23:19:09 -04:00
Darin Randal
cca073c809 Code cleanup / Quality of Life updates
Adapter::get, post, put, patch and delete all had non-optional parameters for $headers and $query or $body. These have been made optional. I also re-ordered the parameters as $headers was never used while $query/$body were heavily used. I also condensed and removed some duplicate calls so that every call to Adapter::get/post sends that call to Adapter::request. It could use a magic method to do this but it might make it more difficult to test.
2018-04-12 23:11:04 -04:00
Junade
35ce8eadf1 Merge pull request #51 from cloudflare/SOPS-161
SOPS-161 :: Add Custom Hostname endpoints to cloudflare-php
2018-03-18 23:47:42 -07:00
Junade Ali
d95573976e SOPS-161 :: Lint changes 2018-03-18 23:45:06 -07:00
Junade Ali
3bfd5e17f1 SOPS-161 :: Add Custom Hostname endpoints to cloudflare-php 2018-03-18 23:40:09 -07:00
Junade
19a4f481d3 Merge pull request #48 from anthonysterling/fix/issue-46
Nest payload for forwarding_url page rule action in value block
2018-03-05 14:21:59 -06:00
Junade
9c56941516 Merge pull request #49 from darinrandal/add-priority-for-dns-creation
MX records need ability to set priority
2018-03-05 14:20:38 -06:00
Darin Randal
e18a64e7e4 MX records need ability to set priority 2018-03-05 11:38:18 -05:00
Anthony Sterling
3585dde8ea Fixed merge conflict 2018-02-27 09:45:51 +00:00
Anthony Sterling
730b0c97ee Nest payload for forwarding_url page rule action in value block 2018-02-27 09:40:50 +00:00
Junade
dc53414c2a Merge pull request #45 from darinrandal/master
Fix name of jumpstart zone add option to jump_start
2018-01-30 14:30:46 +13:00
Darin Randal
a628cac283 Update phpdoc to match camelCase variable 2018-01-23 10:09:36 -05:00
Darin Randal
0112425a61 Rename $jump_start to $jumpStart to follow camelCase conventions for variables 2018-01-23 10:08:40 -05:00
Darin Randal
fe854e1b21 Update zone tests to reflect correctly named jumpstart option 2018-01-23 10:01:51 -05:00
Darin Randal
45cb8ee539 Fix name of jumpstart zone add option to jump_start 2018-01-23 09:57:14 -05:00
Junade
cd2fd73cc3 Merge pull request #42 from JorgenPhi/master
AnalyticsDashboard params are not headers
2017-12-26 18:52:26 +00:00
Jorgen Phillips
bd83c6d48a Fix test 2017-12-24 12:48:22 -06:00
Jorgen Phillips
4e3d307bdd AnalyticsDashboard params are not headers
Also 'continuous' needs to be a string for the API to process it.
2017-12-24 12:41:38 -06:00
40 changed files with 621 additions and 263 deletions

View File

@@ -18,7 +18,7 @@ Each API call is provided via a similarly named function within various classes
- [x] [Page Rules](https://support.cloudflare.com/hc/en-us/articles/200168306-Is-there-a-tutorial-for-Page-Rules-) - [x] [Page Rules](https://support.cloudflare.com/hc/en-us/articles/200168306-Is-there-a-tutorial-for-Page-Rules-)
- [x] [Web Application Firewall (WAF)](https://www.cloudflare.com/waf/) - [x] [Web Application Firewall (WAF)](https://www.cloudflare.com/waf/)
- [ ] Virtual DNS Management - [ ] Virtual DNS Management
- [ ] Custom hostnames - [x] Custom hostnames
- [x] Zone Lockdown and User-Agent Block rules - [x] Zone Lockdown and User-Agent Block rules
- [ ] Organization Administration - [ ] Organization Administration
- [x] [Railgun](https://www.cloudflare.com/railgun/) administration - [x] [Railgun](https://www.cloudflare.com/railgun/) administration

View File

@@ -31,46 +31,46 @@ interface Adapter
* RFCs, it is never useful). * RFCs, it is never useful).
* *
* @param string $uri * @param string $uri
* @param array $query * @param array $data
* @param array $headers * @param array $headers
* *
* @return mixed * @return mixed
*/ */
public function get(string $uri, array $query, array $headers): ResponseInterface; public function get(string $uri, array $data = [], array $headers = []): ResponseInterface;
/** /**
* @param string $uri * @param string $uri
* @param array $data
* @param array $headers * @param array $headers
* @param array $body
* *
* @return mixed * @return mixed
*/ */
public function post(string $uri, array $headers, array $body): ResponseInterface; public function post(string $uri, array $data = [], array $headers = []): ResponseInterface;
/** /**
* @param string $uri * @param string $uri
* @param array $data
* @param array $headers * @param array $headers
* @param array $body
* *
* @return mixed * @return mixed
*/ */
public function put(string $uri, array $headers, array $body): ResponseInterface; public function put(string $uri, array $data = [], array $headers = []): ResponseInterface;
/** /**
* @param string $uri * @param string $uri
* @param array $data
* @param array $headers * @param array $headers
* @param array $body
* *
* @return mixed * @return mixed
*/ */
public function patch(string $uri, array $headers, array $body): ResponseInterface; public function patch(string $uri, array $data = [], array $headers = []): ResponseInterface;
/** /**
* @param string $uri * @param string $uri
* @param array $data
* @param array $headers * @param array $headers
* @param array $body
* *
* @return mixed * @return mixed
*/ */
public function delete(string $uri, array $headers, array $body): ResponseInterface; public function delete(string $uri, array $data = [], array $headers = []): ResponseInterface;
} }

View File

@@ -37,79 +37,56 @@ class Guzzle implements Adapter
/** /**
* @inheritDoc * @inheritDoc
*/ */
public function get(string $uri, array $query = [], array $headers = []): ResponseInterface public function get(string $uri, array $data = [], array $headers = []): ResponseInterface
{ {
$response = $this->client->get($uri, ['query' => $query, 'headers' => $headers]); return $this->request('get', $uri, $data, $headers);
$this->checkError($response);
return $response;
} }
/** /**
* @inheritDoc * @inheritDoc
*/ */
public function post(string $uri, array $headers = [], array $body = []): ResponseInterface public function post(string $uri, array $data = [], array $headers = []): ResponseInterface
{ {
$response = $this->client->post( return $this->request('post', $uri, $data, $headers);
$uri,
[
'headers' => $headers,
'json' => $body
]
);
$this->checkError($response);
return $response;
} }
/** /**
* @inheritDoc * @inheritDoc
*/ */
public function put(string $uri, array $headers = [], array $body = []): ResponseInterface public function put(string $uri, array $data = [], array $headers = []): ResponseInterface
{ {
$response = $this->client->put( return $this->request('put', $uri, $data, $headers);
$uri,
[
'headers' => $headers,
'json' => $body
]
);
$this->checkError($response);
return $response;
} }
/** /**
* @inheritDoc * @inheritDoc
*/ */
public function patch(string $uri, array $headers = [], array $body = []): ResponseInterface public function patch(string $uri, array $data = [], array $headers = []): ResponseInterface
{ {
$response = $this->client->patch( return $this->request('patch', $uri, $data, $headers);
$uri,
[
'headers' => $headers,
'json' => $body
]
);
$this->checkError($response);
return $response;
} }
/** /**
* @inheritDoc * @inheritDoc
*/ */
public function delete(string $uri, array $headers = [], array $body = []): ResponseInterface public function delete(string $uri, array $data = [], array $headers = []): ResponseInterface
{ {
$response = $this->client->delete( return $this->request('delete', $uri, $data, $headers);
$uri, }
[
'headers' => $headers, public function request(string $method, string $uri, array $data = [], array $headers = [])
'json' => $body {
] if (!in_array($method, ['get', 'post', 'put', 'patch', 'delete'])) {
); throw new \InvalidArgumentException('Request method must be get, post, put, patch, or delete');
}
$response = $this->client->$method($uri, [
'headers' => $headers,
($method === 'get' ? 'query' : 'json') => $data,
]);
$this->checkError($response); $this->checkError($response);
return $response; return $response;
} }

View File

@@ -132,9 +132,11 @@ class PageRulesActions implements Configurations
throw new ConfigurationsException('Status Codes can only be 301 or 302.'); throw new ConfigurationsException('Status Codes can only be 301 or 302.');
} }
$this->addConfigurationOption('forwarding_url', [ $this->addConfigurationOption("forwarding_url", [
'status_code' => $statusCode, 'value' => [
'url' => $forwardingUrl, 'status_code' => $statusCode,
'url' => $forwardingUrl,
],
]); ]);
} }
@@ -301,7 +303,7 @@ class PageRulesActions implements Configurations
{ {
$configuration['id'] = $setting; $configuration['id'] = $setting;
$this->configs[] = (object) $configuration; array_push($this->configs, $configuration);
} }
private function getBoolAsOnOrOff(bool $value): string private function getBoolAsOnOrOff(bool $value): string

View File

@@ -15,9 +15,9 @@ class PageRulesTargets implements Configurations
public function __construct(string $queryUrl) public function __construct(string $queryUrl)
{ {
$this->targets = [ $this->targets = [
(object)[ [
'target' => 'url', 'target' => 'url',
'constraint' => (object)[ 'constraint' => [
'operator' => 'matches', 'operator' => 'matches',
'value' => $queryUrl 'value' => $queryUrl
] ]

View File

@@ -14,7 +14,7 @@ class UARules implements Configurations
public function addUA(string $value) public function addUA(string $value)
{ {
$this->configs[] = (object)['target' => 'ua', 'value' => $value]; $this->configs[] = ['target' => 'ua', 'value' => $value];
} }
public function getArray(): array public function getArray(): array

View File

@@ -14,12 +14,12 @@ class ZoneLockdown implements Configurations
public function addIP(string $value) public function addIP(string $value)
{ {
$this->configs[] = (object)['target' => 'ip', 'value' => $value]; $this->configs[] = ['target' => 'ip', 'value' => $value];
} }
public function addIPRange(string $value) public function addIPRange(string $value)
{ {
$this->configs[] = (object)['target' => 'ip_range', 'value' => $value]; $this->configs[] = ['target' => 'ip_range', 'value' => $value];
} }
public function getArray(): array public function getArray(): array

View File

@@ -77,7 +77,7 @@ class AccessRules implements API
$query['notes'] = $notes; $query['notes'] = $notes;
} }
$data = $this->adapter->get('zones/' . $zoneID . '/firewall/access_rules/rules', $query, []); $data = $this->adapter->get('zones/' . $zoneID . '/firewall/access_rules/rules', $query);
$body = json_decode($data->getBody()); $body = json_decode($data->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -91,14 +91,14 @@ class AccessRules implements API
): bool { ): bool {
$options = [ $options = [
'mode' => $mode, 'mode' => $mode,
'configuration' => (object) $configuration->getArray() 'configuration' => $configuration->getArray()
]; ];
if ($notes !== null) { if ($notes !== null) {
$options['notes'] = $notes; $options['notes'] = $notes;
} }
$query = $this->adapter->post('zones/' . $zoneID . '/firewall/access_rules/rules', [], $options); $query = $this->adapter->post('zones/' . $zoneID . '/firewall/access_rules/rules', $options);
$body = json_decode($query->getBody()); $body = json_decode($query->getBody());
@@ -123,7 +123,7 @@ class AccessRules implements API
$options['notes'] = $notes; $options['notes'] = $notes;
} }
$query = $this->adapter->patch('zones/' . $zoneID . '/firewall/access_rules/rules/' . $ruleID, [], $options); $query = $this->adapter->patch('zones/' . $zoneID . '/firewall/access_rules/rules/' . $ruleID, $options);
$body = json_decode($query->getBody()); $body = json_decode($query->getBody());
@@ -140,7 +140,7 @@ class AccessRules implements API
'cascade' => $cascade 'cascade' => $cascade
]; ];
$data = $this->adapter->delete('zones/' . $zoneID . '/firewall/access_rules/rules/' . $ruleID, [], $options); $data = $this->adapter->delete('zones/' . $zoneID . '/firewall/access_rules/rules/' . $ruleID, $options);
$body = json_decode($data->getBody()); $body = json_decode($data->getBody());

View File

@@ -0,0 +1,150 @@
<?php
/**
* Created by PhpStorm.
* User: junade
* Date: 18/03/2018
* Time: 21:46
*/
namespace Cloudflare\API\Endpoints;
use Cloudflare\API\Adapter\Adapter;
class CustomHostnames implements API
{
private $adapter;
public function __construct(Adapter $adapter)
{
$this->adapter = $adapter;
}
/**
* @SuppressWarnings(PHPMD.BooleanArgumentFlag)
*
* @param string $zoneID
* @param string $hostname
* @param string $sslMethod
* @param string $sslType
* @return \stdClass
*/
public function addHostname(string $zoneID, string $hostname, string $sslMethod = 'http', string $sslType = 'dv'): \stdClass
{
$options = [
'hostname' => $hostname,
'ssl' => [
'method' => $sslMethod,
'type' => $sslType
]
];
$zone = $this->adapter->post('zones/'.$zoneID.'/custom_hostnames', $options);
$body = json_decode($zone->getBody());
return $body->result;
}
/**
* @param string $zoneID
* @param string $hostname
* @param string $id
* @param int $page
* @param int $perPage
* @param string $order
* @param string $direction
* @param int $ssl
* @return \stdClass
*/
public function listHostnames(
string $zoneID,
string $hostname = '',
string $hostnameID = '',
int $page = 1,
int $perPage = 20,
string $order = '',
string $direction = '',
int $ssl = 0
): \stdClass {
$query = [
'page' => $page,
'per_page' => $perPage,
'ssl' => $ssl
];
if (!empty($hostname)) {
$query['hostname'] = $hostname;
}
if (!empty($hostnameID)) {
$query['id'] = $hostnameID;
}
if (!empty($order)) {
$query['order'] = $order;
}
if (!empty($direction)) {
$query['direction'] = $direction;
}
$zone = $this->adapter->get('zones/'.$zoneID.'/custom_hostnames', $query);
$body = json_decode($zone->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info];
}
/**
* @param string $zoneID
* @param string $hostnameID
* @return mixed
*/
public function getHostname(string $zoneID, string $hostnameID)
{
$zone = $this->adapter->get('zones/'.$zoneID.'/custom_hostnames/'.$hostnameID);
$body = json_decode($zone->getBody());
return $body->result;
}
/**
* @SuppressWarnings(PHPMD.BooleanArgumentFlag)
*
* @param string $zoneID
* @param string $hostnameID
* @param string $sslMethod
* @param string $sslType
* @return \stdClass
*/
public function updateHostname(string $zoneID, string $hostnameID, string $sslMethod = '', string $sslType = ''): \stdClass
{
$query = [];
if (!empty($sslMethod)) {
$query['method'] = $sslMethod;
}
if (!empty($sslType)) {
$query['type'] = $sslType;
}
$options = [
'ssl' => $query
];
$zone = $this->adapter->patch('zones/'.$zoneID.'/custom_hostnames/'.$hostnameID, $options);
$body = json_decode($zone->getBody());
return $body->result;
}
/**
* @param string $zoneID
* @param string $hostnameID
* @return \stdClass
*/
public function deleteHostname(string $zoneID, string $hostnameID): \stdClass
{
$zone = $this->adapter->delete('zones/'.$zoneID.'/custom_hostnames/'.$hostnameID);
$body = json_decode($zone->getBody());
return $body;
}
}

View File

@@ -28,6 +28,7 @@ class DNS implements API
* @param string $content * @param string $content
* @param int $ttl * @param int $ttl
* @param bool $proxied * @param bool $proxied
* @param string $priority
* @return bool * @return bool
*/ */
public function addRecord( public function addRecord(
@@ -36,7 +37,8 @@ class DNS implements API
string $name, string $name,
string $content, string $content,
int $ttl = 0, int $ttl = 0,
bool $proxied = true bool $proxied = true,
string $priority = ''
): bool { ): bool {
$options = [ $options = [
'type' => $type, 'type' => $type,
@@ -49,7 +51,11 @@ class DNS implements API
$options['ttl'] = $ttl; $options['ttl'] = $ttl;
} }
$user = $this->adapter->post('zones/' . $zoneID . '/dns_records', [], $options); if (!empty($priority)) {
$options['priority'] = (int)$priority;
}
$user = $this->adapter->post('zones/' . $zoneID . '/dns_records', $options);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
@@ -97,7 +103,7 @@ class DNS implements API
$query['direction'] = $direction; $query['direction'] = $direction;
} }
$user = $this->adapter->get('zones/' . $zoneID . '/dns_records', $query, []); $user = $this->adapter->get('zones/' . $zoneID . '/dns_records', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -105,20 +111,20 @@ class DNS implements API
public function getRecordDetails(string $zoneID, string $recordID): \stdClass public function getRecordDetails(string $zoneID, string $recordID): \stdClass
{ {
$user = $this->adapter->get('zones/' . $zoneID . '/dns_records/' . $recordID, [], []); $user = $this->adapter->get('zones/' . $zoneID . '/dns_records/' . $recordID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
} }
public function updateRecordDetails(string $zoneID, string $recordID, array $details): \stdClass public function updateRecordDetails(string $zoneID, string $recordID, array $details): \stdClass
{ {
$response = $this->adapter->put('zones/' . $zoneID . '/dns_records/' . $recordID, [], $details); $response = $this->adapter->put('zones/' . $zoneID . '/dns_records/' . $recordID, $details);
return json_decode($response->getBody()); return json_decode($response->getBody());
} }
public function deleteRecord(string $zoneID, string $recordID): bool public function deleteRecord(string $zoneID, string $recordID): bool
{ {
$user = $this->adapter->delete('zones/' . $zoneID . '/dns_records/' . $recordID, [], []); $user = $this->adapter->delete('zones/' . $zoneID . '/dns_records/' . $recordID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());

View File

@@ -21,7 +21,7 @@ class IPs implements API
public function listIPs(): \stdClass public function listIPs(): \stdClass
{ {
$ips = $this->adapter->get('ips', [], []); $ips = $this->adapter->get('ips');
$body = json_decode($ips->getBody()); $body = json_decode($ips->getBody());
return $body->result; return $body->result;

View File

@@ -52,7 +52,7 @@ class PageRules implements API
} }
$query = $this->adapter->post('zones/' . $zoneID . '/pagerules', [], $options); $query = $this->adapter->post('zones/' . $zoneID . '/pagerules', $options);
$body = json_decode($query->getBody()); $body = json_decode($query->getBody());
@@ -93,7 +93,7 @@ class PageRules implements API
'match' => $match 'match' => $match
]; ];
$user = $this->adapter->get('zones/' . $zoneID . '/pagerules', $query, []); $user = $this->adapter->get('zones/' . $zoneID . '/pagerules', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
@@ -101,7 +101,7 @@ class PageRules implements API
public function getPageRuleDetails(string $zoneID, string $ruleID): \stdClass public function getPageRuleDetails(string $zoneID, string $ruleID): \stdClass
{ {
$user = $this->adapter->get('zones/' . $zoneID . '/pagerules/' . $ruleID, [], []); $user = $this->adapter->get('zones/' . $zoneID . '/pagerules/' . $ruleID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
} }
@@ -132,7 +132,7 @@ class PageRules implements API
} }
$query = $this->adapter->patch('zones/' . $zoneID . '/pagerules', [], $options); $query = $this->adapter->patch('zones/' . $zoneID . '/pagerules', $options);
$body = json_decode($query->getBody()); $body = json_decode($query->getBody());
@@ -145,7 +145,7 @@ class PageRules implements API
public function deletePageRule(string $zoneID, string $ruleID): bool public function deletePageRule(string $zoneID, string $ruleID): bool
{ {
$user = $this->adapter->delete('zones/' . $zoneID . '/pagerules/' . $ruleID, [], []); $user = $this->adapter->delete('zones/' . $zoneID . '/pagerules/' . $ruleID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());

View File

@@ -26,7 +26,7 @@ class Railgun implements API
'name' => $name, 'name' => $name,
]; ];
$user = $this->adapter->post('railguns', [], $query); $user = $this->adapter->post('railguns', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body; return $body;
@@ -46,7 +46,7 @@ class Railgun implements API
$query['direction'] = $direction; $query['direction'] = $direction;
} }
$user = $this->adapter->get('railguns', $query, []); $user = $this->adapter->get('railguns', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -55,7 +55,7 @@ class Railgun implements API
public function get( public function get(
string $railgunID string $railgunID
): \stdClass { ): \stdClass {
$user = $this->adapter->get('railguns/' . $railgunID, [], []); $user = $this->adapter->get('railguns/' . $railgunID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
@@ -64,7 +64,7 @@ class Railgun implements API
public function getZones( public function getZones(
string $railgunID string $railgunID
): \stdClass { ): \stdClass {
$user = $this->adapter->get('railguns/' . $railgunID . '/zones', [], []); $user = $this->adapter->get('railguns/' . $railgunID . '/zones');
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -78,7 +78,7 @@ class Railgun implements API
'enabled' => $status 'enabled' => $status
]; ];
$user = $this->adapter->patch('railguns/' . $railgunID, [], $query); $user = $this->adapter->patch('railguns/' . $railgunID, $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
@@ -87,7 +87,7 @@ class Railgun implements API
public function delete( public function delete(
string $railgunID string $railgunID
): bool { ): bool {
$user = $this->adapter->delete('railguns/' . $railgunID, [], []); $user = $this->adapter->delete('railguns/' . $railgunID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
if (isset($body->result->id)) { if (isset($body->result->id)) {

View File

@@ -30,7 +30,7 @@ class UARules implements API
'per_page' => $perPage 'per_page' => $perPage
]; ];
$user = $this->adapter->get('zones/' . $zoneID . '/firewall/ua_rules', $query, []); $user = $this->adapter->get('zones/' . $zoneID . '/firewall/ua_rules', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -56,7 +56,7 @@ class UARules implements API
$options['description'] = $description; $options['description'] = $description;
} }
$user = $this->adapter->post('zones/' . $zoneID . '/firewall/ua_rules', [], $options); $user = $this->adapter->post('zones/' . $zoneID . '/firewall/ua_rules', $options);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
@@ -69,7 +69,7 @@ class UARules implements API
public function getRuleDetails(string $zoneID, string $blockID): \stdClass public function getRuleDetails(string $zoneID, string $blockID): \stdClass
{ {
$user = $this->adapter->get('zones/' . $zoneID . '/firewall/ua_rules/' . $blockID, [], []); $user = $this->adapter->get('zones/' . $zoneID . '/firewall/ua_rules/' . $blockID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
} }
@@ -91,7 +91,7 @@ class UARules implements API
$options['description'] = $description; $options['description'] = $description;
} }
$user = $this->adapter->put('zones/' . $zoneID . '/firewall/ua_rules/' . $ruleID, [], $options); $user = $this->adapter->put('zones/' . $zoneID . '/firewall/ua_rules/' . $ruleID, $options);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
@@ -104,7 +104,7 @@ class UARules implements API
public function deleteRule(string $zoneID, string $ruleID): bool public function deleteRule(string $zoneID, string $ruleID): bool
{ {
$user = $this->adapter->delete('zones/' . $zoneID . '/firewall/ua_rules/' . $ruleID, [], []); $user = $this->adapter->delete('zones/' . $zoneID . '/firewall/ua_rules/' . $ruleID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());

View File

@@ -20,7 +20,7 @@ class User implements API
public function getUserDetails(): \stdClass public function getUserDetails(): \stdClass
{ {
$user = $this->adapter->get('user', [], []); $user = $this->adapter->get('user');
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
} }
@@ -37,7 +37,7 @@ class User implements API
public function updateUserDetails(array $details): \stdClass public function updateUserDetails(array $details): \stdClass
{ {
$response = $this->adapter->patch('user', [], $details); $response = $this->adapter->patch('user', $details);
return json_decode($response->getBody()); return json_decode($response->getBody());
} }
} }

View File

@@ -41,7 +41,7 @@ class WAF implements API
$query['direction'] = $direction; $query['direction'] = $direction;
} }
$user = $this->adapter->get('zones/' . $zoneID . '/firewall/waf/packages', $query, []); $user = $this->adapter->get('zones/' . $zoneID . '/firewall/waf/packages', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -52,7 +52,7 @@ class WAF implements API
string $zoneID, string $zoneID,
string $packageID string $packageID
): \stdClass { ): \stdClass {
$user = $this->adapter->get('zones/' . $zoneID . '/firewall/waf/packages/' . $packageID, [], []); $user = $this->adapter->get('zones/' . $zoneID . '/firewall/waf/packages/' . $packageID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
@@ -80,7 +80,7 @@ class WAF implements API
if (!empty($direction)) { if (!empty($direction)) {
$query['direction'] = $direction; $query['direction'] = $direction;
} }
$user = $this->adapter->get('zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/rules', $query, []); $user = $this->adapter->get('zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/rules', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -91,11 +91,7 @@ class WAF implements API
string $packageID, string $packageID,
string $ruleID string $ruleID
): \stdClass { ): \stdClass {
$user = $this->adapter->get( $user = $this->adapter->get('zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/rules/' . $ruleID);
'zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/rules/' . $ruleID,
[],
[]
);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
@@ -113,7 +109,6 @@ class WAF implements API
$user = $this->adapter->patch( $user = $this->adapter->patch(
'zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/rules/' . $ruleID, 'zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/rules/' . $ruleID,
[],
$query $query
); );
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
@@ -146,8 +141,7 @@ class WAF implements API
$user = $this->adapter->get( $user = $this->adapter->get(
'zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/groups', 'zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/groups',
$query, $query
[]
); );
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
@@ -159,11 +153,7 @@ class WAF implements API
string $packageID, string $packageID,
string $groupID string $groupID
): \stdClass { ): \stdClass {
$user = $this->adapter->get( $user = $this->adapter->get('zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/groups/' . $groupID);
'zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/groups/' . $groupID,
[],
[]
);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
@@ -181,7 +171,6 @@ class WAF implements API
$user = $this->adapter->patch( $user = $this->adapter->patch(
'zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/groups/' . $groupID, 'zones/' . $zoneID . '/firewall/waf/packages/' . $packageID . '/groups/' . $groupID,
[],
$query $query
); );
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());

View File

@@ -29,7 +29,7 @@ class ZoneLockdown implements API
'per_page' => $perPage 'per_page' => $perPage
]; ];
$user = $this->adapter->get('zones/' . $zoneID . '/firewall/lockdowns', $query, []); $user = $this->adapter->get('zones/' . $zoneID . '/firewall/lockdowns', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -55,7 +55,7 @@ class ZoneLockdown implements API
$options['description'] = $description; $options['description'] = $description;
} }
$user = $this->adapter->post('zones/' . $zoneID . '/firewall/lockdowns', [], $options); $user = $this->adapter->post('zones/' . $zoneID . '/firewall/lockdowns', $options);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
@@ -68,7 +68,7 @@ class ZoneLockdown implements API
public function getLockdownDetails(string $zoneID, string $lockdownID): \stdClass public function getLockdownDetails(string $zoneID, string $lockdownID): \stdClass
{ {
$user = $this->adapter->get('zones/' . $zoneID . '/firewall/lockdowns/' . $lockdownID, [], []); $user = $this->adapter->get('zones/' . $zoneID . '/firewall/lockdowns/' . $lockdownID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
} }
@@ -90,7 +90,7 @@ class ZoneLockdown implements API
$options['description'] = $description; $options['description'] = $description;
} }
$user = $this->adapter->put('zones/' . $zoneID . '/firewall/lockdowns/' . $lockdownID, [], $options); $user = $this->adapter->put('zones/' . $zoneID . '/firewall/lockdowns/' . $lockdownID, $options);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
@@ -103,7 +103,7 @@ class ZoneLockdown implements API
public function deleteLockdown(string $zoneID, string $lockdownID): bool public function deleteLockdown(string $zoneID, string $lockdownID): bool
{ {
$user = $this->adapter->delete('zones/' . $zoneID . '/firewall/lockdowns/' . $lockdownID, [], []); $user = $this->adapter->delete('zones/' . $zoneID . '/firewall/lockdowns/' . $lockdownID);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());

View File

@@ -23,29 +23,29 @@ class Zones implements API
* @SuppressWarnings(PHPMD.BooleanArgumentFlag) * @SuppressWarnings(PHPMD.BooleanArgumentFlag)
* *
* @param string $name * @param string $name
* @param bool $jumpstart * @param bool $jumpStart
* @param string $organizationID * @param string $organizationID
* @return \stdClass * @return \stdClass
*/ */
public function addZone(string $name, bool $jumpstart = false, string $organizationID = ''): \stdClass public function addZone(string $name, bool $jumpStart = false, string $organizationID = ''): \stdClass
{ {
$options = [ $options = [
'name' => $name, 'name' => $name,
'jumpstart' => $jumpstart 'jump_start' => $jumpStart
]; ];
if (!empty($organizationID)) { if (!empty($organizationID)) {
$options['organization'] = (object)['id' => $organizationID]; $options['organization'] = ['id' => $organizationID];
} }
$user = $this->adapter->post('zones', [], $options); $user = $this->adapter->post('zones', $options);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return $body->result; return $body->result;
} }
public function activationCheck(string $zoneID): bool public function activationCheck(string $zoneID): bool
{ {
$user = $this->adapter->put('zones/' . $zoneID . '/activation_check', [], []); $user = $this->adapter->put('zones/' . $zoneID . '/activation_check');
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
if (isset($body->result->id)) { if (isset($body->result->id)) {
@@ -86,7 +86,7 @@ class Zones implements API
$query['direction'] = $direction; $query['direction'] = $direction;
} }
$user = $this->adapter->get('zones', $query, []); $user = $this->adapter->get('zones', $query);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
return (object)['result' => $body->result, 'result_info' => $body->result_info]; return (object)['result' => $body->result, 'result_info' => $body->result_info];
@@ -114,7 +114,7 @@ class Zones implements API
*/ */
public function getAnalyticsDashboard(string $zoneID, string $since = '-10080', string $until = '0', bool $continuous = true): \stdClass public function getAnalyticsDashboard(string $zoneID, string $since = '-10080', string $until = '0', bool $continuous = true): \stdClass
{ {
$response = $this->adapter->get('zones/' . $zoneID . '/analytics/dashboard', [], ['since' => $since, 'until' => $until, 'continuous' => $continuous]); $response = $this->adapter->get('zones/' . $zoneID . '/analytics/dashboard', ['since' => $since, 'until' => $until, 'continuous' => var_export($continuous, true)]);
return json_decode($response->getBody())->result; return json_decode($response->getBody())->result;
} }
@@ -128,7 +128,7 @@ class Zones implements API
*/ */
public function changeDevelopmentMode(string $zoneID, bool $enable = false): bool public function changeDevelopmentMode(string $zoneID, bool $enable = false): bool
{ {
$response = $this->adapter->patch('zones/' . $zoneID . '/settings/development_mode', [], ['value' => $enable ? 'on' : 'off']); $response = $this->adapter->patch('zones/' . $zoneID . '/settings/development_mode', ['value' => $enable ? 'on' : 'off']);
$body = json_decode($response->getBody()); $body = json_decode($response->getBody());
@@ -147,7 +147,7 @@ class Zones implements API
*/ */
public function cachePurgeEverything(string $zoneID): bool public function cachePurgeEverything(string $zoneID): bool
{ {
$user = $this->adapter->delete('zones/' . $zoneID . '/purge_cache', [], ['purge_everything' => true]); $user = $this->adapter->delete('zones/' . $zoneID . '/purge_cache', ['purge_everything' => true]);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());
@@ -158,18 +158,26 @@ class Zones implements API
return false; return false;
} }
public function cachePurge(string $zoneID, array $files = null, array $tags = null): bool public function cachePurge(string $zoneID, array $files = null, array $tags = null, array $hosts = null): bool
{ {
if ($files === null && $tags === null) { if ($files === null && $tags === null && $hosts === null) {
throw new EndpointException('No files or tags to purge.'); throw new EndpointException('No files, tags or hosts to purge.');
} }
$options = [ $options = [];
'files' => $files, if (!is_null($files)) {
'tags' => $tags $options['files'] = $files;
]; }
$user = $this->adapter->delete('zones/' . $zoneID . '/purge_cache', [], $options); if (!is_null($tags)) {
$options['tags'] = $tags;
}
if (!is_null($hosts)) {
$options['hosts'] = $hosts;
}
$user = $this->adapter->delete('zones/' . $zoneID . '/purge_cache', $options);
$body = json_decode($user->getBody()); $body = json_decode($user->getBody());

View File

@@ -41,7 +41,7 @@ class GuzzleTest extends TestCase
public function testPost() public function testPost()
{ {
$response = $this->client->post('https://httpbin.org/post', [], ['X-Post-Test' => 'Testing a POST request.']); $response = $this->client->post('https://httpbin.org/post', ['X-Post-Test' => 'Testing a POST request.']);
$headers = $response->getHeaders(); $headers = $response->getHeaders();
$this->assertEquals('application/json', $headers['Content-Type'][0]); $this->assertEquals('application/json', $headers['Content-Type'][0]);
@@ -52,7 +52,7 @@ class GuzzleTest extends TestCase
public function testPut() public function testPut()
{ {
$response = $this->client->put('https://httpbin.org/put', [], ['X-Put-Test' => 'Testing a PUT request.']); $response = $this->client->put('https://httpbin.org/put', ['X-Put-Test' => 'Testing a PUT request.']);
$headers = $response->getHeaders(); $headers = $response->getHeaders();
$this->assertEquals('application/json', $headers['Content-Type'][0]); $this->assertEquals('application/json', $headers['Content-Type'][0]);
@@ -65,7 +65,6 @@ class GuzzleTest extends TestCase
{ {
$response = $this->client->patch( $response = $this->client->patch(
'https://httpbin.org/patch', 'https://httpbin.org/patch',
[],
['X-Patch-Test' => 'Testing a PATCH request.'] ['X-Patch-Test' => 'Testing a PATCH request.']
); );
@@ -80,7 +79,6 @@ class GuzzleTest extends TestCase
{ {
$response = $this->client->delete( $response = $this->client->delete(
'https://httpbin.org/delete', 'https://httpbin.org/delete',
[],
['X-Delete-Test' => 'Testing a DELETE request.'] ['X-Delete-Test' => 'Testing a DELETE request.']
); );

View File

@@ -16,12 +16,12 @@ class ConfigurationsUARulesTest extends TestCase
$array = $configuration->getArray(); $array = $configuration->getArray();
$this->assertCount(1, $array); $this->assertCount(1, $array);
$this->assertObjectHasAttribute('target', $array[0]); $this->assertArrayHasKey('target', $array[0]);
$this->assertEquals('ua', $array[0]->target); $this->assertEquals('ua', $array[0]['target']);
$this->assertObjectHasAttribute('value', $array[0]); $this->assertArrayHasKey('value', $array[0]);
$this->assertEquals( $this->assertEquals(
'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/603.2.4 (KHTML, like Gecko) Version/10.1.1 Safari/603.2.4', 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/603.2.4 (KHTML, like Gecko) Version/10.1.1 Safari/603.2.4',
$array[0]->value $array[0]['value']
); );
} }
} }

View File

@@ -16,19 +16,19 @@ class ConfigurationsZoneLockdownTest extends TestCase
$array = $configuration->getArray(); $array = $configuration->getArray();
$this->assertCount(1, $array); $this->assertCount(1, $array);
$this->assertObjectHasAttribute('target', $array[0]); $this->assertArrayHasKey('target', $array[0]);
$this->assertEquals('ip', $array[0]->target); $this->assertEquals('ip', $array[0]['target']);
$this->assertObjectHasAttribute('value', $array[0]); $this->assertArrayHasKey('value', $array[0]);
$this->assertEquals('1.2.3.4', $array[0]->value); $this->assertEquals('1.2.3.4', $array[0]['value']);
$configuration->addIPRange('1.2.3.4/24'); $configuration->addIPRange('1.2.3.4/24');
$array = $configuration->getArray(); $array = $configuration->getArray();
$this->assertCount(2, $array); $this->assertCount(2, $array);
$this->assertObjectHasAttribute('target', $array[1]); $this->assertArrayHasKey('target', $array[1]);
$this->assertEquals('ip_range', $array[1]->target); $this->assertEquals('ip_range', $array[1]['target']);
$this->assertObjectHasAttribute('value', $array[1]); $this->assertArrayHasKey('value', $array[1]);
$this->assertEquals('1.2.3.4/24', $array[1]->value); $this->assertEquals('1.2.3.4/24', $array[1]['value']);
} }
} }

View File

@@ -0,0 +1,21 @@
<?php
use Cloudflare\API\Configurations\PageRulesActions;
class PageRulesActionTest extends TestCase
{
public function testForwardingURLConfigurationIsApplied()
{
$identifier = 'forwarding_url';
$statusCode = 301;
$forwardingURL = 'https://www.example.org/';
$actions = new PageRulesActions();
$actions->setForwardingURL($statusCode, $forwardingURL);
$configuration = $actions->getArray();
$this->assertCount(1, $configuration);
$this->assertEquals($identifier, $configuration[0]['id']);
$this->assertEquals($statusCode, $configuration[0]['value']['status_code']);
$this->assertEquals($forwardingURL, $configuration[0]['value']['url']);
}
}

View File

@@ -16,7 +16,7 @@ class PageRulesTargetTest extends TestCase
$array = $targets->getArray(); $array = $targets->getArray();
$this->assertCount(1, $array); $this->assertCount(1, $array);
$this->assertEquals('junade.com/*', $array[0]->constraint->value); $this->assertEquals('junade.com/*', $array[0]['constraint']['value']);
$this->assertEquals('matches', $array[0]->constraint->operator); $this->assertEquals('matches', $array[0]['constraint']['operator']);
} }
} }

View File

@@ -17,8 +17,7 @@ class AccessRulesTest extends TestCase
'page' => 1, 'page' => 1,
'per_page' => 50, 'per_page' => 50,
'match' => 'all' 'match' => 'all'
]), ])
$this->equalTo([])
); );
$zones = new \Cloudflare\API\Endpoints\AccessRules($mock); $zones = new \Cloudflare\API\Endpoints\AccessRules($mock);
@@ -45,10 +44,9 @@ class AccessRulesTest extends TestCase
->method('post') ->method('post')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/access_rules/rules'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/access_rules/rules'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'mode' => 'challenge', 'mode' => 'challenge',
'configuration' => (object) $config->getArray(), 'configuration' => $config->getArray(),
'notes' => 'This rule is on because of an event that occured on date X', 'notes' => 'This rule is on because of an event that occured on date X',
]) ])
); );
@@ -73,7 +71,6 @@ class AccessRulesTest extends TestCase
->method('patch') ->method('patch')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/access_rules/rules/92f17202ed8bd63d69a66b86a49a8f6b'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/access_rules/rules/92f17202ed8bd63d69a66b86a49a8f6b'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'mode' => 'challenge', 'mode' => 'challenge',
'notes' => 'This rule is on because of an event that occured on date X', 'notes' => 'This rule is on because of an event that occured on date X',
@@ -100,7 +97,6 @@ class AccessRulesTest extends TestCase
->method('delete') ->method('delete')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/access_rules/rules/92f17202ed8bd63d69a66b86a49a8f6b'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/access_rules/rules/92f17202ed8bd63d69a66b86a49a8f6b'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'cascade' => 'none' 'cascade' => 'none'
]) ])

View File

@@ -0,0 +1,133 @@
<?php
/**
* Created by PhpStorm.
* User: junade
* Date: 18/03/2018
* Time: 22:23
*/
use Cloudflare\API\Endpoints\CustomHostnames;
class CustomHostnamesTest extends TestCase
{
public function testAddHostname()
{
$response = $this->getPsr7JsonResponseForFixture('Endpoints/createCustomHostname.json');
$mock = $this->getMockBuilder(\Cloudflare\API\Adapter\Adapter::class)->getMock();
$mock->method('post')->willReturn($response);
$mock->expects($this->once())
->method('post')
->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/custom_hostnames'),
$this->equalTo([
'hostname' => 'app.example.com',
'ssl' => [
'method' => 'http',
'type' => 'dv'
]
])
);
$hostname = new CustomHostnames($mock);
$hostname->addHostname('023e105f4ecef8ad9ca31a8372d0c353', 'app.example.com', 'http', 'dv');
}
public function testListHostnames()
{
$response = $this->getPsr7JsonResponseForFixture('Endpoints/listHostnames.json');
$mock = $this->getMockBuilder(\Cloudflare\API\Adapter\Adapter::class)->getMock();
$mock->method('get')->willReturn($response);
$mock->expects($this->once())
->method('get')
->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/custom_hostnames'),
$this->equalTo([
'hostname' => 'app.example.com',
'id' => '0d89c70d-ad9f-4843-b99f-6cc0252067e9',
'page' => 1,
'per_page' => 20,
'order' => 'ssl',
'direction' => 'desc',
'ssl' => 0
])
);
$zones = new \Cloudflare\API\Endpoints\CustomHostnames($mock);
$result = $zones->listHostnames('023e105f4ecef8ad9ca31a8372d0c353', 'app.example.com', '0d89c70d-ad9f-4843-b99f-6cc0252067e9', 1, 20, 'ssl', 'desc', 0);
$this->assertObjectHasAttribute('result', $result);
$this->assertObjectHasAttribute('result_info', $result);
$this->assertEquals('0d89c70d-ad9f-4843-b99f-6cc0252067e9', $result->result[0]->id);
$this->assertEquals(1, $result->result_info->page);
}
public function testGetHostname()
{
$response = $this->getPsr7JsonResponseForFixture('Endpoints/getHostname.json');
$mock = $this->getMockBuilder(\Cloudflare\API\Adapter\Adapter::class)->getMock();
$mock->method('get')->willReturn($response);
$mock->expects($this->once())
->method('get')
->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/custom_hostnames/0d89c70d-ad9f-4843-b99f-6cc0252067e9')
);
$zones = new \Cloudflare\API\Endpoints\CustomHostnames($mock);
$result = $zones->getHostname('023e105f4ecef8ad9ca31a8372d0c353', '0d89c70d-ad9f-4843-b99f-6cc0252067e9', '0d89c70d-ad9f-4843-b99f-6cc0252067e9');
$this->assertObjectHasAttribute('id', $result);
$this->assertObjectHasAttribute('hostname', $result);
}
public function testUpdateHostname()
{
$response = $this->getPsr7JsonResponseForFixture('Endpoints/updateHostname.json');
$mock = $this->getMockBuilder(\Cloudflare\API\Adapter\Adapter::class)->getMock();
$mock->method('patch')->willReturn($response);
$mock->expects($this->once())
->method('patch')
->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/custom_hostnames/0d89c70d-ad9f-4843-b99f-6cc0252067e9'),
$this->equalTo([
'ssl' => [
'method' => 'http',
'type' => 'dv'
]
])
);
$zones = new \Cloudflare\API\Endpoints\CustomHostnames($mock);
$result = $zones->updateHostname('023e105f4ecef8ad9ca31a8372d0c353', '0d89c70d-ad9f-4843-b99f-6cc0252067e9', 'http', 'dv');
$this->assertObjectHasAttribute('id', $result);
$this->assertObjectHasAttribute('hostname', $result);
}
public function testDeleteHostname()
{
$response = $this->getPsr7JsonResponseForFixture('Endpoints/deleteHostname.json');
$mock = $this->getMockBuilder(\Cloudflare\API\Adapter\Adapter::class)->getMock();
$mock->method('delete')->willReturn($response);
$mock->expects($this->once())
->method('delete')
->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/custom_hostnames/0d89c70d-ad9f-4843-b99f-6cc0252067e9')
);
$zones = new \Cloudflare\API\Endpoints\CustomHostnames($mock);
$result = $zones->deleteHostname('023e105f4ecef8ad9ca31a8372d0c353', '0d89c70d-ad9f-4843-b99f-6cc0252067e9');
$this->assertEquals('0d89c70d-ad9f-4843-b99f-6cc0252067e9', $result->id);
}
}

View File

@@ -19,7 +19,6 @@ class DNSTest extends TestCase
->method('post') ->method('post')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/dns_records'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/dns_records'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'type' => 'A', 'type' => 'A',
'name' => 'example.com', 'name' => 'example.com',
@@ -44,16 +43,16 @@ class DNSTest extends TestCase
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/dns_records'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/dns_records'),
$this->equalTo([ $this->equalTo([
'page' => 1, 'page' => 1,
'per_page' => 20, 'per_page' => 20,
'match' => 'all', 'match' => 'all',
'type' => 'A', 'type' => 'A',
'name' => 'example.com', 'name' => 'example.com',
'content' => '127.0.0.1', 'content' => '127.0.0.1',
'order' => 'type', 'order' => 'type',
'direction' => 'desc']), 'direction' => 'desc',
$this->equalTo([]) ])
); );
$zones = new \Cloudflare\API\Endpoints\DNS($mock); $zones = new \Cloudflare\API\Endpoints\DNS($mock);
@@ -76,8 +75,7 @@ class DNSTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/dns_records/372e67954025e0ba6aaa6d586b9e0b59'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/dns_records/372e67954025e0ba6aaa6d586b9e0b59')
$this->equalTo([])
); );
$dns = new \Cloudflare\API\Endpoints\DNS($mock); $dns = new \Cloudflare\API\Endpoints\DNS($mock);
@@ -105,7 +103,6 @@ class DNSTest extends TestCase
->method('put') ->method('put')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/dns_records/372e67954025e0ba6aaa6d586b9e0b59'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/dns_records/372e67954025e0ba6aaa6d586b9e0b59'),
$this->equalTo([]),
$this->equalTo($details) $this->equalTo($details)
); );

View File

@@ -18,8 +18,7 @@ class IPsTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('ips'), $this->equalTo('ips')
$this->equalTo([])
); );
$ips = new \Cloudflare\API\Endpoints\IPs($mock); $ips = new \Cloudflare\API\Endpoints\IPs($mock);

View File

@@ -23,7 +23,6 @@ class PageRulesTest extends TestCase
->method('post') ->method('post')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/pagerules'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/pagerules'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'targets' => $target->getArray(), 'targets' => $target->getArray(),
'actions' => $action->getArray(), 'actions' => $action->getArray(),
@@ -54,8 +53,7 @@ class PageRulesTest extends TestCase
'order' => 'status', 'order' => 'status',
'direction' => 'desc', 'direction' => 'desc',
'match' => 'all' 'match' => 'all'
]), ])
$this->equalTo([])
); );
$pageRules = new \Cloudflare\API\Endpoints\PageRules($mock); $pageRules = new \Cloudflare\API\Endpoints\PageRules($mock);
@@ -72,8 +70,7 @@ class PageRulesTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/pagerules/9a7806061c88ada191ed06f989cc3dac'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/pagerules/9a7806061c88ada191ed06f989cc3dac')
$this->equalTo([])
); );
$pageRules = new \Cloudflare\API\Endpoints\PageRules($mock); $pageRules = new \Cloudflare\API\Endpoints\PageRules($mock);
@@ -95,7 +92,6 @@ class PageRulesTest extends TestCase
->method('patch') ->method('patch')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/pagerules'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/pagerules'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'targets' => $target->getArray(), 'targets' => $target->getArray(),
'actions' => $action->getArray(), 'actions' => $action->getArray(),
@@ -120,9 +116,7 @@ class PageRulesTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('delete') ->method('delete')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/pagerules/9a7806061c88ada191ed06f989cc3dac'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/pagerules/9a7806061c88ada191ed06f989cc3dac')
$this->equalTo([]),
$this->equalTo([])
); );
$pageRules = new \Cloudflare\API\Endpoints\PageRules($mock); $pageRules = new \Cloudflare\API\Endpoints\PageRules($mock);

View File

@@ -23,7 +23,6 @@ class RailgunTest extends TestCase
->method('post') ->method('post')
->with( ->with(
$this->equalTo('railguns'), $this->equalTo('railguns'),
$this->equalTo([]),
$this->equalTo(['name' => $details['name']]) $this->equalTo(['name' => $details['name']])
); );
@@ -52,8 +51,7 @@ class RailgunTest extends TestCase
'page' => 1, 'page' => 1,
'per_page' => 20, 'per_page' => 20,
'direction' => 'desc' 'direction' => 'desc'
]), ])
$this->equalTo([])
); );
$railgun = new \Cloudflare\API\Endpoints\Railgun($mock); $railgun = new \Cloudflare\API\Endpoints\Railgun($mock);
@@ -73,8 +71,7 @@ class RailgunTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('railguns/e928d310693a83094309acf9ead50448'), $this->equalTo('railguns/e928d310693a83094309acf9ead50448')
$this->equalTo([])
); );
$railgun = new \Cloudflare\API\Endpoints\Railgun($mock); $railgun = new \Cloudflare\API\Endpoints\Railgun($mock);
@@ -93,9 +90,7 @@ class RailgunTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('railguns/e928d310693a83094309acf9ead50448/zones'), $this->equalTo('railguns/e928d310693a83094309acf9ead50448/zones')
$this->equalTo([]),
$this->equalTo([])
); );
$railgun = new \Cloudflare\API\Endpoints\Railgun($mock); $railgun = new \Cloudflare\API\Endpoints\Railgun($mock);
@@ -120,7 +115,6 @@ class RailgunTest extends TestCase
->method('patch') ->method('patch')
->with( ->with(
$this->equalTo('railguns/e928d310693a83094309acf9ead50448'), $this->equalTo('railguns/e928d310693a83094309acf9ead50448'),
$this->equalTo([]),
$this->equalTo($details) $this->equalTo($details)
); );
@@ -140,9 +134,7 @@ class RailgunTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('delete') ->method('delete')
->with( ->with(
$this->equalTo('railguns/e928d310693a83094309acf9ead50448'), $this->equalTo('railguns/e928d310693a83094309acf9ead50448')
$this->equalTo([]),
$this->equalTo([])
); );
$waf = new \Cloudflare\API\Endpoints\Railgun($mock); $waf = new \Cloudflare\API\Endpoints\Railgun($mock);

View File

@@ -22,8 +22,7 @@ class UARulesTest extends TestCase
$this->equalTo([ $this->equalTo([
'page' => 1, 'page' => 1,
'per_page' => 20 'per_page' => 20
]), ])
$this->equalTo([])
); );
$zones = new \Cloudflare\API\Endpoints\UARules($mock); $zones = new \Cloudflare\API\Endpoints\UARules($mock);
@@ -50,7 +49,6 @@ class UARulesTest extends TestCase
->method('post') ->method('post')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/ua_rules'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/ua_rules'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'mode' => 'js_challenge', 'mode' => 'js_challenge',
'id' => '372e67954025e0ba6aaa6d586b9e0b59', 'id' => '372e67954025e0ba6aaa6d586b9e0b59',
@@ -79,8 +77,7 @@ class UARulesTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/ua_rules/372e67954025e0ba6aaa6d586b9e0b59'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/ua_rules/372e67954025e0ba6aaa6d586b9e0b59')
$this->equalTo([])
); );
$lockdown = new \Cloudflare\API\Endpoints\UARules($mock); $lockdown = new \Cloudflare\API\Endpoints\UARules($mock);
@@ -103,7 +100,6 @@ class UARulesTest extends TestCase
->method('put') ->method('put')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/ua_rules/372e67954025e0ba6aaa6d586b9e0b59'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/ua_rules/372e67954025e0ba6aaa6d586b9e0b59'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'mode' => 'js_challenge', 'mode' => 'js_challenge',
'id' => '372e67954025e0ba6aaa6d586b9e0b59', 'id' => '372e67954025e0ba6aaa6d586b9e0b59',
@@ -132,9 +128,7 @@ class UARulesTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('delete') ->method('delete')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/ua_rules/372e67954025e0ba6aaa6d586b9e0b59'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/ua_rules/372e67954025e0ba6aaa6d586b9e0b59')
$this->equalTo([]),
$this->equalTo([])
); );
$rules = new \Cloudflare\API\Endpoints\UARules($mock); $rules = new \Cloudflare\API\Endpoints\UARules($mock);

View File

@@ -56,7 +56,7 @@ class UserTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('patch') ->method('patch')
->with($this->equalTo('user'), $this->equalTo([]), $this->equalTo(['email' => 'user2@example.com'])); ->with($this->equalTo('user'), $this->equalTo(['email' => 'user2@example.com']));
$user = new \Cloudflare\API\Endpoints\User($mock); $user = new \Cloudflare\API\Endpoints\User($mock);
$user->updateUserDetails(['email' => 'user2@example.com']); $user->updateUserDetails(['email' => 'user2@example.com']);

View File

@@ -25,8 +25,7 @@ class WAFTest extends TestCase
'match' => 'all', 'match' => 'all',
'order' => 'status', 'order' => 'status',
'direction' => 'desc' 'direction' => 'desc'
]), ])
$this->equalTo([])
); );
$waf = new \Cloudflare\API\Endpoints\WAF($mock); $waf = new \Cloudflare\API\Endpoints\WAF($mock);
@@ -49,8 +48,7 @@ class WAFTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b')
$this->equalTo([])
); );
$waf = new \Cloudflare\API\Endpoints\WAF($mock); $waf = new \Cloudflare\API\Endpoints\WAF($mock);
@@ -76,8 +74,7 @@ class WAFTest extends TestCase
'match' => 'all', 'match' => 'all',
'order' => 'status', 'order' => 'status',
'direction' => 'desc' 'direction' => 'desc'
]), ])
$this->equalTo([])
); );
$waf = new \Cloudflare\API\Endpoints\WAF($mock); $waf = new \Cloudflare\API\Endpoints\WAF($mock);
@@ -100,8 +97,7 @@ class WAFTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b/rules/f939de3be84e66e757adcdcb87908023'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b/rules/f939de3be84e66e757adcdcb87908023')
$this->equalTo([])
); );
$waf = new \Cloudflare\API\Endpoints\WAF($mock); $waf = new \Cloudflare\API\Endpoints\WAF($mock);
@@ -125,7 +121,6 @@ class WAFTest extends TestCase
->method('patch') ->method('patch')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b/rules/f939de3be84e66e757adcdcb87908023'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b/rules/f939de3be84e66e757adcdcb87908023'),
$this->equalTo([]),
$this->equalTo($details) $this->equalTo($details)
); );
@@ -156,8 +151,7 @@ class WAFTest extends TestCase
'match' => 'all', 'match' => 'all',
'order' => 'status', 'order' => 'status',
'direction' => 'desc' 'direction' => 'desc'
]), ])
$this->equalTo([])
); );
$waf = new \Cloudflare\API\Endpoints\WAF($mock); $waf = new \Cloudflare\API\Endpoints\WAF($mock);
@@ -180,8 +174,7 @@ class WAFTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b/groups/de677e5818985db1285d0e80225f06e5'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b/groups/de677e5818985db1285d0e80225f06e5')
$this->equalTo([])
); );
$waf = new \Cloudflare\API\Endpoints\WAF($mock); $waf = new \Cloudflare\API\Endpoints\WAF($mock);
@@ -205,7 +198,6 @@ class WAFTest extends TestCase
->method('patch') ->method('patch')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b/groups/de677e5818985db1285d0e80225f06e5'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/waf/packages/a25a9a7e9c00afc1fb2e0245519d725b/groups/de677e5818985db1285d0e80225f06e5'),
$this->equalTo([]),
$this->equalTo($details) $this->equalTo($details)
); );

View File

@@ -19,11 +19,10 @@ class ZoneLockdownTest extends TestCase
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns'),
$this->equalTo([ $this->equalTo([
'page' => 1, 'page' => 1,
'per_page' => 20, 'per_page' => 20,
]), ])
$this->equalTo([])
); );
$zones = new \Cloudflare\API\Endpoints\ZoneLockdown($mock); $zones = new \Cloudflare\API\Endpoints\ZoneLockdown($mock);
@@ -50,7 +49,6 @@ class ZoneLockdownTest extends TestCase
->method('post') ->method('post')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'urls' => ['api.mysite.com/some/endpoint*'], 'urls' => ['api.mysite.com/some/endpoint*'],
'id' => '372e67954025e0ba6aaa6d586b9e0b59', 'id' => '372e67954025e0ba6aaa6d586b9e0b59',
@@ -79,8 +77,7 @@ class ZoneLockdownTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns/372e67954025e0ba6aaa6d586b9e0b59'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns/372e67954025e0ba6aaa6d586b9e0b59')
$this->equalTo([])
); );
$lockdown = new \Cloudflare\API\Endpoints\ZoneLockdown($mock); $lockdown = new \Cloudflare\API\Endpoints\ZoneLockdown($mock);
@@ -103,7 +100,6 @@ class ZoneLockdownTest extends TestCase
->method('put') ->method('put')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns/372e67954025e0ba6aaa6d586b9e0b59'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns/372e67954025e0ba6aaa6d586b9e0b59'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'urls' => ['api.mysite.com/some/endpoint*'], 'urls' => ['api.mysite.com/some/endpoint*'],
'id' => '372e67954025e0ba6aaa6d586b9e0b59', 'id' => '372e67954025e0ba6aaa6d586b9e0b59',
@@ -135,9 +131,7 @@ class ZoneLockdownTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('delete') ->method('delete')
->with( ->with(
$this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns/372e67954025e0ba6aaa6d586b9e0b59'), $this->equalTo('zones/023e105f4ecef8ad9ca31a8372d0c353/firewall/lockdowns/372e67954025e0ba6aaa6d586b9e0b59')
$this->equalTo([]),
$this->equalTo([])
); );
$zoneLockdown = new \Cloudflare\API\Endpoints\ZoneLockdown($mock); $zoneLockdown = new \Cloudflare\API\Endpoints\ZoneLockdown($mock);

View File

@@ -19,8 +19,7 @@ class ZonesTest extends TestCase
->method('post') ->method('post')
->with( ->with(
$this->equalTo('zones'), $this->equalTo('zones'),
$this->equalTo([]), $this->equalTo(['name' => 'example.com', 'jump_start' => false])
$this->equalTo(['name' => 'example.com', 'jumpstart' => false])
); );
$zones = new \Cloudflare\API\Endpoints\Zones($mock); $zones = new \Cloudflare\API\Endpoints\Zones($mock);
@@ -38,11 +37,10 @@ class ZonesTest extends TestCase
->method('post') ->method('post')
->with( ->with(
$this->equalTo('zones'), $this->equalTo('zones'),
$this->equalTo([]),
$this->equalTo([ $this->equalTo([
'name' => 'example.com', 'name' => 'example.com',
'jumpstart' => true, 'jump_start' => true,
'organization' => (object)['id' => '01a7362d577a6c3019a474fd6f485823'] 'organization' => ['id' => '01a7362d577a6c3019a474fd6f485823']
]) ])
); );
@@ -60,9 +58,7 @@ class ZonesTest extends TestCase
$mock->expects($this->once()) $mock->expects($this->once())
->method('put') ->method('put')
->with( ->with(
$this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/activation_check'), $this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/activation_check')
$this->equalTo([]),
$this->equalTo([])
); );
$zones = new \Cloudflare\API\Endpoints\Zones($mock); $zones = new \Cloudflare\API\Endpoints\Zones($mock);
@@ -82,16 +78,15 @@ class ZonesTest extends TestCase
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones'), $this->equalTo('zones'),
$this->equalTo([ $this->equalTo([
'page' => 1, 'page' => 1,
'per_page' => 20, 'per_page' => 20,
'match' => 'all', 'match' => 'all',
'name' => 'example.com', 'name' => 'example.com',
'status' => 'active', 'status' => 'active',
'order' => 'status', 'order' => 'status',
'direction' => 'desc' 'direction' => 'desc',
]), ])
$this->equalTo([])
); );
$zones = new \Cloudflare\API\Endpoints\Zones($mock); $zones = new \Cloudflare\API\Endpoints\Zones($mock);
@@ -115,13 +110,12 @@ class ZonesTest extends TestCase
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones'), $this->equalTo('zones'),
$this->equalTo([ $this->equalTo([
'page' => 1, 'page' => 1,
'per_page' => 20, 'per_page' => 20,
'match' => 'all', 'match' => 'all',
'name' => 'example.com', 'name' => 'example.com',
]), ])
$this->equalTo([])
); );
$zones = new \Cloudflare\API\Endpoints\Zones($mock); $zones = new \Cloudflare\API\Endpoints\Zones($mock);
@@ -141,8 +135,7 @@ class ZonesTest extends TestCase
->method('get') ->method('get')
->with( ->with(
$this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/analytics/dashboard'), $this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/analytics/dashboard'),
$this->equalTo([]), $this->equalTo(['since' => '-10080', 'until' => '0', 'continuous' => var_export(true, true)])
$this->equalTo(['since' => '-10080', 'until' => '0', 'continuous' => true])
); );
$zones = new \Cloudflare\API\Endpoints\Zones($mock); $zones = new \Cloudflare\API\Endpoints\Zones($mock);
@@ -151,7 +144,7 @@ class ZonesTest extends TestCase
$this->assertObjectHasAttribute('since', $analytics->totals); $this->assertObjectHasAttribute('since', $analytics->totals);
$this->assertObjectHasAttribute('since', $analytics->timeseries[0]); $this->assertObjectHasAttribute('since', $analytics->timeseries[0]);
} }
public function testChangeDevelopmentMode() public function testChangeDevelopmentMode()
{ {
$response = $this->getPsr7JsonResponseForFixture('Endpoints/changeDevelopmentMode.json'); $response = $this->getPsr7JsonResponseForFixture('Endpoints/changeDevelopmentMode.json');
@@ -163,7 +156,6 @@ class ZonesTest extends TestCase
->method('patch') ->method('patch')
->with( ->with(
$this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/settings/development_mode'), $this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/settings/development_mode'),
$this->equalTo([]),
$this->equalTo(['value' => 'on']) $this->equalTo(['value' => 'on'])
); );
@@ -184,7 +176,6 @@ class ZonesTest extends TestCase
->method('delete') ->method('delete')
->with( ->with(
$this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/purge_cache'), $this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/purge_cache'),
$this->equalTo([]),
$this->equalTo(['purge_everything' => true]) $this->equalTo(['purge_everything' => true])
); );
@@ -193,4 +184,30 @@ class ZonesTest extends TestCase
$this->assertTrue($result); $this->assertTrue($result);
} }
public function testCachePurgeHost()
{
$response = $this->getPsr7JsonResponseForFixture('Endpoints/cachePurgeHost.json');
$mock = $this->getMockBuilder(\Cloudflare\API\Adapter\Adapter::class)->getMock();
$mock->method('delete')->willReturn($response);
$mock->expects($this->once())
->method('delete')
->with(
$this->equalTo('zones/c2547eb745079dac9320b638f5e225cf483cc5cfdda41/purge_cache'),
$this->equalTo(
[
'files' => [],
'tags' => [],
'hosts' => ['dash.cloudflare.com']
]
)
);
$zones = new \Cloudflare\API\Endpoints\Zones($mock);
$result = $zones->cachePurge('c2547eb745079dac9320b638f5e225cf483cc5cfdda41', [], [], ['dash.cloudflare.com']);
$this->assertTrue($result);
}
} }

View File

@@ -0,0 +1,8 @@
{
"success": true,
"errors": [],
"messages": [],
"result": {
"id": "023e105f4ecef8ad9ca31a8372d0c353"
}
}

View File

@@ -0,0 +1,20 @@
{
"success": true,
"errors": [
{}
],
"messages": [
{}
],
"result": {
"id": "0d89c70d-ad9f-4843-b99f-6cc0252067e9",
"hostname": "app.example.com",
"ssl": {
"status": "pending_validation",
"method": "http",
"type": "dv",
"cname_target": "dcv.digicert.com",
"cname": "810b7d5f01154524b961ba0cd578acc2.app.example.com"
}
}
}

View File

@@ -0,0 +1,3 @@
{
"id": "0d89c70d-ad9f-4843-b99f-6cc0252067e9"
}

View File

@@ -0,0 +1,20 @@
{
"success": true,
"errors": [
{}
],
"messages": [
{}
],
"result": {
"id": "0d89c70d-ad9f-4843-b99f-6cc0252067e9",
"hostname": "app.example.com",
"ssl": {
"status": "pending_validation",
"method": "http",
"type": "dv",
"cname_target": "dcv.digicert.com",
"cname": "810b7d5f01154524b961ba0cd578acc2.app.example.com"
}
}
}

View File

@@ -0,0 +1,28 @@
{
"success": true,
"errors": [
{}
],
"messages": [
{}
],
"result": [
{
"id": "0d89c70d-ad9f-4843-b99f-6cc0252067e9",
"hostname": "app.example.com",
"ssl": {
"status": "pending_validation",
"method": "http",
"type": "dv",
"cname_target": "dcv.digicert.com",
"cname": "810b7d5f01154524b961ba0cd578acc2.app.example.com"
}
}
],
"result_info": {
"page": 1,
"per_page": 20,
"count": 1,
"total_count": 2000
}
}

View File

@@ -0,0 +1,20 @@
{
"success": true,
"errors": [
{}
],
"messages": [
{}
],
"result": {
"id": "0d89c70d-ad9f-4843-b99f-6cc0252067e9",
"hostname": "app.example.com",
"ssl": {
"status": "pending_validation",
"method": "http",
"type": "dv",
"cname_target": "dcv.digicert.com",
"cname": "810b7d5f01154524b961ba0cd578acc2.app.example.com"
}
}
}