2017 © Pedro Peláez
 

library cdn-purge-control-php

CDN Purge Control SDK for PHP - Lightweight PHP library to control multiple CDN edge cache.

image

sony/cdn-purge-control-php

CDN Purge Control SDK for PHP - Lightweight PHP library to control multiple CDN edge cache.

  • Thursday, October 6, 2016
  • by shekharhimanshu
  • Repository
  • 9 Watchers
  • 6 Stars
  • 142 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 2 Forks
  • 0 Open issues
  • 5 Versions
  • 0 % Grown

The README.md

CdnPurge, Multi CDN purge control library for PHP

Build Status Stable Version MIT license, (*1)

CdnPurge is a lightweight PHP CDN client which makes it easier to purge contents for multiple CDN providers. Currently, CdnPurge supports AWS CloudFront and Limelight., (*2)

  • Simple common interface to purge contents against multiple CDNs and get purge status.
  • Easily extensible to other CDN providers.
  • Easy code maintenance.
  • Requires PHP >= 5.5 compiled with cURL extension and cURL 7.16.2+ compiled with a TLS backend (e.g. NSS or OpenSSL).
  • Uses Guzzle to make http rest api calls.

Installing CdnPurge

The recommended way to install CdnPurge is through Composer., (*3)

# Install Composer
curl -sS https://getcomposer.org/installer | php

Next, run the Composer command to install the latest stable version of CdnPurge:, (*4)

composer.phar require sony/cdn-purge-control-php

After installing, you need to require Composer's autoloader:, (*5)

require 'vendor/autoload.php';

You can then later update CdnPurge using composer:, (*6)

bash composer.phar update, (*7)

Quick Examples

Make purge request

<?php
// Require the Composer autoloader.
require 'vendor/autoload.php';

use CdnPurge\CdnPurgeFactory;
use CdnPurge\CdnType;

$config = array(
    'cloudfront' => array(
            'distribution_id' => 'your cloudfront distribution id'
        ),
    'limelight' => array(
            'shortname' => 'your limelight api shortname'
            'publish_url' => 'your limelight publish url'
        )
);
$credential = array(
    'cloudfront' => array(
            'key' => 'aws iam account access key id',
            'secret' => 'aws iam account secret access key'
        ),
    'limelight' => array(
            'username' => 'limelight account username',
            'shared_key' => 'limelight account shared key'
        )
);

try {
    // Make a purge request against AWS cloudfront
    $cfClient = CdnPurgeFactory::build(CdnType::CLOUDFRONT, $credential, $config);
    $cfRequestId = $client->createPurgeRequest(array(
        '/my-path-1',
        '/my-path-2'
    ));

    // Make a purge request against Limelight
    $llClient = CdnPurgeFactory::build(CdnType::LIMELIGHT, $credential, $config);
    $llRequestId = $client->createPurgeRequest(array(
        'http://my-limelight-domain/my-path-1',
        '/my-path-2'
    ));

} catch (CdnPurge\CdnClientException $e) {
    echo "An error occurred: " . $e->getMessage();
}

Get purge status

<?php
// Get the purge status
try {
    $client->getPurgeStatus($requestId);
    // 'InProgress' or 'Complete'
} catch (CdnPurge\CdnClientException $e) {
    echo "There was an error getting purge status.\n";
}

See example for a running example of how to use this library., (*8)

Specifying credentials

Credentials are specified as an array., (*9)

AWS CloudFront

Credential key Type Required Description
cloudfront['key'] String Yes AWS IAM user Access Key Id. See here for details
cloudfront['secret'] String Yes AWS IAM user Secret Access Key. See here for details

Limelight

Credential key Type Required Description
limelight['username'] String Yes Limelight account username
limelight['shared_key'] String Yes Limelight account share key

Specifying configurations

Configurations are specified as an array., (*10)

AWS CloudFront

Config key Type Required Description
cloudfront['distribution_id'] String Yes AWS CloudFront Distribution Id
http['proxy'] String No Specify http proxy for the client. For example: 'my-company.proxy.com:1234'

Limelight

Config key Type Required Description
limelight['shortname'] String Yes Limelight api shortname
limelight['publish_url'] String No Limelight publish url. This is prepended to the purge path if the path doesn't start with 'http' or 'https'
limelight['evict'] Boolean No If true, matching cache objects are evicted (deleted), otherwise invalidated. Default is false
limelight['exact'] Boolean No If true, paths to be purged are treated as an exact public URL. Optional. Default is false. Default is false
limelight['incqs'] Boolean No If true, pattern is allowed to match query string part of URL, otherwise query string is stripped before matching. Default is false
limelight['email'] Array No Array of email info to send purge completion details to
limelight['email']['subject'] String No Subject of sent mail
limelight['email']['to'] String Yes Email recipient address. A comma is used to separate multiple recipients
limelight['email']['cc'] String No Email carbon copy. A comma is used to separate multiple recipients
limelight['email']['bcc'] String No Email blind carbon copy. A comma is used to separate multiple recipients
limelight['callback'] Array No HTTP(S) callback URL for purge request state transition notifications
limelight['callback']['url'] String Yes Callback url
http['proxy'] String No Specify http proxy for the client. For example: 'my-company.proxy.com:1234'

Development

License

The MIT License (MIT), (*11)

See LICENSE for details., (*12)

The Versions

06/10 2016

dev-master

9999999-dev

CDN Purge Control SDK for PHP - Lightweight PHP library to control multiple CDN edge cache.

  Sources   Download

MIT

The Requires

 

The Development Requires

cache cdn sdk purge cloudfront limelight

06/10 2016

2.1.1

2.1.1.0

CDN Purge Control SDK for PHP - Lightweight PHP library to control multiple CDN edge cache.

  Sources   Download

MIT

The Requires

 

The Development Requires

cache cdn sdk purge cloudfront limelight

05/10 2016

2.0.1

2.0.1.0

CDN Purge Control SDK for PHP - Lightweight PHP library to control multiple CDN edge cache.

  Sources   Download

MIT

The Requires

 

The Development Requires

cache cdn sdk purge cloudfront limelight

03/10 2016

2.0.0

2.0.0.0

CDN Purge Control SDK for PHP - Lightweight PHP library to control multiple CDN edge cache.

  Sources   Download

MIT

The Requires

 

The Development Requires

cache cdn sdk purge cloudfront limelight

12/01 2016

1.0.0

1.0.0.0

CDN Purge Control SDK for PHP - Lightweight PHP library to control multiple CDN edge cache.

  Sources   Download

MIT

The Requires

 

The Development Requires

cache cdn sdk purge cloudfront limelight