Edit File by line
/home/zeestwma/ceyloniy.../wp-conte.../plugins/cookiead.../includes/admin
File: settings.php
<?php
[0] Fix | Delete
[1] Fix | Delete
namespace CookieAdmin\Admin;
[2] Fix | Delete
[3] Fix | Delete
if(!defined('COOKIEADMIN_VERSION') || !defined('ABSPATH')){
[4] Fix | Delete
die('Hacking Attempt');
[5] Fix | Delete
}
[6] Fix | Delete
[7] Fix | Delete
class Settings{
[8] Fix | Delete
[9] Fix | Delete
static function settings(){
[10] Fix | Delete
global $cookieadmin_lang, $cookieadmin_error, $cookieadmin_msg, $cookieadmin_settings;
[11] Fix | Delete
[12] Fix | Delete
$view = get_option('cookieadmin_law', 'cookieadmin_gdpr');
[13] Fix | Delete
$policy = cookieadmin_load_policy();
[14] Fix | Delete
[15] Fix | Delete
$cookieadmin_requires_pro = \CookieAdmin\Admin::is_feature_available(1);
[16] Fix | Delete
[17] Fix | Delete
\CookieAdmin\Admin::header_theme(__('Settings', 'cookieadmin'));
[18] Fix | Delete
[19] Fix | Delete
echo '
[20] Fix | Delete
<div class="cookieadmin_consent-wrap">
[21] Fix | Delete
<form action="" method="post" id="setting_submenu">
[22] Fix | Delete
[23] Fix | Delete
<div class="cookieadmin_consent-contents">
[24] Fix | Delete
<div class="cookieadmin_consent_settings">
[25] Fix | Delete
<div class="cookieadmin-contents cookieadmin-settings">
[26] Fix | Delete
<div class="cookieadmin-setting setting-prior">
[27] Fix | Delete
<label class="cookieadmin-title">'.esc_html__('Load Cookies prior to consent', 'cookieadmin').'
[28] Fix | Delete
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Selected category of cookies will be loaded before user consent.', 'cookieadmin').'"></span>
[29] Fix | Delete
</label>
[30] Fix | Delete
<div class="cookieadmin-setting-contents">
[31] Fix | Delete
[32] Fix | Delete
<input name="cookieadmin_preload[]" type="checkbox" id="necessary_preload" value="necessary" checked disabled>
[33] Fix | Delete
<label class="cookieadmin-input" for="necessary_preload">'.esc_html__('Necessary', 'cookieadmin').'</label>
[34] Fix | Delete
[35] Fix | Delete
<input name="cookieadmin_preload[]" type="checkbox" id="functional_preload" value="functional" '.(!empty($policy[$view]['preload']) && in_array("functional", $policy[$view]['preload']) ? 'checked' : '').'>
[36] Fix | Delete
<label class="cookieadmin-input" for="functional_preload">'.esc_html__('Functional', 'cookieadmin').'</label>
[37] Fix | Delete
[38] Fix | Delete
<input name="cookieadmin_preload[]" type="checkbox" id="analytics_preload" value="analytics" '.(!empty($policy[$view]['preload']) && in_array("analytics", $policy[$view]['preload']) ? 'checked' : '').'>
[39] Fix | Delete
<label class="cookieadmin-input" for="analytics_preload">'.esc_html__('Analytical', 'cookieadmin').'</label>
[40] Fix | Delete
[41] Fix | Delete
<input name="cookieadmin_preload[]" type="checkbox" id="marketing_preload" value="marketing" '.(!empty($policy[$view]['preload']) && in_array("marketing", $policy[$view]['preload']) ? 'checked' : '').'>
[42] Fix | Delete
<label for="marketing_preload">'.esc_html__('Advertisement', 'cookieadmin').'</label>
[43] Fix | Delete
</div>
[44] Fix | Delete
</div>'.(!empty($policy[$view]['preload']) ? '<p class="cookieadmin-collapsible-notice">'.esc_html__('Loading cookies prior to receiving user consent will make your website non-compliant with GDPR.', 'cookieadmin').'</p>' : '').'
[45] Fix | Delete
[46] Fix | Delete
<div class="cookieadmin-setting setting-reload">
[47] Fix | Delete
<label class="cookieadmin-title" for="cookieadmin_reload_on_consent">'.esc_html__('Reload page on consent', 'cookieadmin').'
[48] Fix | Delete
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Page will be loaded on user consent.', 'cookieadmin').'"></span>
[49] Fix | Delete
</label>
[50] Fix | Delete
<div class="cookieadmin-setting-contents">
[51] Fix | Delete
<label class="cookieadmin_toggle">
[52] Fix | Delete
<input name="cookieadmin_reload_on_consent" type="checkbox" id="cookieadmin_reload_on_consent" '.(!empty($policy[$view]['reload_on_consent']) ? 'checked' : '').'>
[53] Fix | Delete
<span class="cookieadmin_slider"></span>
[54] Fix | Delete
</label>
[55] Fix | Delete
</div>
[56] Fix | Delete
</div>
[57] Fix | Delete
[58] Fix | Delete
<div class="coookieadmin-contents" cookieadmin-pro-only="1">
[59] Fix | Delete
<div class="cookieadmin-setting">
[60] Fix | Delete
<label class="cookieadmin-title" for="cookieadmin_google_consent_mode_v2">'.esc_html__('Google Consent Mode v2', 'cookieadmin').wp_kses_post($cookieadmin_requires_pro).'
[61] Fix | Delete
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Enable Google consent mode v2.', 'cookieadmin').'"></span>
[62] Fix | Delete
</label>
[63] Fix | Delete
<div class="cookieadmin-setting-contents">
[64] Fix | Delete
<label class="cookieadmin_toggle">
[65] Fix | Delete
<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' : '').'>
[66] Fix | Delete
<span class="cookieadmin_slider"></span>
[67] Fix | Delete
</label>
[68] Fix | Delete
</div>
[69] Fix | Delete
</div>
[70] Fix | Delete
[71] Fix | Delete
<div class="cookieadmin-setting">
[72] Fix | Delete
<label class="cookieadmin-title" for="cookieadmin_hide_powered_by">'.esc_html__('Hide Powered by Link', 'cookieadmin').wp_kses_post($cookieadmin_requires_pro).'
[73] Fix | Delete
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Hide powered by CookieAdmin on banner.', 'cookieadmin').'"></span>
[74] Fix | Delete
</label>
[75] Fix | Delete
<div class="cookieadmin-setting-contents">
[76] Fix | Delete
<label class="cookieadmin_toggle">
[77] Fix | Delete
<input name="cookieadmin_hide_powered_by" type="checkbox" id="cookieadmin_hide_powered_by" '.(!empty($cookieadmin_settings['hide_powered_by']) && cookieadmin_is_pro() ? 'checked' : '').'>
[78] Fix | Delete
<span class="cookieadmin_slider"></span>
[79] Fix | Delete
</label>
[80] Fix | Delete
</div>
[81] Fix | Delete
</div>
[82] Fix | Delete
[83] Fix | Delete
<div class="cookieadmin-setting">
[84] Fix | Delete
<label class="cookieadmin-title" for="cookieadmin_hide_reconsent">'.esc_html__('Hide Re-consent Icon', 'cookieadmin').wp_kses_post($cookieadmin_requires_pro).'
[85] Fix | Delete
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Hide reconsent icon after user consent.', 'cookieadmin').'"></span>
[86] Fix | Delete
</label>
[87] Fix | Delete
<div class="cookieadmin-setting-contents">
[88] Fix | Delete
<label class="cookieadmin_toggle">
[89] Fix | Delete
<input name="cookieadmin_hide_reconsent" type="checkbox" id="cookieadmin_hide_reconsent" '.(!empty($cookieadmin_settings['hide_reconsent']) && cookieadmin_is_pro() ? 'checked' : '').'>
[90] Fix | Delete
<span class="cookieadmin_slider"></span>
[91] Fix | Delete
</label>
[92] Fix | Delete
</div>
[93] Fix | Delete
</div>
[94] Fix | Delete
[95] Fix | Delete
<div class="cookieadmin-setting">
[96] Fix | Delete
<label class="cookieadmin-title" for="cookieadmin_auto_scan">'.esc_html__('Auto Cookies Scan', 'cookieadmin').wp_kses_post($cookieadmin_requires_pro).'
[97] Fix | Delete
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Monthly auto scan will detect cookies.', 'cookieadmin').'"></span>
[98] Fix | Delete
</label>
[99] Fix | Delete
<div class="cookieadmin-setting-contents">
[100] Fix | Delete
<label class="cookieadmin_toggle">
[101] Fix | Delete
<input name="cookieadmin_auto_scan" type="checkbox" id="cookieadmin_auto_scan" '.(!empty($cookieadmin_settings['cookieadmin_auto_scan']) && cookieadmin_is_pro() ? 'checked' : '').'>
[102] Fix | Delete
<span class="cookieadmin_slider"></span>
[103] Fix | Delete
</label>
[104] Fix | Delete
</div>
[105] Fix | Delete
</div>
[106] Fix | Delete
[107] Fix | Delete
<div class="cookieadmin-setting">
[108] Fix | Delete
<label class="cookieadmin-title" for="cookieadmin_consent_logs_expiry">'.esc_html__('Consent Log Cleanup', 'cookieadmin').wp_kses_post($cookieadmin_requires_pro).'
[109] Fix | Delete
<span class="dashicons dashicons-info cookieadmin-tooltip-box" data-tip="'.esc_html__('Daily auto delete consent logs older than the set limit.', 'cookieadmin').'"></span>
[110] Fix | Delete
</label>
[111] Fix | Delete
<div class="cookieadmin-setting-contents cookieadmin-setting cookieadmin-setting-logs">
[112] Fix | Delete
<label class="cookieadmin_toggle">
[113] Fix | Delete
<input name="cookieadmin_consent_logs_expiry" type="checkbox" id="cookieadmin_consent_logs_expiry" '.(!empty($cookieadmin_settings['consent_logs_expiry']) && cookieadmin_is_pro() ? 'checked' : '').'>
[114] Fix | Delete
<span class="cookieadmin_slider"></span>
[115] Fix | Delete
</label>
[116] Fix | Delete
<input name="cookieadmin_consent_logs_expiry_days" class="cookieadmin-tooltip-box" id="cookieadmin_consent_logs_expiry_days" 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').'">
[117] Fix | Delete
<input type="button" class="button '.(cookieadmin_is_pro() ? ' cookieadmin-purge-consent-btn cookieadmin-tooltip-box' : '').'" data-tip="'.esc_html__('Delete consent logs older than the set limit (runs once)', 'cookieadmin').'" value="'.esc_html__('Delete Now', 'cookieadmin').'"/>
[118] Fix | Delete
</div>
[119] Fix | Delete
</div>
[120] Fix | Delete
</div>
[121] Fix | Delete
[122] Fix | Delete
<div class="cookieadmin-setting cookieadmin-save-settings">
[123] Fix | Delete
<div class="cookieadmin-setting-contents">
[124] Fix | Delete
<span><input type="submit" name="cookieadmin_save_settings" class="cookieadmin-btn cookieadmin-btn-primary" value="'.esc_html__('Save Settings', 'cookieadmin').'"></span>
[125] Fix | Delete
</div>
[126] Fix | Delete
</div>
[127] Fix | Delete
</div>
[128] Fix | Delete
</div>';
[129] Fix | Delete
[130] Fix | Delete
wp_nonce_field('cookieadmin_admin_nonce', 'cookieadmin_security');
[131] Fix | Delete
echo '
[132] Fix | Delete
<br/>
[133] Fix | Delete
<br/>
[134] Fix | Delete
</div>
[135] Fix | Delete
</form>
[136] Fix | Delete
</div>';
[137] Fix | Delete
[138] Fix | Delete
\CookieAdmin\Admin::footer_theme();
[139] Fix | Delete
}
[140] Fix | Delete
[141] Fix | Delete
static function save_settings(){
[142] Fix | Delete
global $cookieadmin_lang, $cookieadmin_error, $cookieadmin_msg, $cookieadmin_settings, $cookieadmin_policies;
[143] Fix | Delete
[144] Fix | Delete
// debug_print_backtrace();die;
[145] Fix | Delete
[146] Fix | Delete
check_admin_referer('cookieadmin_admin_nonce', 'cookieadmin_security');
[147] Fix | Delete
[148] Fix | Delete
if(!current_user_can('administrator')){
[149] Fix | Delete
wp_send_json_error(array('message' => __('Sorry, but you do not have permissions to perform this action', 'cookieadmin')));
[150] Fix | Delete
}
[151] Fix | Delete
[152] Fix | Delete
$cookieadmin_settings = get_option('cookieadmin_settings', []);
[153] Fix | Delete
[154] Fix | Delete
// Save cookieadmin_settings only on settings page
[155] Fix | Delete
$cookieadmin_settings['google_consent_mode_v2'] = (isset( $_REQUEST['cookieadmin_google_consent_mode_v2'] ) ? 1 : 0);
[156] Fix | Delete
$cookieadmin_settings['hide_powered_by'] = (isset( $_REQUEST['cookieadmin_hide_powered_by'] ) ? 1 : 0);
[157] Fix | Delete
$cookieadmin_settings['hide_reconsent'] = (isset( $_REQUEST['cookieadmin_hide_reconsent'] ) ? 1 : 0);
[158] Fix | Delete
$cookieadmin_settings['cookieadmin_auto_scan'] = (isset( $_REQUEST['cookieadmin_auto_scan'] ) ? 1 : 0);
[159] Fix | Delete
$cookieadmin_settings['consent_logs_expiry'] = (isset( $_REQUEST['cookieadmin_consent_logs_expiry'] ) ? sanitize_text_field(wp_unslash($_REQUEST['cookieadmin_consent_logs_expiry'])) : 0);
[160] Fix | Delete
$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);
[161] Fix | Delete
[162] Fix | Delete
if(empty($cookieadmin_error)){
[163] Fix | Delete
update_option('cookieadmin_settings', $cookieadmin_settings);
[164] Fix | Delete
}
[165] Fix | Delete
[166] Fix | Delete
//Clear schedule if logs deletion is disabled
[167] Fix | Delete
if(empty($cookieadmin_settings['consent_logs_expiry'])){
[168] Fix | Delete
wp_clear_scheduled_hook('cookieadmin_daily_consent_log_pruning');
[169] Fix | Delete
}
[170] Fix | Delete
//Clear schedule if auto scan is disabled
[171] Fix | Delete
if(empty($cookieadmin_settings['cookieadmin_auto_scan'])){
[172] Fix | Delete
wp_clear_scheduled_hook('cookieadmin_run_auto_cookie_scan');
[173] Fix | Delete
}
[174] Fix | Delete
[175] Fix | Delete
// get the consent type from option table, if not saved then return default as 'gdpr'
[176] Fix | Delete
$law = get_option('cookieadmin_law', 'cookieadmin_gdpr');
[177] Fix | Delete
$policy = cookieadmin_load_policy();
[178] Fix | Delete
[179] Fix | Delete
//set preload and consent field for "cookieadmin-settings" page
[180] Fix | Delete
$policy[$law]['preload'] = !empty($_REQUEST['cookieadmin_preload']) ? array_map('sanitize_text_field', wp_unslash($_REQUEST['cookieadmin_preload'])) : [];
[181] Fix | Delete
$policy[$law]['reload_on_consent'] = !empty($_REQUEST['cookieadmin_reload_on_consent']) ? sanitize_text_field(wp_unslash($_REQUEST['cookieadmin_reload_on_consent'])) : '';
[182] Fix | Delete
[183] Fix | Delete
update_option('cookieadmin_consent_settings', $policy);
[184] Fix | Delete
[185] Fix | Delete
if(empty($cookieadmin_error)){
[186] Fix | Delete
$cookieadmin_msg = __('Settings saved successfully', 'cookieadmin');
[187] Fix | Delete
}
[188] Fix | Delete
}
[189] Fix | Delete
}
[190] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function