<?php
class ITSEC_System_Tweaks_Setup {
public function __construct() {
add_action( 'itsec_modules_do_plugin_uninstall', array( $this, 'execute_uninstall' ) );
add_action( 'itsec_modules_do_plugin_upgrade', array( $this, 'execute_upgrade' ) );
}
/**
* Execute module uninstall
*
* @return void
*/
public function execute_uninstall() {
delete_site_option( 'itsec_tweaks' );
}
/**
* Execute module upgrade
*
* @since 4.0
*
* @return void
*/
public function execute_upgrade( $itsec_old_version ) {
if ( $itsec_old_version < 4000 ) {
global $itsec_bwps_options;
ITSEC_Lib::create_database_tables();
$current_options = get_site_option( 'itsec_tweaks' );
// Don't do anything if settings haven't already been set, defaults exist in the module system and we prefer to use those
if ( false !== $current_options ) {
$current_options['protect_files'] = isset( $itsec_bwps_options['st_ht_files'] ) && $itsec_bwps_options['st_ht_files'] == 1 ? true : false;
$current_options['directory_browsing'] = isset( $itsec_bwps_options['st_ht_browsing'] ) && $itsec_bwps_options['st_ht_browsing'] == 1 ? true : false;
$current_options['request_methods'] = isset( $itsec_bwps_options['st_ht_request'] ) && $itsec_bwps_options['st_ht_request'] == 1 ? true : false;
$current_options['suspicious_query_strings'] = isset( $itsec_bwps_options['st_ht_query'] ) && $itsec_bwps_options['st_ht_query'] == 1 ? true : false;
$current_options['non_english_characters'] = isset( $itsec_bwps_options['st_ht_foreign'] ) && $itsec_bwps_options['st_ht_foreign'] == 1 ? true : false;
$current_options['long_url_strings'] = isset( $itsec_bwps_options['st_longurl'] ) && $itsec_bwps_options['st_longurl'] == 1 ? true : false;
$current_options['write_permissions'] = isset( $itsec_bwps_options['st_fileperm'] ) && $itsec_bwps_options['st_fileperm'] == 1 ? true : false;
update_site_option( 'itsec_tweaks', $current_options );
ITSEC_Response::regenerate_wp_config();
}
}
if ( $itsec_old_version < 4041 ) {
$current_options = get_site_option( 'itsec_tweaks' );
// If there are no current options, go with the new defaults by not saving anything
if ( is_array( $current_options ) ) {
$new_module_settings = ITSEC_Modules::get_settings( 'system-tweaks' );
// Reduce to only settings in new module
$current_options = array_intersect_key( $current_options, $new_module_settings );
// Use new module settings as defaults for any missing settings
$current_options = array_merge( $new_module_settings, $current_options );
// If anything in this module is being used activate it, otherwise deactivate it
$activate = false;
foreach ( $current_options as $on ) {
if ( $on ) {
$activate = true;
break;
}
}
if ( $activate ) {
ITSEC_Modules::activate( 'system-tweaks' );
} else {
ITSEC_Modules::deactivate( 'system-tweaks' );
}
ITSEC_Modules::set_settings( 'system-tweaks', $current_options );
}
}
if ( $itsec_old_version < 4095 ) {
ITSEC_Response::regenerate_server_config();
}
if ( $itsec_old_version < 4123 ) {
if ( ITSEC_Modules::get_setting( 'system-tweaks', 'write_permissions' ) ) {
@chmod( ITSEC_Lib::get_htaccess(), 0644 );
@chmod( ITSEC_Lib::get_config(), 0644 );
}
// System Tweaks is now active by default, if the user has it deactivated,
// we need to turn off all the options so their site functions the same on update.
$active = get_site_option( 'itsec_active_modules', [] );
if ( empty( $active['system-tweaks'] ) ) {
$settings = ITSEC_Modules::get_settings( 'system-tweaks' );
$disable = [
'protect_files' => false,
'directory_browsing' => false,
'uploads_php' => false,
'themes_php' => false,
'plugins_php' => false,
];
ITSEC_Modules::set_settings( 'system-tweaks', array_merge( $settings, $disable ) );
}
}
}
}
new ITSEC_System_Tweaks_Setup();