You are here

class FastlyCommands in Fastly 8.3

Provides drush commands for Fastly.

Hierarchy

  • class \Drupal\fastly\Commands\FastlyCommands extends \Drush\Commands\DrushCommands

Expanded class hierarchy of FastlyCommands

1 string reference to 'FastlyCommands'
drush.services.yml in ./drush.services.yml
drush.services.yml
1 service uses FastlyCommands
fastly.commands in ./drush.services.yml
Drupal\fastly\Commands\FastlyCommands

File

src/Commands/FastlyCommands.php, line 12

Namespace

Drupal\fastly\Commands
View source
class FastlyCommands extends DrushCommands {

  /**
   * Fastly API.
   *
   * @var \Drupal\fastly\Api
   */
  protected $api;

  /**
   * @var \Drupal\fastly\CacheTagsHash
   */
  protected $cacheTagsHash;

  /**
   * Construct the FastlyCommands object.
   *
   * @param \Drupal\fastly\Api $api
   *   The Fastly API service.
   * @param \Drupal\fastly\CacheTagsHash $cache_tags_hash
   *   CacheTagsHash service.
   */
  public function __construct(Api $api, CacheTagsHash $cache_tags_hash) {
    $this->api = $api;
    $this->cacheTagsHash = $cache_tags_hash;
  }

  /**
   * Purge/invalidate all site content.
   *
   * @command fastly:purge:all
   * @aliases fpall
   */
  public function purgeAll() {
    if ($this->api
      ->purgeAll()) {
      $this
        ->output()
        ->writeln("<info>Successfully purged/invalidated all site content on Fastly.</info>");
    }
    else {
      $this
        ->output()
        ->writeln("<error>Unable to purge/invalidate all site content on Fastly.</error>");
    }
  }

  /**
   * Purge cache by Url.
   *
   * @param string $url
   *   A full URL to purge.
   *
   * @command fastly:purge:url
   * @aliases fpurl
   */
  public function purgeUrl($url = '') {
    if (empty($url)) {
      return;
    }
    if ($this->api
      ->purgeUrl($url)) {
      $this
        ->output()
        ->writeln("<info>Successfully purged url on Fastly.</info>");
    }
    else {
      $this
        ->output()
        ->writeln("<error>Unable to purge url on Fastly.</error>");
    }
  }

  /**
   * Purge cache by key.
   *
   * @param string $keys
   *   A comma-separated list of keys to purge.
   *
   * @command fastly:purge:key
   * @aliases fpkey
   */
  public function purgeKeys($keys = '') {
    if (empty($keys)) {
      return;
    }
    $keys = explode(',', $keys);
    $hashes = $this->cacheTagsHash
      ->cacheTagsToHashes($keys);
    if ($this->api
      ->purgeKeys($hashes)) {
      $this
        ->output()
        ->writeln("<info>Successfully purged key(s) on Fastly.</info>");
    }
    else {
      $this
        ->output()
        ->writeln("<error>Unable to purged key(s) on Fastly.</error>");
    }
  }

  /**
   * Purge whole service.
   *
   * @command fastly:purge:service
   * @aliases fpservice
   */
  public function purgeService() {
    if ($this->api
      ->purgeAll(FALSE)) {
      $this
        ->output()
        ->writeln("<info>Successfully purged whole service on Fastly.</info>");
    }
    else {
      $this
        ->output()
        ->writeln("<error>Unable to purge whole service on Fastly.</error>");
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
FastlyCommands::$api protected property Fastly API.
FastlyCommands::$cacheTagsHash protected property
FastlyCommands::purgeAll public function Purge/invalidate all site content.
FastlyCommands::purgeKeys public function Purge cache by key.
FastlyCommands::purgeService public function Purge whole service.
FastlyCommands::purgeUrl public function Purge cache by Url.
FastlyCommands::__construct public function Construct the FastlyCommands object.