File "settings.php"
Full Path: /home/lacostenacom/public_html/wp/wp-content/plugins/cookieadmin/includes/admin/settings.php
File size: 19.83 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace CookieAdmin\Admin;
if(!defined('COOKIEADMIN_VERSION') || !defined('ABSPATH')){
die('Hacking Attempt');
}
class Settings{
static function settings(){
global $cookieadmin, $cookieadmin_lang, $cookieadmin_error, $cookieadmin_msg, $cookieadmin_settings;
$view = get_option('cookieadmin_law', 'cookieadmin_gdpr');
$policy = cookieadmin_load_policy();
$cookieadmin_requires_pro = \CookieAdmin\Admin::is_feature_available(1);
\CookieAdmin\Admin::header_theme(__('Settings', 'cookieadmin'));
echo '
<div class="cookieadmin_consent-wrap">
<form action="" method="post" id="setting_submenu">
<div class="cookieadmin-card">
<div class="cookieadmin-card-header">
<span class="cookieadmin-card-title"><span class="dashicons dashicons-download"></span> '.esc_html__('Cookie Loading', 'cookieadmin').'</span>
</div>
<div class="cookieadmin-card-body">
<div class="cookieadmin-setting">
<label class="cookieadmin-title">'.esc_html__('Load cookies prior to consent', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Selected category of cookies will be loaded before user consent.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-horizontal" style="cursor:pointer; font-weight:400;">
<input name="cookieadmin_preload[]" type="checkbox" value="necessary" checked disabled>
'.esc_html__('Necessary', 'cookieadmin').'
</label>
<label class="cookieadmin-horizontal" style="cursor:pointer; font-weight:400;">
<input name="cookieadmin_preload[]" type="checkbox" id="functional_preload" value="functional" '.(!empty($policy[$view]['preload']) && in_array("functional", $policy[$view]['preload']) ? 'checked' : '').'>
'.esc_html__('Functional', 'cookieadmin').'
</label>
<label class="cookieadmin-horizontal" style="cursor:pointer; font-weight:400;">
<input name="cookieadmin_preload[]" type="checkbox" id="analytics_preload" value="analytics" '.(!empty($policy[$view]['preload']) && in_array("analytics", $policy[$view]['preload']) ? 'checked' : '').'>
'.esc_html__('Analytical', 'cookieadmin').'
</label>
<label class="cookieadmin-horizontal" style="cursor:pointer; font-weight:400;">
<input name="cookieadmin_preload[]" type="checkbox" id="marketing_preload" value="marketing" '.(!empty($policy[$view]['preload']) && in_array("marketing", $policy[$view]['preload']) ? 'checked' : '').'>
'.esc_html__('Advertisement', 'cookieadmin').'
</label>
<div class="cookieadmin-collapsible-notice" style="display:'.(!empty($policy[$view]['preload'])? 'block':'none').'">'.esc_html__('Loading cookies prior to receiving user consent will make your website non-compliant with GDPR.', 'cookieadmin').'</div>
</div>
</div>
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_reload_on_consent">'.esc_html__('Reload page on consent', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Page will be loaded on user consent.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_reload_on_consent" type="checkbox" id="cookieadmin_reload_on_consent" '.(!empty($policy[$view]['reload_on_consent']) ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
</div>
</div>';
// Card: Advanced Features (PRO)
echo '
<div class="cookieadmin-card cookieadmin-mt-16" cookieadmin-pro-only="1">
<div class="cookieadmin-card-header">
<span class="cookieadmin-card-title"><span class="dashicons dashicons-star-filled"></span> '.esc_html__('Advanced Features', 'cookieadmin').wp_kses_post($cookieadmin_requires_pro).'</span>
</div>
<div class="cookieadmin-card-body">
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_google_consent_mode_v2">'.esc_html__('Google Consent Mode v2', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Enable Google consent mode v2.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_google_consent_mode_v2" type="checkbox" id="cookieadmin_google_consent_mode_v2" '.(!empty($cookieadmin_settings['google_consent_mode_v2']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_clarity_consent">'.esc_html__('Clarity Consent Mode V2', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Enable Microsoft Clarity consent mode v2.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_clarity_consent" type="checkbox" id="cookieadmin_clarity_consent" '.(!empty($cookieadmin_settings['clarity_consent']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_hide_powered_by">'.esc_html__('Hide Powered by Link', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Hide powered by CookieAdmin on banner.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_hide_powered_by" type="checkbox" id="cookieadmin_hide_powered_by" '.(!empty($cookieadmin_settings['hide_powered_by']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_hide_reconsent">'.esc_html__('Hide Re-consent Icon', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Hide reconsent icon after user consent.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_hide_reconsent" type="checkbox" id="cookieadmin_hide_reconsent" '.(!empty($cookieadmin_settings['hide_reconsent']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_auto_scan">'.esc_html__('Auto Cookies Scan', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Monthly auto scan will detect cookies.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_auto_scan" type="checkbox" id="cookieadmin_auto_scan" '.(!empty($cookieadmin_settings['cookieadmin_auto_scan']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_shared_subdomain_consent">'.esc_html__('Shared Subdomain Consent', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Enable shared consent across subdomains.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_shared_subdomain_consent" type="checkbox" id="cookieadmin_shared_subdomain_consent" '.(!empty($cookieadmin_settings['shared_subdomain_consent']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
<div class="cookieadmin-setting setting-blocking">
<label class="cookieadmin-title" for="cookieadmin_content_blocking">'.esc_html__('Content Blocking', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Block third-party content which uses iframes to load cookies until user consent is given.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_content_blocking" type="checkbox" id="cookieadmin_content_blocking" '.(!empty($cookieadmin_settings['content_blocking']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
<div class="cookieadmin-content-blocking-options" style="display: '.(!empty($cookieadmin_settings['content_blocking']) ? 'block' : 'none').';">
<div class="cookieadmin-cb-services">
<label class="cookieadmin-title"><input type="checkbox" name="cookieadmin_content_blocking_services[]" value="youtube" '.(!empty($cookieadmin_settings['content_blocking_services']) && in_array('youtube', $cookieadmin_settings['content_blocking_services']) ? 'checked' : '').'> '.esc_html__('YouTube', 'cookieadmin').'</label>
<label class="cookieadmin-title"><input type="checkbox" name="cookieadmin_content_blocking_services[]" value="vimeo" '.(!empty($cookieadmin_settings['content_blocking_services']) && in_array('vimeo', $cookieadmin_settings['content_blocking_services']) ? 'checked' : '').'> '.esc_html__('Vimeo', 'cookieadmin').'</label>
<label class="cookieadmin-title"><input type="checkbox" name="cookieadmin_content_blocking_services[]" value="soundcloud" '.(!empty($cookieadmin_settings['content_blocking_services']) && in_array('soundcloud', $cookieadmin_settings['content_blocking_services']) ? 'checked' : '').'> '.esc_html__('SoundCloud', 'cookieadmin').'</label>
<label class="cookieadmin-title"><input type="checkbox" name="cookieadmin_content_blocking_services[]" value="dailymotion" '.(!empty($cookieadmin_settings['content_blocking_services']) && in_array('dailymotion', $cookieadmin_settings['content_blocking_services']) ? 'checked' : '').'> '.esc_html__('Dailymotion', 'cookieadmin').'</label>
<label class="cookieadmin-title"><input type="checkbox" name="cookieadmin_content_blocking_services[]" value="maps" '.(!empty($cookieadmin_settings['content_blocking_services']) && in_array('maps', $cookieadmin_settings['content_blocking_services']) ? 'checked' : '').'> '.esc_html__('Google Maps', 'cookieadmin').'</label>
</div>
</div>
</div>
</div>';
// Card: Data Management (PRO)
echo '
<div class="cookieadmin-card cookieadmin-mt-16" cookieadmin-pro-only="1">
<div class="cookieadmin-card-header">
<span class="cookieadmin-card-title"><span class="dashicons dashicons-database"></span> '.esc_html__('Data Management', 'cookieadmin').wp_kses_post($cookieadmin_requires_pro).'</span>
</div>
<div class="cookieadmin-card-body">
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_consent_logs_expiry">'.esc_html__('Consent Log Cleanup', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Daily auto delete consent logs older than the set limit.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_consent_logs_expiry" type="checkbox" id="cookieadmin_consent_logs_expiry" '.(!empty($cookieadmin_settings['consent_logs_expiry']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
<input name="cookieadmin_consent_logs_expiry_days" id="cookieadmin_consent_logs_expiry_days" class="cookieadmin-tooltip-box" value="'.((!empty($cookieadmin_settings['consent_logs_expiry_days']) && cookieadmin_is_pro()) ? esc_attr($cookieadmin_settings['consent_logs_expiry_days']) : '365').'" data-tip="'.esc_html__('Keep consent logs for these many days', 'cookieadmin').'" style="width:60px; text-align:center; margin:0 10px;">
<input type="button" class="cookieadmin-btn cookieadmin-btn-sm '.((cookieadmin_is_pro()) ? ' cookieadmin-btn-danger cookieadmin-tooltip-box cookieadmin-purge-consent-btn' : '').'" data-tip="'.esc_html__('Delete consent logs older than the set limit (runs once)', 'cookieadmin').'" value="'.esc_html__('Delete Now', 'cookieadmin').'"/>
</div>
</div>
</div>
</div>';
// Card: Global Privacy Control (PRO)
echo '
<div class="cookieadmin-card cookieadmin-mt-16" cookieadmin-pro-only="1">
<div class="cookieadmin-card-header">
<span class="cookieadmin-card-title"><span class="dashicons dashicons-privacy"></span> '.esc_html__('Global Privacy Control', 'cookieadmin').wp_kses_post($cookieadmin_requires_pro).'</span>
</div>
<div class="cookieadmin-card-body">
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_respect_gpc">'.esc_html__('Respect GPC', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Automatically honor GPC signals from browsers. When enabled, users with GPC enabled will automatically have non-essential cookies rejected.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<label class="cookieadmin-toggle-wrap">
<input name="cookieadmin_respect_gpc" type="checkbox" id="cookieadmin_respect_gpc" '.(!empty($cookieadmin_settings['respect_gpc']) && cookieadmin_is_pro() ? 'checked' : '').'>
<div class="cookieadmin-toggle-track">
<div class="cookieadmin-toggle-thumb"></div>
</div>
</label>
</div>
</div>
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_gpc_message">'.esc_html__('GPC Message', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Custom message shown when GPC preference is honored.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<textarea name="cookieadmin_gpc_message" id="cookieadmin_gpc_message" rows="4" style="width:100%; max-width:500px;" '.(!cookieadmin_is_pro() ? 'disabled' : '').'>'.esc_textarea(!empty($cookieadmin_settings['gpc_message']) ? $cookieadmin_settings['gpc_message'] : (!empty($cookieadmin['gpc_message_default']) ? $cookieadmin['gpc_message_default'] : '')).'</textarea>
</div>
</div>
<div class="cookieadmin-setting">
<label class="cookieadmin-title" for="cookieadmin_gpc_override_warning">'.esc_html__('GPC Override Warning', 'cookieadmin').'
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Warning shown when user tries to enable cookies while GPC signal is active.', 'cookieadmin').'"></span>
</label>
<div class="cookieadmin-setting-contents">
<textarea name="cookieadmin_gpc_override_warning" id="cookieadmin_gpc_override_warning" rows="4" style="width:100%; max-width:500px;" '.(!cookieadmin_is_pro() ? 'disabled' : '').'>'.esc_textarea(!empty($cookieadmin_settings['gpc_override_warning']) ? $cookieadmin_settings['gpc_override_warning'] : (!empty($cookieadmin['gpc_override_warning_default']) ? $cookieadmin['gpc_override_warning_default'] : '')).'</textarea>
</div>
</div>
</div>
</div>';
wp_nonce_field('cookieadmin_admin_nonce', 'cookieadmin_security');
echo '
<div class="cookieadmin-save-bar">
<input type="submit" name="cookieadmin_save_settings" class="cookieadmin-btn cookieadmin-btn-primary" value="'.esc_html__('Save Settings', 'cookieadmin').'">
</div>
</form>
</div>';
\CookieAdmin\Admin::footer_theme();
}
static function save_settings(){
global $cookieadmin_lang, $cookieadmin_error, $cookieadmin_msg, $cookieadmin_settings, $cookieadmin_policies;
// debug_print_backtrace();die;
check_admin_referer('cookieadmin_admin_nonce', 'cookieadmin_security');
if(!current_user_can('administrator')){
wp_send_json_error(array('message' => __('Sorry, but you do not have permissions to perform this action', 'cookieadmin')));
}
$cookieadmin_settings = get_option('cookieadmin_settings', []);
// Save cookieadmin_settings only on settings page
$cookieadmin_settings['google_consent_mode_v2'] = (isset( $_REQUEST['cookieadmin_google_consent_mode_v2'] ) ? 1 : 0);
$cookieadmin_settings['hide_powered_by'] = (isset( $_REQUEST['cookieadmin_hide_powered_by'] ) ? 1 : 0);
$cookieadmin_settings['hide_reconsent'] = (isset( $_REQUEST['cookieadmin_hide_reconsent'] ) ? 1 : 0);
$cookieadmin_settings['cookieadmin_auto_scan'] = (isset( $_REQUEST['cookieadmin_auto_scan'] ) ? 1 : 0);
$cookieadmin_settings['consent_logs_expiry'] = (isset( $_REQUEST['cookieadmin_consent_logs_expiry'] ) ? sanitize_text_field(wp_unslash($_REQUEST['cookieadmin_consent_logs_expiry'])) : 0);
$cookieadmin_settings['consent_logs_expiry_days'] = (isset( $_REQUEST['cookieadmin_consent_logs_expiry_days'] ) ? sanitize_text_field(wp_unslash($_REQUEST['cookieadmin_consent_logs_expiry_days'])) : 365);
$cookieadmin_settings['clarity_consent'] = !empty($_REQUEST['cookieadmin_clarity_consent']);
$cookieadmin_settings['shared_subdomain_consent'] = !empty($_REQUEST['cookieadmin_shared_subdomain_consent']);
$cookieadmin_settings['content_blocking'] = !empty($_REQUEST['cookieadmin_content_blocking']);
$cookieadmin_settings['content_blocking_services'] = [];
if(!empty($_REQUEST['cookieadmin_content_blocking_services'])){
$cookieadmin_settings['content_blocking_services'] = array_map('sanitize_text_field', wp_unslash($_REQUEST['cookieadmin_content_blocking_services']));
}
if(empty($cookieadmin_error)){
update_option('cookieadmin_settings', $cookieadmin_settings);
}
//Clear schedule if logs deletion is disabled
if(empty($cookieadmin_settings['consent_logs_expiry'])){
wp_clear_scheduled_hook('cookieadmin_daily_consent_log_pruning');
}
//Clear schedule if auto scan is disabled
if(empty($cookieadmin_settings['cookieadmin_auto_scan'])){
wp_clear_scheduled_hook('cookieadmin_run_auto_cookie_scan');
}
// get the consent type from option table, if not saved then return default as 'gdpr'
$law = get_option('cookieadmin_law', 'cookieadmin_gdpr');
$policy = cookieadmin_load_policy();
//set preload and consent field for "cookieadmin-settings" page
$policy[$law]['preload'] = !empty($_REQUEST['cookieadmin_preload']) ? array_map('sanitize_text_field', wp_unslash($_REQUEST['cookieadmin_preload'])) : [];
$policy[$law]['reload_on_consent'] = !empty($_REQUEST['cookieadmin_reload_on_consent']) ? sanitize_text_field(wp_unslash($_REQUEST['cookieadmin_reload_on_consent'])) : '';
update_option('cookieadmin_consent_settings', $policy);
if(empty($cookieadmin_error)){
$cookieadmin_msg = __('Settings saved successfully', 'cookieadmin');
}
}
}