| @@ 24-79 (lines=56) @@ | ||
| 21 | * |
|
| 22 | * @author David Buchmann <[email protected]> |
|
| 23 | */ |
|
| 24 | class InvalidatePathCommand extends BaseInvalidateCommand |
|
| 25 | { |
|
| 26 | /** |
|
| 27 | * @var string |
|
| 28 | */ |
|
| 29 | private $commandName; |
|
| 30 | ||
| 31 | /** |
|
| 32 | * If no cache manager is specified explicitly, fos_http_cache.cache_manager |
|
| 33 | * is automatically loaded. |
|
| 34 | * |
|
| 35 | * @param CacheManager|null $cacheManager The cache manager to talk to. |
|
| 36 | * @param string $commandName Name of this command, in case you want to reuse it. |
|
| 37 | */ |
|
| 38 | public function __construct(CacheManager $cacheManager = null, $commandName = 'fos:httpcache:invalidate:path') |
|
| 39 | { |
|
| 40 | $this->commandName = $commandName; |
|
| 41 | parent::__construct($cacheManager); |
|
| 42 | } |
|
| 43 | ||
| 44 | /** |
|
| 45 | * {@inheritdoc} |
|
| 46 | */ |
|
| 47 | protected function configure() |
|
| 48 | { |
|
| 49 | $this |
|
| 50 | ->setName($this->commandName) |
|
| 51 | ->setDescription('Invalidate cached paths on all configured caching proxies') |
|
| 52 | ->addArgument( |
|
| 53 | 'paths', |
|
| 54 | InputArgument::IS_ARRAY | InputArgument::REQUIRED, |
|
| 55 | 'URL paths you want to invalidate, you can specify any number of paths' |
|
| 56 | ) |
|
| 57 | ->setHelp(<<<'EOF' |
|
| 58 | The <info>%command.name%</info> command invalidates a list of paths on the configured caching proxies. |
|
| 59 | ||
| 60 | Example: |
|
| 61 | ||
| 62 | <info>php %command.full_name% /some/path /other/path</info> |
|
| 63 | EOF |
|
| 64 | ) |
|
| 65 | ; |
|
| 66 | } |
|
| 67 | ||
| 68 | /** |
|
| 69 | * {@inheritdoc} |
|
| 70 | */ |
|
| 71 | protected function execute(InputInterface $input, OutputInterface $output) |
|
| 72 | { |
|
| 73 | $paths = $input->getArgument('paths'); |
|
| 74 | ||
| 75 | foreach ($paths as $path) { |
|
| 76 | $this->getCacheManager()->invalidatePath($path); |
|
| 77 | } |
|
| 78 | } |
|
| 79 | } |
|
| 80 | ||
| @@ 25-82 (lines=58) @@ | ||
| 22 | * @author Christian Stocker <[email protected]> |
|
| 23 | * @author David Buchmann <[email protected]> |
|
| 24 | */ |
|
| 25 | class InvalidateRegexCommand extends BaseInvalidateCommand |
|
| 26 | { |
|
| 27 | /** |
|
| 28 | * @var string |
|
| 29 | */ |
|
| 30 | private $commandName; |
|
| 31 | ||
| 32 | /** |
|
| 33 | * If no cache manager is specified explicitly, fos_http_cache.cache_manager |
|
| 34 | * is automatically loaded. |
|
| 35 | * |
|
| 36 | * @param CacheManager|null $cacheManager The cache manager to talk to. |
|
| 37 | * @param string $commandName Name of this command, in case you want to reuse it. |
|
| 38 | */ |
|
| 39 | public function __construct(CacheManager $cacheManager = null, $commandName = 'fos:httpcache:invalidate:regex') |
|
| 40 | { |
|
| 41 | $this->commandName = $commandName; |
|
| 42 | parent::__construct($cacheManager); |
|
| 43 | } |
|
| 44 | ||
| 45 | /** |
|
| 46 | * {@inheritdoc} |
|
| 47 | */ |
|
| 48 | protected function configure() |
|
| 49 | { |
|
| 50 | $this |
|
| 51 | ->setName($this->commandName) |
|
| 52 | ->setDescription('Invalidate everything matching a regular expression on all configured caching proxies') |
|
| 53 | ->addArgument( |
|
| 54 | 'regex', |
|
| 55 | InputArgument::REQUIRED, |
|
| 56 | 'Regular expression for the paths to match.' |
|
| 57 | ) |
|
| 58 | ->setHelp(<<<'EOF' |
|
| 59 | The <info>%command.name%</info> command invalidates all cached content matching a regular expression on the configured caching proxies. |
|
| 60 | ||
| 61 | Example: |
|
| 62 | ||
| 63 | <info>php %command.full_name% "/some.*/path" </info> |
|
| 64 | ||
| 65 | or clear the whole cache |
|
| 66 | ||
| 67 | <info>php %command.full_name% .</info> |
|
| 68 | EOF |
|
| 69 | ) |
|
| 70 | ; |
|
| 71 | } |
|
| 72 | ||
| 73 | /** |
|
| 74 | * {@inheritdoc} |
|
| 75 | */ |
|
| 76 | protected function execute(InputInterface $input, OutputInterface $output) |
|
| 77 | { |
|
| 78 | $regex = $input->getArgument('regex'); |
|
| 79 | ||
| 80 | $this->getCacheManager()->invalidateRegex($regex); |
|
| 81 | } |
|
| 82 | } |
|
| 83 | ||
| @@ 24-79 (lines=56) @@ | ||
| 21 | * |
|
| 22 | * @author David Buchmann <[email protected]> |
|
| 23 | */ |
|
| 24 | class RefreshPathCommand extends BaseInvalidateCommand |
|
| 25 | { |
|
| 26 | /** |
|
| 27 | * @var string |
|
| 28 | */ |
|
| 29 | private $commandName; |
|
| 30 | ||
| 31 | /** |
|
| 32 | * If no cache manager is specified explicitly, fos_http_cache.cache_manager |
|
| 33 | * is automatically loaded. |
|
| 34 | * |
|
| 35 | * @param CacheManager|null $cacheManager The cache manager to talk to. |
|
| 36 | * @param string $commandName Name of this command, in case you want to reuse it. |
|
| 37 | */ |
|
| 38 | public function __construct(CacheManager $cacheManager = null, $commandName = 'fos:httpcache:refresh:path') |
|
| 39 | { |
|
| 40 | $this->commandName = $commandName; |
|
| 41 | parent::__construct($cacheManager); |
|
| 42 | } |
|
| 43 | ||
| 44 | /** |
|
| 45 | * {@inheritdoc} |
|
| 46 | */ |
|
| 47 | protected function configure() |
|
| 48 | { |
|
| 49 | $this |
|
| 50 | ->setName($this->commandName) |
|
| 51 | ->setDescription('Refresh paths on all configured caching proxies') |
|
| 52 | ->addArgument( |
|
| 53 | 'paths', |
|
| 54 | InputArgument::IS_ARRAY | InputArgument::REQUIRED, |
|
| 55 | 'URL paths you want to refresh, you can specify any number of paths' |
|
| 56 | ) |
|
| 57 | ->setHelp(<<<'EOF' |
|
| 58 | The <info>%command.name%</info> command refreshes a list of paths on the configured caching proxies. |
|
| 59 | ||
| 60 | Example: |
|
| 61 | ||
| 62 | <info>php %command.full_name% /some/path /other/path</info> |
|
| 63 | EOF |
|
| 64 | ) |
|
| 65 | ; |
|
| 66 | } |
|
| 67 | ||
| 68 | /** |
|
| 69 | * {@inheritdoc} |
|
| 70 | */ |
|
| 71 | protected function execute(InputInterface $input, OutputInterface $output) |
|
| 72 | { |
|
| 73 | $paths = $input->getArgument('paths'); |
|
| 74 | ||
| 75 | foreach ($paths as $path) { |
|
| 76 | $this->getCacheManager()->refreshPath($path); |
|
| 77 | } |
|
| 78 | } |
|
| 79 | } |
|
| 80 | ||