%PDF- %PDF-
Direktori : /home/emergentqj/jugement/wp-content/plugins/wp-rocket/vendor/jamesryanbell/cloudflare/src/CloudFlare/User/LoadBalancers/ |
Current File : /home/emergentqj/jugement/wp-content/plugins/wp-rocket/vendor/jamesryanbell/cloudflare/src/CloudFlare/User/LoadBalancers/Pools.php |
<?php namespace Cloudflare\User\LoadBalancers; use Cloudflare\Api; use Cloudflare\User; /** * CloudFlare API wrapper * * CTM Pool * User-level Cloud Traffic Manager Pool * * @author James Bell <james@james-bell.co.uk> * * @version 1 */ class Pools extends Api { /** * List pools * List configured pools */ public function pools() { return $this->get('/user/load_balancers/pools'); } /** * Create a pool * Create a new pool * * @param string $name Object name * @param array $origins A list of origins contained in the pool. * Traffic destined to the pool is balanced across all * available origins contained in the pool (as long as the pool * is considered available). * @param string|null $description Object description * @param bool|null $enabled Whether this pool is enabled or not. * @param string|null $monitor ID of the monitor object to use for monitoring the health * status of origins inside this pool. * @param string|null $notification_email ID of the notifier object to use for notifications relating * to the health status of origins inside this pool. */ public function create($name, $origins, $description = null, $enabled = null, $monitor = null, $notification_email = null) { $data = [ 'name' => $name, 'origins' => $origins, 'description' => $description, 'enabled' => $enabled, 'monitor' => $monitor, 'notification_email' => $notification_email, ]; return $this->post('/user/load_balancers/pools', $data); } /** * Pool details * Fetch a single configured pool * * @param string $identifier */ public function details($identifier) { return $this->get('/user/load_balancers/pools/'.$identifier); } /** * Modify a pool * Modify a configured pool * * @param string $identifier * @param string $name Object name * @param array $origins A list of origins contained in the pool. * Traffic destined to the pool is balanced across all * available origins contained in the pool (as long as the pool * is considered available). * @param string|null $description Object description * @param bool|null $enabled Whether this pool is enabled or not. * @param string|null $monitor ID of the monitor object to use for monitoring the health * status of origins inside this pool. * @param string|null $notification_email ID of the notifier object to use for notifications relating * to the health status of origins inside this pool. */ public function update($identifier, $name, $origins, $description = null, $enabled = null, $monitor = null, $notification_email = null) { $data = [ 'name' => $name, 'origins' => $origins, 'description' => $description, 'enabled' => $enabled, 'monitor' => $monitor, 'notification_email' => $notification_email, ]; return $this->patch('/user/load_balancers/pools/'.$identifier, $data); } /** * Delete a pool * Delete a configured pool * * @param string $identifier */ public function delete_pool($identifier) { return $this->delete('/user/load_balancers/pools/'.$identifier); } }