Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added logic to clean root files #5761

Merged
merged 25 commits into from
Jun 28, 2023
Merged
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
88c7d22
Added logic to clean root files
CrochetFeve0251 Feb 15, 2023
265c96f
Fixed issue with the namespace from the WP_Filesystem_Direct
CrochetFeve0251 Feb 17, 2023
6407448
Fixed issue with the namespace from the WP_Filesystem_Direct
CrochetFeve0251 Feb 17, 2023
2c64a20
Merge branch 'develop' into bug/5611-wpml-clean-root-directory
vmanthos Mar 14, 2023
e11950d
Fixed code standards
CrochetFeve0251 Mar 15, 2023
be6e17f
Added logic to clear cache on cache from directory_for_default_language
CrochetFeve0251 Mar 20, 2023
eac9e06
Removed useless data tests
CrochetFeve0251 Mar 20, 2023
4924990
Merge branch 'develop' into bug/5611-wpml-clean-root-directory
vmanthos Mar 28, 2023
8dd7775
Prevent crash on $cache_folder_directory not being an array
CrochetFeve0251 Mar 28, 2023
b1b2c91
Merge remote-tracking branch 'origin/bug/5611-wpml-clean-root-directo…
CrochetFeve0251 Mar 28, 2023
b9040d8
Fixed code standards
CrochetFeve0251 Mar 28, 2023
3521768
Added a reset from preload when changing the option
CrochetFeve0251 Mar 30, 2023
ea6dc87
Merge branch 'develop' into bug/5611-wpml-clean-root-directory
CrochetFeve0251 Mar 30, 2023
e76cc3c
Fixed code standards
CrochetFeve0251 Mar 30, 2023
fba52bc
Added clearing when wpml is disabled or enabled
CrochetFeve0251 Apr 17, 2023
6200af3
Added reset preload to enabled logic
CrochetFeve0251 Apr 17, 2023
3ad6a77
Merge branch 'develop' into bug/5611-wpml-clean-root-directory
vmanthos Apr 19, 2023
243189f
Fixed activation issue
CrochetFeve0251 Apr 19, 2023
acb7a78
Merge remote-tracking branch 'origin/bug/5611-wpml-clean-root-directo…
CrochetFeve0251 Apr 19, 2023
5fa456d
Fixed code standards
CrochetFeve0251 Apr 19, 2023
e5dbcd7
Merge branch 'develop' into bug/5611-wpml-clean-root-directory
vmanthos May 15, 2023
feb0872
Added clean cache on enabled/disable
CrochetFeve0251 May 16, 2023
d7dbad4
Merge branch 'develop' into bug/5611-wpml-clean-root-directory
vmanthos May 18, 2023
12321bc
Fixed QA review
CrochetFeve0251 May 22, 2023
ce96f94
Merge branch 'develop' into bug/5611-wpml-clean-root-directory
vmanthos Jun 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions inc/Engine/Preload/Subscriber.php
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@ public static function get_subscribed_events() {
],
'rocket_after_process_buffer' => 'update_cache_row',
'rocket_deactivation' => 'on_deactivation',
'rocket_reset_preload' => 'on_permalink_changed',
'permalink_structure_changed' => 'on_permalink_changed',
'wp_rocket_upgrade' => [ 'on_update', 16, 2 ],
'rocket_rucss_complete_job_status' => 'clean_url',
Expand Down
105 changes: 99 additions & 6 deletions inc/ThirdParty/Plugins/I18n/WPML.php
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
namespace WP_Rocket\ThirdParty\Plugins\I18n;

use WP_Rocket\Event_Management\Subscriber_Interface;
use WP_Filesystem_Direct;
use WP_Rocket\ThirdParty\ReturnTypesTrait;

/**
Expand All @@ -11,22 +12,46 @@
class WPML implements Subscriber_Interface {
use ReturnTypesTrait;

/**
* Filesystem instance.
*
* @var WP_Filesystem_Direct
*/
protected $filesystem;

/**
* Instantiate class.
*
* @param WP_Filesystem_Direct $filesystem Filesystem instance.
*/
public function __construct( WP_Filesystem_Direct $filesystem = null ) {
$this->filesystem = $filesystem ?: rocket_direct_filesystem();
}


/**
* Events for subscriber to listen to.
*
* @return array
*/
public static function get_subscribed_events() {
if ( ! defined( 'ICL_SITEPRESS_VERSION' ) ) {
return [];
}

$events = [
'rocket_rucss_is_home_url' => [ 'is_secondary_home', 10, 2 ],
'rocket_preload_all_to_pending_condition' => 'clean_only_right_domain',
'rocket_preload_sitemap_before_queue' => 'add_languages_sitemaps',
'activate_sitepress-multilingual-cms/sitepress.php' => 'maybe_clear_on_disable',
'deactivate_sitepress-multilingual-cms/sitepress.php' => 'maybe_clear_on_disable',
];

if ( ! defined( 'ICL_SITEPRESS_VERSION' ) ) {
return $events;
}

$events['rocket_rucss_is_home_url'] = [ 'is_secondary_home', 10, 2 ];
$events['rocket_preload_all_to_pending_condition'] = 'clean_only_right_domain';
$events['rocket_preload_sitemap_before_queue'] = 'add_languages_sitemaps';
$events['after_rocket_clean_home'] = 'remove_root_cached_files';
$events['after_rocket_clean_domain'] = 'remove_root_cached_files';
$events['pre_update_option_icl_sitepress_settings'] = [ 'on_change_directory_for_default_language_clean_cache', 10, 2 ];

return $events;
}

Expand Down Expand Up @@ -100,4 +125,72 @@ public function add_languages_sitemaps( $sitemaps ) {
}
return array_unique( $new_sitemaps );
}

/**
* Remove root files when WPML is active.
*
* @return void
*/
public function remove_root_cached_files() {
$site_url = home_url();
$host_name = wp_parse_url( $site_url, PHP_URL_HOST );
$cache_folder_path = _rocket_get_wp_rocket_cache_path() . $host_name . '/';
$cache_folder_directory = $this->filesystem->dirlist( $cache_folder_path );

if ( ! is_array( $cache_folder_directory ) || ! is_array( array_keys( $cache_folder_directory ) ) ) {
return;
}

foreach ( array_keys( $cache_folder_directory ) as $entry ) {
if ( $this->filesystem->is_dir( $cache_folder_path . $entry ) ) {
continue;
}
$this->filesystem->delete( $cache_folder_path . $entry );
}
}

/**
* Reset cache when changing the option.
*
* @param array $new new configurations.
* @param array $old old configurations.
*
* @return array
*/
public function on_change_directory_for_default_language_clean_cache( $new, $old ) {
if ( ! is_array( $old ) || ! is_array( $new ) ) {
return $new;
}

if ( ! key_exists( 'urls', $old ) || ! key_exists( 'directory_for_default_language', $old['urls'] ) || ! key_exists( 'urls', $new ) || ! key_exists( 'directory_for_default_language', $new['urls'] ) || $new['urls']['directory_for_default_language'] === $old['urls']['directory_for_default_language'] ) {
return $new;
}

/**
* Reset WP Rocket Preload.
*/
do_action( 'rocket_reset_preload' );
rocket_clean_domain();

return $new;
}

/**
* Clear the cache when the option language directory is enabled.
*
* @return void
*/
public function maybe_clear_on_disable() {
$option = get_option( 'icl_sitepress_settings' );
if ( ! $option || ! is_array( $option ) || ! key_exists( 'urls', $option ) || ! key_exists( 'directory_for_default_language', $option['urls'] ) || false === $option['urls']['directory_for_default_language'] ) {
return;
}

/**
* Reset WP Rocket Preload.
*/
do_action( 'rocket_reset_preload' );
rocket_clean_cache_dir();
rocket_clean_domain();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
<?php
return [
'noFieldsShouldNotClean' => [
'config' => [
'old' => [

],
'new' => [

],
'should_clean' => false,
],
'expected' => [

]
],
'SameFieldsShouldNotClean' => [
'config' => [
'old' => [
'urls' => [
'directory_for_default_language' => false,
]
],
'new' => [
'urls' => [
'directory_for_default_language' => false,
]
],
'should_clean' => false,
],
'expected' => [
'urls' => [
'directory_for_default_language' => false,
]
]
],
'differentFieldsShouldClean' => [
'config' => [
'old' => [
'urls' => [
'directory_for_default_language' => false,
]
],
'new' => [
'urls' => [
'directory_for_default_language' => true,
]
],
'should_clean' => true,
],
'expected' => [
'urls' => [
'directory_for_default_language' => true,
]
]
],

];
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
<?php
return [
'removeFilesOnRoot' => [
'config' => [
'home_url' => 'https/example.org',
'host' => 'example.org',
'entries' => [
'entry_path' => [],
],
'path' => 'path',
'cache_path' => 'pathexample.org/',
'entry_path' => 'pathexample.org/entry_path',
],
],
];
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
<?php

namespace WP_Rocket\Tests\Unit\inc\ThirdParty\Plugins\I18n\WPML;

use WP_Rocket\ThirdParty\Plugins\I18n\WPML;
use Mockery;
use WP_Filesystem_Direct;


use WP_Rocket\Tests\Unit\TestCase;
use Brain\Monkey\Functions;

/**
* @covers \WP_Rocket\ThirdParty\Plugins\I18n\WPML::on_change_directory_for_default_language_clean_cache
*/
class Test_onChangeDirectoryForDefaultLanguageCleanCache extends TestCase {

/**
* @var WP_Filesystem_Direct
*/
protected $filesystem;

/**
* @var WPML
*/
protected $wpml;

public function set_up() {
parent::set_up();
$this->filesystem = Mockery::mock(WP_Filesystem_Direct::class);

$this->wpml = new WPML($this->filesystem);
}

/**
* @dataProvider configTestData
*/
public function testShouldReturnAsExpected( $config, $expected )
{
if($config['should_clean']) {
Functions\expect('rocket_clean_domain');
} else {
Functions\expect('rocket_clean_domain')->never();
}
$this->assertSame($expected, $this->wpml->on_change_directory_for_default_language_clean_cache($config['new'], $config['old']));

}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
<?php

namespace WP_Rocket\Tests\Unit\inc\ThirdParty\Plugins\I18n\WPML;

use Mockery;
use WP_Filesystem_Direct;
use WP_Rocket\Tests\Unit\TestCase;
use WP_Rocket\ThirdParty\Plugins\I18n\WPML;
use Brain\Monkey\Functions;
use Brain\Monkey\Filters;

class Test_RemoveRootCachedFiles extends TestCase
{
protected $subscriber;
protected $filesystem;

protected function set_up()
{
parent::set_up();
$this->filesystem = Mockery::mock( WP_Filesystem_Direct::class );
$this->subscriber = new WPML($this->filesystem);
}

/**
* @dataProvider configTestData
*/
public function testShouldAsExpected( $config ) {
Functions\expect('home_url')->andReturn($config['home_url']);
Functions\expect('wp_parse_url')->with($config['home_url'], PHP_URL_HOST)->andReturn($config['host']);
Functions\expect('_rocket_get_wp_rocket_cache_path')->with($config['home_url'], PHP_URL_HOST)->andReturn($config['path']);
$this->filesystem->expects()->dirlist($config['cache_path'])->andReturn($config['entries']);
$this->filesystem->expects()->is_dir($config['entry_path'])->andReturn(false);
$this->filesystem->expects()->delete($config['entry_path']);
$this->subscriber->remove_root_cached_files();
}
}