%PDF- %PDF-
Direktori : /home/tradesc/www/relax/wp-content/plugins/complianz-gdpr/ |
Current File : /home/tradesc/www/relax/wp-content/plugins/complianz-gdpr/functions.php |
<?php defined( 'ABSPATH' ) or die( "you do not have access to this page!" ); require_once plugin_dir_path(__FILE__) . 'functions-legacy.php'; global $cmplz_banner; if ( !function_exists('cmplz_get_cookiebanner')) { function cmplz_get_cookiebanner($ID = false, $set_defaults = true, $load_wysiwyg_options = false){ global $cmplz_banner; //try cached data if defaults are used if ( $ID && $set_defaults && !$load_wysiwyg_options ) { $banner = $cmplz_banner[ $ID ] ?? false; if (!$banner){ $banner = new CMPLZ_COOKIEBANNER($ID, $set_defaults, $load_wysiwyg_options); $cmplz_banner[ $ID ] = $banner; } } else { $banner = new CMPLZ_COOKIEBANNER($ID, $set_defaults, $load_wysiwyg_options); } return $banner; } } if ( ! function_exists( 'cmplz_get_option' ) ) { /** * Get a Really Simple SSL option by name * * @param string $name * @param bool $default * * @return mixed */ function cmplz_get_option( string $id, bool $load_default=true ) { $id = cmplz_sanitize_title_preserve_uppercase($id); //to ensure the fields function only runs once, we store it here, and check if it's filled in the next request. $fields = false; $options = get_option( 'cmplz_options', [] ); $value = $options[ $id ] ?? false; if ( $value===false && $load_default && class_exists('COMPLIANZ') ) { $fields = COMPLIANZ::$config->fields ?? []; $keys = array_keys( array_column( $fields, 'id' ), $id ); $key = reset( $keys ); if (isset($fields[$key]) ) { $default = $fields[ $key ]['default'] ?? false; $value = apply_filters( 'cmplz_default_value', $default, $id, $fields[$key] ); } } /* * Translate output * * */ if ( function_exists('pll__') || function_exists('icl_translate') || defined("WPML_PLUGIN_BASENAME" ) ) { //check if Complianz::$config has property fields if (class_exists('COMPLIANZ')) { $config_fields = COMPLIANZ::$config->fields ?? []; } else { $config_fields = []; } $fields = $fields ?: $config_fields; $keys = array_keys( array_column( $fields, 'id' ), $id ); $key = reset( $keys ); if ( $key !== false ) { $type = $fields[ $key ]['type'] ?? false; $translatable = $fields[ $key ]['translatable'] ?? false; if ( $translatable ) { if ( is_array( $value ) && ( $type === 'thirdparties' || $type === 'processors' ) ) { foreach ( $value as $item_key => $item ) { //contains the values of an item foreach ( $item as $key => $key_value ) { if ( function_exists( 'pll__' ) ) { $value[ $item_key ][ $key ] = pll__( $item_key . '_' . $id . "_" . $key ); } if ( function_exists( 'icl_translate' ) ) { $value[ $item_key ][ $key ] = icl_translate( 'complianz', $item_key . '_' . $id . "_" . $key, $key_value ); } $value[ $item_key ][ $key ] = apply_filters( 'wpml_translate_single_string', $key_value, 'complianz', $item_key . '_' . $id . "_" . $key ); } } } else { if ( function_exists( 'pll__' ) ) { $value = pll__( $value ); } if ( function_exists( 'icl_translate' ) ) { $value = icl_translate( 'complianz', $id, $value ); } $value = apply_filters( 'wpml_translate_single_string', $value, 'complianz', $id ); } } } } return apply_filters("cmplz_option_$id", $value, $id); } } if (!function_exists('cmplz_get_field')) { function cmplz_get_field($id){ $fields = COMPLIANZ::$config->fields; foreach ($fields as $field) { if (isset($field['id']) && $field['id'] === $id) { return $field; } } return false; } } if (!function_exists('cmplz_get_field_index')) { function cmplz_get_field_index($id, $fields){ foreach ($fields as $index => $field) { if (isset($field['id']) && $field['id'] === $id) { return $index; } } return false; } } if ( !function_exists('cmplz_remove_field') ) { /** * @param array $fields * @param $ids * * @return array */ function cmplz_remove_field( array $fields, $ids): array { if (!is_array($ids)) { $ids = array($ids); } $field_ids = array_column($fields, 'id'); foreach ($ids as $id){ $drop_index = array_search( $id, $field_ids, true ); if ($drop_index!==false) { unset($fields[$drop_index]); } } return $fields; } } if ( !function_exists('cmplz_sanitize_title_preserve_uppercase')) { /** * @param string $title * * @return string */ function cmplz_sanitize_title_preserve_uppercase($title) { if (empty($title)) { return ''; } $title = preg_replace( '/&.+?;/', '', $title ); $title = str_replace( '.', '-', $title ); $title = preg_replace( '/[^%a-zA-Z0-9 _-]/', '', $title ); $title = preg_replace( '/\s+/', '-', $title ); $title = preg_replace( '|-+|', '-', $title ); return str_replace(' ', '-', sanitize_text_field(remove_accents($title))); } } if ( ! function_exists( 'cmplz_uses_google_analytics' ) ) { /** * Check if site uses google analytics * @return bool */ function cmplz_uses_google_analytics() { return COMPLIANZ::$banner_loader->uses_google_analytics(); } } if ( ! function_exists( 'cmplz_consent_mode' ) ) { /** * Check if site uses google analytics * @return bool */ function cmplz_consent_mode() { return cmplz_get_option( 'consent-mode' ) === 'yes'; } } if ( ! function_exists('cmplz_upload_dir')) { /** * Get the upload dir * * @param string $path * * @return string */ function cmplz_upload_dir( string $path=''): string { $uploads = wp_upload_dir(); $upload_dir = trailingslashit( apply_filters( 'cmplz_upload_dir', $uploads['basedir'] ) ).'complianz/'.$path; if ( !is_dir( $upload_dir) ) { cmplz_create_missing_directories_recursively($upload_dir); } return trailingslashit( $upload_dir ); } } /** * Create directories recursively * * @param string $path */ if ( !function_exists('cmplz_create_missing_directories_recursively') ) { function cmplz_create_missing_directories_recursively( string $path ) { if ( ! cmplz_user_can_manage() ) { return; } $parts = explode( '/', $path ); $dir = ''; foreach ( $parts as $part ) { $dir .= $part . '/'; if (cmplz_has_open_basedir_restriction($dir)) { continue; } if ( ! is_dir( $dir ) && strlen( $dir ) > 0 && is_writable( dirname( $dir, 1 ) ) ) { if ( ! mkdir( $dir ) && ! is_dir( $dir ) ) { throw new \RuntimeException( sprintf( 'Directory "%s" was not created', $dir ) ); } } } } } if (!function_exists('cmplz_has_open_basedir_restriction')) { function cmplz_has_open_basedir_restriction($path) { // Default error handler is required set_error_handler(null); // Clean last error info. error_clear_last(); // Testing... @file_exists($path); // Restore previous error handler restore_error_handler(); // Return `true` if error has occurred return ($error = error_get_last()) && $error['message'] !== '__clean_error_info'; } } if ( ! function_exists('cmplz_upload_url')) { /** * Get the upload url * * @param string $path * * @return string */ function cmplz_upload_url( string $path=''): string { $uploads = wp_upload_dir(); $upload_url = $uploads['baseurl']; $upload_url = trailingslashit( apply_filters('cmplz_upload_url', $upload_url) ); return trailingslashit($upload_url.'complianz/'.$path); } } if ( ! function_exists( 'cmplz_uses_social_media' ) ) { /** * Check if site uses social media * @return bool */ function cmplz_uses_social_media() { $socialmedia_list = cmplz_get_option( 'socialmedia_on_site' ); return is_array( $socialmedia_list ) && count( array_filter( $socialmedia_list ) ) > 0; } } if ( !function_exists('cmplz_upgraded_to_current_version')){ /** * Check if the user has upgraded to the current version, or if this is a fresh install with this version. */ function cmplz_upgraded_to_current_version() { $first_version = get_option( 'cmplz_first_version' ); //if there's no first version yet, we assume it's not upgraded if ( !$first_version ) { return false; } //if the first version is below current, we just upgraded. if ( version_compare($first_version,cmplz_version ,'<') ){ return true; } return false; } } if ( ! function_exists( 'cmplz_get_template' ) ) { /** * Get a template based on filename, overridable in theme dir * @param string $filename * @param array $args * @param string $path * @return string */ function cmplz_get_template( $filename , $args = array(), $path = false ) { $path = $path ? trailingslashit($path) : trailingslashit( cmplz_path ) . 'templates/'; $file = apply_filters('cmplz_template_file', $path . $filename, $filename); $theme_file = trailingslashit( get_stylesheet_directory() ) . trailingslashit( basename( cmplz_path ) ) . 'templates/' . $filename; if ( !file_exists( $file ) ) { return false; } if ( file_exists( $theme_file ) ) { $file = $theme_file; } if ( strpos( $file, '.php' ) !== false ) { ob_start(); require $file; $contents = ob_get_clean(); } else { $contents = file_get_contents( $file ); } if ( !empty($args) && is_array($args) ) { foreach($args as $fieldname => $value ) { $contents = str_replace( '{'.$fieldname.'}', $value, $contents ); } } return $contents; } } if ( ! function_exists( 'cmplz_uses_google_tagmanager_or_analytics' ) ) { function cmplz_uses_google_tagmanager_or_analytics(){ return COMPLIANZ::$banner_loader->uses_google_analytics() || COMPLIANZ::$banner_loader->uses_google_tagmanager(); } } if ( ! function_exists( 'cmplz_tagmanager_conditional_helptext' ) ) { function cmplz_tagmanager_conditional_helptext() { if ( !COMPLIANZ::$banner_loader->consent_required_for_anonymous_stats() ) { $text = __( "Based on your Analytics configuration you should fire Analytics on event cmplz_functional.", 'complianz-gdpr' ); } else { $text = __( "Based on your Analytics configuration you should fire Analytics on event cmplz_statistics.", 'complianz-gdpr' ); } return $text; } } if ( ! function_exists( 'cmplz_statistics_privacy_friendly' ) ) { /** * Checks if statistics are configured privacy friendly * * @return bool */ function cmplz_statistics_privacy_friendly() { return COMPLIANZ::$banner_loader->statistics_privacy_friendly(); } } if ( ! function_exists( 'cmplz_manual_stats_config_possible' ) ) { /** * Checks if the statistics are configured so no consent is need for statistics * * @return bool */ function cmplz_manual_stats_config_possible() { $stats = cmplz_get_option( 'compile_statistics' ); if ( $stats === 'matomo' && cmplz_no_ip_addresses() ) { return true; } //Google Tag Manager should also be possible to embed yourself if you haven't integrated it anonymously if ( $stats === 'google-tag-manager' ) { return true; } if ( $stats === 'google-analytics' ) { if ( !COMPLIANZ::$banner_loader->consent_required_for_anonymous_stats() ) { return true; } } return false; } } if ( ! function_exists( 'cmplz_get_stats_tool_nice' ) ) { function cmplz_get_stats_tool_nice() { //if the user just changed the setting, we use the posted data. The data is not saved yet, so would yield the previous setting if ( isset($_POST['cmplz_compile_statistics'])) { $stats = sanitize_text_field($_POST['cmplz_compile_statistics']); } else { $stats = cmplz_get_option( 'compile_statistics' ); } switch ( $stats ){ case 'google-analytics': return "Google Analytics"; case 'matomo': return "Matomo"; case 'clicky': return "Clicky"; case 'yandex': return "Yandex"; case 'google-tag-manager': return "Google Tag Manager"; case 'matomo-tag-manager': return "Matomo Tag Manager"; case 'clarity': return "Clarity"; default: return __("Not found","complianz-gdpr"); } } } if ( !function_exists('cmplz_detected_cookie_plugin')) { function cmplz_detected_cookie_plugin( $return_name = false ){ $plugin = false; if (defined('CLI_LATEST_VERSION_NUMBER')){ $plugin = "GDPR Cookie Consent"; } elseif(defined('MOOVE_GDPR_VERSION')) { $plugin = "GDPR Cookie Compliance"; }elseif(defined('CTCC_PLUGIN_URL')) { $plugin = "GDPR Cookie Consent Banner"; }elseif(defined('RCB_FILE')) { $plugin = "Real Cookie Banner"; }elseif(class_exists('Cookiebot_WP')) { $plugin = "Cookiebot"; }elseif(function_exists('bst_plugin_install')) { $plugin = "BST DSGVO Cookie"; }elseif(function_exists('jlplg_lovecoding_set_cookie')) { $plugin = "Simple Cookie Notice"; }elseif(class_exists('SCCBPP_WpCookie_Save')) { $plugin = "Seers Cookie Consent Banner Privacy Policy"; }elseif(function_exists('daextlwcnf_customize_action_links')) { $plugin = "Lightweight Cookie Notice Free"; }elseif(defined('GDPRCN_VERSION')) { $plugin = "GDPR Cookie Notice"; }elseif(function_exists('wp_gdpr_cookie_notice_check_requirements')) { $plugin = "WP GDPR Cookie Notice"; }elseif(defined('SURBMA_GPGA_PLUGIN_VERSION_NUMBER')) { $plugin = "Surbma | GDPR Proof Cookie Consent & Notice Bar"; }elseif(class_exists('dsdvo_wp_backend')) { $plugin = "DSGVO All in one for WP"; }elseif(class_exists('Cookie_Notice')) { $plugin = "Cookie Notice & Compliance"; }elseif(defined('CNCB_VERSION')) { $plugin = "Cookie Notice and Consent Banner"; }elseif(function_exists('add_cookie_notice')) { $plugin = "Cookie Notice Lite"; }elseif(function_exists('fhw_dsgvo_cookie_insert')) { $plugin = "GDPR tools: cookie notice + privacy"; }elseif(defined('GDPR_COOKIE_CONSENT_PLUGIN_URL')) { $plugin = "GDPR Cookie Consent"; }elseif(defined('WP_GDPR_C_SLUG')) { $plugin = "WP GDPR Compliance"; }elseif(defined('TERMLY_VERSION')) { $plugin = "Termly | GDPR/CCPA Cookie Consent Banner"; } if ( $plugin !== false && !$return_name ) { return true; } else { return $plugin; } } } if ( ! function_exists( 'cmplz_revoke_link' ) ) { /** * Output a revoke button * @param bool $text * * @return string */ function cmplz_revoke_link( $text = false ) { $text = sanitize_text_field($text) ? : __( 'Revoke', 'complianz-gdpr' ); $text = apply_filters( 'cmplz_revoke_button_text', $text ); $css = "<style>.cmplz-status-accepted,.cmplz-status-denied {display: none;}</style> <script> document.addEventListener('cmplz_before_cookiebanner', function(){ if (cmplz_has_consent('marketing')) { document.querySelector('.cmplz-status-accepted').style.display = 'block'; document.querySelector('.cmplz-status-denied').style.display = 'none'; } else { document.querySelector('.cmplz-status-accepted').style.display = 'none'; document.querySelector('.cmplz-status-denied').style.display = 'block'; document.querySelector('.cmplz-revoke-custom').setAttribute('disabled', true); } document.addEventListener('click', e => { if ( e.target.closest('.cmplz-revoke-custom') ) { document.querySelector('.cmplz-revoke-custom').setAttribute('disabled', true); cmplz_set_banner_status('dismissed'); } }); document.addEventListener('click', e => { if ( e.target.closest('.cmplz-accept') ) { document.querySelector('.cmplz-status-accepted').style.display = 'block'; document.querySelector('.cmplz-status-denied').style.display = 'none'; document.querySelector('.cmplz-revoke-custom').removeAttribute('disabled'); } }); }); </script>"; $html = $css . '<button class="cmplz-deny cmplz-revoke-custom">' . esc_html($text) . '</button> <span class="cmplz-status-accepted">' . cmplz_sprintf( __( 'Current status: %s', 'complianz-gdpr' ), __( "Accepted", 'complianz-gdpr' ) ) . '</span><span class="cmplz-status-denied">' . cmplz_sprintf( __( 'Current status: %s', 'complianz-gdpr' ), __( "Denied", 'complianz-gdpr' ) ) . '</span>'; return apply_filters( 'cmplz_revoke_link', $html ); } } if ( ! function_exists( 'cmplz_sells_personal_data' ) ) { function cmplz_sells_personal_data() { $purposes = cmplz_get_option( 'purpose_personaldata'); if ( isset( $purposes['selling-data-thirdparty'] ) && $purposes['selling-data-thirdparty'] ) { return true; } return false; } } if ( ! function_exists( 'cmplz_sold_data_12months' ) ) { function cmplz_sold_data_12months() { return COMPLIANZ::$company->sold_data_12months(); } } if ( ! function_exists( 'cmplz_disclosed_data_12months' ) ) { function cmplz_disclosed_data_12months() { return COMPLIANZ::$company->disclosed_data_12months(); } } if ( ! function_exists( 'cmplz_site_needs_cookie_warning' ) ) { /** * Check if site needs a cookie warning * * @return bool */ function cmplz_site_needs_cookie_warning() { return COMPLIANZ::$banner_loader->site_needs_cookie_warning(); } } if ( ! function_exists( 'cmplz_eu_site_needs_cookie_warning' ) ) { /** * Check if EU targeted site needs a cookie warning * * @return bool */ function cmplz_eu_site_needs_cookie_warning() { return COMPLIANZ::$banner_loader->site_needs_cookie_warning( 'eu' ); } } if ( ! function_exists( 'cmplz_za_site_needs_cookie_warning' ) ) { /** * Check if ZA targeted site needs a cookie warning * * @return bool */ function cmplz_za_site_needs_cookie_warning() { return COMPLIANZ::$banner_loader->site_needs_cookie_warning( 'za' ); } } if ( ! function_exists( 'cmplz_uk_site_needs_cookie_warning' ) ) { /** * Check if EU targeted site needs a cookie warning * * @return bool */ function cmplz_uk_site_needs_cookie_warning() { return COMPLIANZ::$banner_loader->site_needs_cookie_warning( 'uk' ); } } if ( ! function_exists( 'cmplz_site_uses_cookie_warning_cats' ) ) { /** * Check if optin site needs cookie warning with categories * @return bool */ function cmplz_site_uses_cookie_warning_cats() { $cookiebanner = cmplz_get_cookiebanner( apply_filters( 'cmplz_user_banner_id', cmplz_get_default_banner_id() ) ); if ( $cookiebanner->use_categories !== 'no' ) { return true; } return false; } } if ( ! function_exists( 'cmplz_company_located_in_region' ) ) { /** * Check if this company is located in a certain region * * @param $region * * @return bool */ function cmplz_company_located_in_region( $region ) { $country_code = cmplz_get_option( 'country_company' ); return ( cmplz_get_region_for_country( $country_code ) === $region ); } } if ( ! function_exists( 'cmplz_has_region' ) ) { /** * Check if this website targets a specific region. * * @param string $code * * @return bool */ function cmplz_has_region( $code ) { $regions = cmplz_get_regions(true); if ( in_array( $code, $regions ) ) { return true; } return false; } } if ( ! function_exists( 'cmplz_has_state' ) ) { /** * Check if this website targest a specific state * * @param string $code * * @return bool */ function cmplz_has_state( $code ) { $regions = cmplz_get_regions(true); if ( !isset( $regions[ 'us' ] ) ) { return false; } $states = cmplz_get_option('us_states'); if ( isset( $states[ $code ] ) ) { return true; } return false; } } if ( ! function_exists( 'cmplz_get_region_from_legacy_type' ) ) { function cmplz_get_region_from_legacy_type( $type ) { $region = false; if ( strpos( $type, 'disclaimer' ) !== false || strpos( $type, 'all' ) !== false ) { $region = 'all'; } //get last three chars of string. if not contains -, it's eu or disclaimer. if ( substr( $type, - 3, 1 ) === '-' ) { $region = substr( $type, - 2 ); } if ( ! $region ) { $region = 'eu'; } return $region; } } if (!function_exists('cmplz_format_as_javascript_array')) { function cmplz_format_as_javascript_array($array) { $out = []; foreach ($array as $key => $label){ $out[] = [ 'id' => $key, 'label' => $label, ]; } return $out; } } if ( ! function_exists( 'cmplz_get_regions' ) ) { function cmplz_get_regions( $ad_all_category = false, $label_type = false ) { $regions = cmplz_get_option( 'regions' ); if ( ! is_array( $regions ) ) { $regions = !empty( $regions ) ? array( $regions ) : []; } if ( $label_type && ! empty( $regions ) ) { $output = array(); foreach ( $regions as $region ) { if ($label_type==='full') { $label = isset( COMPLIANZ::$config->regions[ $region ] ) ? COMPLIANZ::$config->regions[ $region ]['label_full'] : ''; } else { $label = isset( COMPLIANZ::$config->regions[ $region ] ) ? COMPLIANZ::$config->regions[ $region ]['label'] : ''; } $output[ $region ] = $label; } } else { $output = $regions; } if ( $ad_all_category ) { if ($label_type) { $output['all'] = __( 'General', 'complianz-gdpr' ); } else { $output[] = 'all'; } } return array_filter($output); } } if ( ! function_exists( 'cmplz_multiple_regions' ) ) { function cmplz_multiple_regions() { //if geo ip is not enabled, return false anyway if ( ! cmplz_geoip_enabled() ) { return false; } $regions = cmplz_get_regions(); return count( $regions ) > 1; } } if ( ! function_exists( 'cmplz_get_region_for_country' ) ) { function cmplz_get_region_for_country( $country_code ) { $region = false; $regions = COMPLIANZ::$config->regions; foreach ( $regions as $region_code => $region_data ) { if ( in_array( $country_code, $region_data['countries'] ) ) { $region = $region_code; break; } } return apply_filters( "cmplz_region_for_country", $region, $country_code ); } } if ( ! function_exists( 'cmplz_get_consenttype_for_country' ) ) { function cmplz_get_consenttype_for_country( $country_code ) { $regions = COMPLIANZ::$config->regions; $used_regions = cmplz_get_regions(); //do not unset a not used region if it's a manual override. if ( !isset($_GET['cmplz_user_region']) ) { foreach ( $regions as $region => $region_data ) { if ( empty($used_regions) || !in_array( $region, $used_regions )) { unset($regions[$region]); } } } $actual_region = apply_filters('cmplz_user_region', cmplz_get_region_for_country( $country_code )); if ( isset( $regions[ $actual_region ]) && isset( $regions[ $actual_region ]['type'] ) ) { $consenttype = apply_filters( 'cmplz_consenttype', $regions[ $actual_region ]['type'], $actual_region ); return $consenttype; } return false; } } if ( ! function_exists( 'cmplz_targeting_multiple_regions' ) ) { function cmplz_targeting_multiple_regions(){ if ( defined("POLYLANG_VERSION" ) ) return true; if ( defined("WPML_PLUGIN_BASENAME" ) ) return true; return false; } } /** * Check if the scan detected social media on the site. * * * */ if ( ! function_exists( 'cmplz_scan_detected_social_media' ) ) { function cmplz_scan_detected_social_media() { $social_media = get_option( 'cmplz_detected_social_media', array() ); if ( ! is_array( $social_media ) ) { $social_media = array( $social_media ); } $social_media = array_filter( $social_media ); $social_media = apply_filters( 'cmplz_detected_social_media', $social_media ); //nothing scanned yet, or nothing found if ( ! $social_media || ( count( $social_media ) == 0 ) ) { $social_media = false; } return $social_media; } } if ( ! function_exists( 'cmplz_scan_detected_thirdparty_services' ) ) { function cmplz_scan_detected_thirdparty_services() { $thirdparty = get_option( 'cmplz_detected_thirdparty_services', array() ); if ( ! is_array( $thirdparty ) ) { $thirdparty = array( $thirdparty ); } $thirdparty = array_filter( $thirdparty ); $thirdparty = apply_filters( 'cmplz_detected_services', $thirdparty ); //nothing scanned yet, or nothing found if ( ! $thirdparty || ( count( $thirdparty ) == 0 ) ) { $thirdparty = false; } return $thirdparty; } } if ( ! function_exists( 'cmplz_scan_detected_stats' ) ) { function cmplz_scan_detected_stats() { $stats = get_option( 'cmplz_detected_stats', array() ); if ( ! is_array( $stats ) ) { $stats = array( $stats ); } $stats = array_filter( $stats ); //nothing scanned yet, or nothing found if ( ! $stats || ( count( $stats ) == 0 ) ) { $stats = false; } $stats = apply_filters( 'cmplz_detected_stats', $stats ); return $stats; } } if ( ! function_exists( 'cmplz_page_is_of_type' ) ) { /** * Save a complianz option * @param string $type * @return bool */ function cmplz_page_is_of_type( $type ) { $regions = cmplz_get_regions(); global $post; if ( !$post ) return false; $post_id = $post->ID; foreach ( $regions as $region ) { $policy_id = COMPLIANZ::$document->get_shortcode_page_id( $type, $region ); if ( $policy_id === $post_id ) { return true; } } return false; } } if ( ! function_exists( 'cmplz_uses_statistics' ) ) { function cmplz_uses_statistics() { $stats = cmplz_get_option( 'compile_statistics' ); if ( $stats !== 'no' ) { return true; } return false; } } if ( ! function_exists( 'cmplz_show_install_burst_warning' ) ) { function cmplz_show_install_burst_warning() { if ( cmplz_get_option('consent_for_anonymous_stats') === 'yes' && !defined( 'burst_version' ) ) { return true; } return false; } } if ( ! function_exists( 'cmplz_uses_only_functional_cookies' ) ) { function cmplz_uses_only_functional_cookies() { return COMPLIANZ::$banner_loader->uses_only_functional_cookies(); } } if ( !function_exists('cmplz_scan_in_progress')) { function cmplz_scan_in_progress(){ return isset( $_GET['complianz_scan_token'] ) && wp_verify_nonce( $_GET['complianz_scan_token'], 'complianz_scan_token'); } } if ( ! function_exists( 'cmplz_ecommerce_legal' ) ) { function cmplz_ecommerce_legal() { //check Woo and EDD constants $ecommerce_enabled = defined('WC_PLUGIN_FILE') || defined('EDD_VERSION'); return $ecommerce_enabled; } } if ( ! function_exists( 'cmplz_site_shares_data' ) ) { /** * Function to check if site shares data. Used in canada cookie policy * @return bool */ function cmplz_site_shares_data() { return COMPLIANZ::$banner_loader->site_shares_data(); } } if ( ! function_exists( 'cmplz_strip_spaces' ) ) { function cmplz_strip_spaces( $string ) { return preg_replace( '/\s*/m', '', $string ); } } if ( ! function_exists( 'cmplz_localize_date' ) ) { function cmplz_localize_date( $unix_time ) { $formatted_date = date( get_option( 'date_format' ), $unix_time ); $month = date( 'F', $unix_time ); //june $month_localized = __( $month ); //juni $date = str_replace( $month, $month_localized, $formatted_date ); $weekday = date( 'l', $unix_time ); //wednesday $weekday_localized = __( $weekday ); //woensdag $date = str_replace( $weekday, $weekday_localized, $date ); return $date; } } if (!function_exists('cmplz_strpos_arr')) { /** * check if there is a partial match between a key of the array and the haystack * We cannot use array_search, as this would not allow partial matches. * * @param string $haystack * @param array $needle * * @return bool|string */ function cmplz_strpos_arr( $haystack, $needle ) { if ( empty( $haystack ) ) { return false; } if ( ! is_array( $needle ) ) { $needle = array( $needle ); } foreach ( $needle as $key => $value ) { if ( strlen($value) === 0 ) continue; if ( ( strpos( $haystack, $value ) ) !== false ) { return ( is_numeric( $key ) ) ? $value : $key; } } return false; } } /** * callback for privacy document Check if there is a text entered in the custom privacy statement text * * */ if ( ! function_exists( 'cmplz_has_custom_privacy_policy' ) ) { function cmplz_has_custom_privacy_policy() { $policy = cmplz_get_option( 'custom_privacy_policy_text' ); if ( empty( $policy ) ) { return false; } return true; } } /** * callback for privacy statement document, check if google is allowed to share data with other services * * */ if ( ! function_exists( 'cmplz_statistics_no_sharing_allowed' ) ) { function cmplz_statistics_no_sharing_allowed() { $statistics = cmplz_get_option( 'compile_statistics', false, 'wizard' ); $tagmanager = ( $statistics === 'google-tag-manager' ) ? true : false; $google_analytics = ( $statistics === 'google-analytics' ) ? true : false; if ( $google_analytics || $tagmanager ) { $thirdparty = $google_analytics ? cmplz_get_option( 'compile_statistics_more_info' ) : cmplz_get_option( 'compile_statistics_more_info_tag_manager'); if ( !is_array($thirdparty) ) { $thirdparty = array(); } return in_array( 'no-sharing', $thirdparty, true ); } //only applies to google return false; } } /** * callback for privacy statement document. Check if ip addresses are stored. * * */ if ( ! function_exists( 'cmplz_no_ip_addresses' ) ) { function cmplz_no_ip_addresses() { $statistics = cmplz_get_option( 'compile_statistics'); //not anonymous stats. if ( $statistics === 'yes' ) { return false; } $tagmanager = ( $statistics === 'google-tag-manager' ) ? true : false; $matomo = ( $statistics === 'matomo' ) ? true : false; $google_analytics = ( $statistics === 'google-analytics' ) ? true : false; if ( $google_analytics || $tagmanager ) { $thirdparty = $google_analytics ? cmplz_get_option( 'compile_statistics_more_info') : cmplz_get_option( 'compile_statistics_more_info_tag_manager'); if ( !is_array($thirdparty) ) { $thirdparty = array(); } return in_array( 'ip-addresses-blocked', $thirdparty, true ); } if ( $matomo ) { return false; } return false; } } if (!function_exists('cmplz_get_console_errors')){ /** * Get console errors as detected by complianz * @return string */ function cmplz_get_console_errors(){ $errors = get_option('cmplz_detected_console_errors'); $location = isset($errors[2]) && strlen($errors[2])>0 ? $errors[2] : __('the page source', 'complianz-gdpr'); $line_no = isset($errors[1]) ? $errors[1] : 0; if ( $errors && isset($errors[0]) && $line_no>1 ) { return cmplz_sprintf(__('%s on line %s of %s', 'complianz-gdpr'), $errors[0], $errors[1], $location); } return false; } } if ( ! function_exists( 'cmplz_cookie_warning_required_stats_eu' ) ) { function cmplz_cookie_warning_required_stats_eu() { return COMPLIANZ::$banner_loader->cookie_warning_required_stats('eu'); } } if ( ! function_exists( 'cmplz_cookie_warning_required_stats_uk' ) ) { function cmplz_cookie_warning_required_stats_uk() { return COMPLIANZ::$banner_loader->cookie_warning_required_stats('uk'); } } if ( ! function_exists( 'cmplz_cookie_warning_required_stats_za' ) ) { function cmplz_cookie_warning_required_stats_za() { return COMPLIANZ::$banner_loader->cookie_warning_required_stats('za'); } } if ( ! function_exists( 'cmplz_accepted_processing_agreement' ) ) { function cmplz_accepted_processing_agreement() { $statistics = cmplz_get_option( 'compile_statistics' ); $tagmanager = $statistics === 'google-tag-manager'; $google_analytics = $statistics === 'google-analytics'; if ( $google_analytics || $tagmanager ) { $thirdparty = $google_analytics ? cmplz_get_option( 'compile_statistics_more_info' ) : cmplz_get_option( 'compile_statistics_more_info_tag_manager' ); if ( !is_array($thirdparty) ) { $thirdparty = array(); } return in_array( 'accepted', $thirdparty, true ); } //only applies to google return false; } } if ( ! function_exists( 'cmplz_init_cookie_blocker' ) ) { /** * Check if the Cookie Blocker should run * @param bool $admin_test * @return bool */ function cmplz_can_run_cookie_blocker( $admin_test = false ){ if ( ! COMPLIANZ::$banner_loader->site_needs_cookie_warning() ) { return false; } if ( cmplz_get_option('enable_cookie_blocker') !== 'yes' ) { return false; } //we can pass a variable $admin_test=true if we want to test cookieblocker availability from admin if ( !$admin_test ) { //only allow cookieblocker on admin when it's an ajax request if ( ! wp_doing_ajax() && is_admin() ) { return false; } } if ( is_feed() ) { return false; } //don't fire on the back-end if ( is_preview() || cmplz_is_pagebuilder_preview() || isset($_GET["cmplz_safe_mode"]) ) { return false; } if ( defined( 'CMPLZ_DO_NOT_BLOCK' ) && CMPLZ_DO_NOT_BLOCK ) { return false; } if ( cmplz_get_option( 'safe_mode' ) ) { return false; } /* Do not block when visitors are from outside EU or US, if geoip is enabled */ //check cache, as otherwise all users would get the same output, while this is user specific //@todo better check for any caching plugin, as this check does not work with wp rocket for example. //if (!defined('wp_cache') && class_exists('cmplz_geoip') && COMPLIANZ::$geoip->geoip_enabled() && (COMPLIANZ::$geoip->region() !== 'eu') && (COMPLIANZ::$geoip->region() !== 'us')) return; //do not block cookies during the scan if ( cmplz_scan_in_progress() ) { return false; } /* Do not fix block when call is coming from wp_api or from xmlrpc or feed */ if ( defined( 'JSON_REQUEST' ) && JSON_REQUEST ) { return false; } if ( defined( 'XMLRPC_REQUEST' ) && XMLRPC_REQUEST ) { return false; } return true; } } if ( ! function_exists( 'cmplz_init_cookie_blocker' ) ) { function cmplz_init_cookie_blocker() { if ( !cmplz_can_run_cookie_blocker() ) { return; } if ( wp_doing_ajax() ) { add_action( "admin_init", array( COMPLIANZ::$cookie_blocker, "start_buffer" ) ); } else { if (cmplz_is_amp()) { add_action( "wp", array( COMPLIANZ::$cookie_blocker, "start_buffer" ) , 20); } else { add_action( "template_redirect", array( COMPLIANZ::$cookie_blocker, "start_buffer" ) ); } } add_action( "shutdown", array( COMPLIANZ::$cookie_blocker, "end_buffer" ), 999 ); } } /** * check if a pdf document is being generated * * @return bool */ if ( !function_exists('cmplz_is_loading_pdf')) { function cmplz_is_loading_pdf() { return cmplz_user_can_manage() && isset( $_GET['nonce'] ) && wp_verify_nonce( $_GET['nonce'], 'cmplz_pdf_nonce' ); } } /** * * Check if we are currently in preview mode from one of the known page builders * * @return bool * @since 2.0.7 * */ if ( ! function_exists( 'cmplz_is_pagebuilder_preview' ) ) { function cmplz_is_pagebuilder_preview() { $preview = false; global $wp_customize; if ( isset( $wp_customize ) || isset( $_GET['fb-edit'] ) //avada || isset( $_GET['builder_id'] ) //avada || isset( $_GET['et_pb_preview'] ) //divi || isset( $_GET['et_fb'] ) //divi || isset( $_GET['elementor-preview'] ) || isset( $_GET['elementor_library'] ) || isset( $_GET['elementor-app'] ) || isset( $_GET['vc_action'] ) || isset( $_GET['vc_editable'] ) || isset( $_GET['vcv-action'] ) || isset( $_GET['zion_builder_active']) || isset( $_GET['zionbuilder-preview']) || isset( $_GET['tb-preview']) //themify || isset( $_GET['tb-id']) //themify || isset( $_GET['fl_builder'] ) || isset( $_GET['tve'] ) || isset( $_GET['bricks'] ) //bricks builder || isset( $_GET['ct_builder'] ) //oxygen || isset( $_GET['tatsu'] ) //tatsu || isset( $_GET['tatsu-header'] ) //tatsu || isset( $_GET['tatsu-footer'] ) //tatsu || ( isset( $_GET['action'] ) && $_GET['action'] === 'ms_get_preview' ) //meta slider || strpos( $_SERVER['REQUEST_URI'], 'cornerstone/edit') !== false ) { $preview = true; } //exclude widgets, and don't exclude banner api $request_url = isset($_SERVER['REQUEST_URI']) ? esc_url_raw($_SERVER['REQUEST_URI']) : ''; if ( strpos($request_url, 'wp-json/complianz/')===false && defined( 'REST_REQUEST' ) && REST_REQUEST ) { return true; } if (isset($_GET['context']) && $_GET['context']==='edit') { return true; } return apply_filters( 'cmplz_is_preview', $preview ); } } if (!function_exists('cmplz_datarequests_active')) { /** * Check if the site requires DNSMPI logic * * @return bool */ function cmplz_datarequests_active() { return cmplz_get_option( 'datarequest' ) === 'yes'; } } if (!function_exists('cmplz_datarequests_or_dnsmpi_active')) { /** * Check if the site requires data requests OR dnsmpi logic * * @return bool */ function cmplz_datarequests_or_dnsmpi_active() { return cmplz_datarequests_active() || cmplz_has_region('us'); } } if (!function_exists('cmplz_file_exists_on_url')) { function cmplz_file_exists_on_url($url){ $upload_dir = cmplz_upload_dir(); $upload_url = cmplz_upload_url(); $path = str_replace( $upload_url, $upload_dir, $url ); return file_exists($path); } } if ( ! function_exists( 'cmplz_geoip_enabled' ) ) { function cmplz_geoip_enabled() { return apply_filters( 'cmplz_geoip_enabled', false ); } } if ( ! function_exists( 'cmplz_tcf_active' ) ) { function cmplz_tcf_active() { if ( !defined('cmplz_premium') ) { return false; } if ( cmplz_get_option('uses_ad_cookies') !=='yes' ) { return false; } return cmplz_get_option('uses_ad_cookies_personalized') === 'tcf' || cmplz_get_option('uses_ad_cookies_personalized') === 'yes'; } } if ( !function_exists('cmplz_get_transient') ) { /** * We user our own transient, as the wp transient is not always persistent * * @param string $name * * @return mixed */ function cmplz_get_transient( string $name ){ if ( isset($_GET['cmplz_nocache']) ) { return false; } $value = false; $now = time(); $transients = get_option('cmplz_transients', array()); if ( isset($transients[$name]) ) { $data = $transients[$name]; $expires = isset($data['expires']) ? $data['expires'] : 0; $value = isset($data['value']) ? $data['value'] : false; if ( $expires < $now ) { unset($transients[$name]); update_option('cmplz_transients', $transients); $value = false; } } return $value; } } if (!function_exists('cmplz_delete_transient')) { /** * We user our own transient, as the wp transient is not always persistent * * @param string $name * * @return void */ function cmplz_delete_transient( string $name ): void { $transients = get_option( 'cmplz_transients', array() ); if ( !is_array( $transients ) ) { $transients = array(); } if (isset($transients[$name])) { unset($transients[$name]); } update_option( 'cmplz_transients', $transients ); } } if (!function_exists('cmplz_set_transient')) { /** * We user our own transient, as the wp transient is not always persistent * Specifically made for license transients, as it stores on network level if multisite. * * @param string $name * @param mixed $value * @param int $expiration * * @return void */ function cmplz_set_transient( string $name, $value, $expiration ): void { $transients = get_option( 'cmplz_transients', array() ); if ( ! is_array( $transients ) ) { $transients = array(); } $transients[ $name ] = array( 'value' => $value, 'expires' => time() + (int) $expiration, ); update_option( 'cmplz_transients', $transients ); } } if (!function_exists('cmplz_upgrade_to_premium')) { /** * Standardization upgrade process * * @param string $url * @param bool $add_space * * @return string */ function cmplz_upgrade_to_premium( $url, $add_space = true ) { $html = '<a class="cmplz-upgrade-to-premium" target="_blank" href="' . $url . '">'.__( "Upgrade", 'complianz-gdpr' ). '</a>'; if ( $add_space ) { $html = ' ' . $html; } return $html; } } /** * For all legal documents for the US, privacy statement, dataleaks or processing agreements, the language should always be en_US * * */ add_filter( 'locale', 'cmplz_set_plugin_language', 19, 1 ); if ( ! function_exists( 'cmplz_set_plugin_language' ) ) { function cmplz_set_plugin_language( $locale ) { //@todo the region can't be detected here, because the term is not defined yet. if ( isset( $_GET['clang'] ) && $_GET['clang'] === 'en' ) { $locale = 'en_US'; } return $locale; } } /** * To make sure the US documents are loaded entirely in English on the front-end, * We check if the locale is a not en- locale, and if so, redirect with a query arg. * This allows us to recognize the page on the next page load is needing a force US language. * */ add_action( 'wp', 'cmplz_add_query_arg' ); if ( ! function_exists( 'cmplz_add_query_arg' ) ) { function cmplz_add_query_arg() { $cmplz_lang = isset( $_GET['clang'] ) ? $_GET['clang'] : false; if ( ! $cmplz_lang && ! cmplz_is_pagebuilder_preview() ) { global $wp; $type = false; $post = get_queried_object(); $locale = get_locale(); //if the locale is english, don't add any query args. if ( strpos( $locale, 'en' ) !== false ) { return; } if ( $post && property_exists( $post, 'post_content' ) ) { $pattern = '/cmplz-document.*type=".*?".*region="(.*?)"/i'; $pattern_gutenberg = '/<!-- wp:complianz\/document {.*?"selectedDocument":"[^\"](.*?)\".*?} \/-->/i'; if ( preg_match_all( $pattern, $post->post_content, $matches, PREG_PATTERN_ORDER ) ) { if ( isset( $matches[1][0] ) ) { $type = $matches[1][0]; } } elseif ( preg_match_all( $pattern_gutenberg, $post->post_content, $matches, PREG_PATTERN_ORDER ) ) { if ( isset( $matches[1][0] ) ) { $type = $matches[1][0]; } } if ( strpos( $type, 'us' ) !== false || strpos( $type, 'uk' ) !== false || strpos( $type, 'au' ) !== false ) { //remove lang property, add our own. wp_redirect( home_url( add_query_arg( 'clang', 'en', remove_query_arg( 'lang', $wp->request ) ) ) ); exit; } } } } } if ( !function_exists('cmplz_has_recommended_phpversion')) { function cmplz_has_recommended_phpversion(){ if (version_compare(PHP_VERSION, '7.2','>=')) { return true; } else { return false; } } } if ( ! function_exists( 'cmplz_array_filter_multidimensional' ) ) { function cmplz_array_filter_multidimensional( $array, $filter_key, $filter_value ): array { return array_filter( $array, static function ( $var ) use ( $filter_value, $filter_key ) { return isset( $var[ $filter_key ] ) && $var[ $filter_key ] === $filter_value; } ); } } if ( ! function_exists( 'cmplz_is_amp' ) ) { /** * Check if we're on AMP, and AMP integration is active * Function should be run not before the 'wp' hook! * * @return bool */ function cmplz_is_amp() { $amp_on = false; if ( !$amp_on && function_exists( 'ampforwp_is_amp_endpoint' ) ) { $amp_on = ampforwp_is_amp_endpoint(); } if ( !$amp_on && function_exists( 'is_amp_endpoint' ) ) { $amp_on = is_amp_endpoint(); } if ( $amp_on ) { $amp_on = cmplz_amp_integration_active(); } return $amp_on; } } if ( ! function_exists( 'cmplz_is_amp_endpoint' ) ) { /** * Check if the site is loading as AMP * Function should be run not before the 'wp' hook! * * @return bool */ function cmplz_is_amp_endpoint() { $amp_on = false; if ( !$amp_on && function_exists( 'ampforwp_is_amp_endpoint' ) ) { $amp_on = ampforwp_is_amp_endpoint(); } if ( !$amp_on && function_exists( 'is_amp_endpoint' ) ) { $amp_on = is_amp_endpoint(); } return $amp_on; } } if ( ! function_exists( 'cmplz_amp_integration_active' ) ) { /** * Check if AMP integration is active * * @return bool */ function cmplz_amp_integration_active() { return cmplz_is_integration_enabled( 'amp' ); } } if ( ! function_exists( 'cmplz_allowed_html' ) ) { function cmplz_allowed_html() { $allowed_tags = array( 'a' => array( 'class' => [], 'href' => [], 'rel' => [], 'title' => [], 'target' => [], 'id' => [], ), 'button' => array( 'id' => [], 'class' => [], 'href' => [], 'rel' => [], 'title' => [], 'target' => [], 'aria-expanded' => [], 'aria-controls' => [], ), 'b' => [], 'br' => [], 'blockquote' => array( 'cite' => [], ), 'div' => array( 'class' => [], 'id' => [], ), 'h1' => [], 'h2' => array(), 'h3' => [], 'h4' => [], 'h5' => [], 'h6' => [], 'i' => [], 'input' => array( 'type' => [], 'class' => [], 'name' => [], 'id' => [], 'required' => [], 'value' => [], 'placeholder' => [], 'data-category' => [], 'data-service' => [], 'style' => array( 'color' => [], ), ), 'img' => array( 'alt' => [], 'class' => [], 'height' => [], 'src' => [], 'width' => [], ), 'label' => array( 'for' => [], 'class' => [], 'style' => array( 'visibility' => [], ), ), 'li' => array( 'class' => [], 'id' => [], ), 'ol' => array( 'class' => [], 'id' => [], ), 'p' => array( 'class' => [], 'id' => [], ), 'span' => array( 'class' => [], 'title' => [], 'style' => array( 'color' => [], 'display' => [], ), 'id' => [], ), 'strong' => [], 'table' => array( 'class' => [], 'id' => [], ), 'tr' => [], 'details' => array( 'class' => [], 'id' => [], ), 'summary' => array( 'class' => [], 'id' => [], ), 'svg' => array( 'width' => [], 'height' => [], 'viewBox' => [], ), 'polyline' => array( 'points' => [], ), 'path' => array( 'd' => [], ), 'style' => [], 'ul' => array( 'class' => [], 'id' => [], ), 'form' => array( 'id' => [], ), ); return apply_filters( "cmplz_allowed_html", $allowed_tags ); } } if ( ! function_exists( 'cmplz_placeholder' ) ) { /** * Get placeholder for any type of blocked content * * @param bool|string $type * @param string $src * * @return string url * * @since 2.1.0 */ function cmplz_placeholder( $type = false, $src = '' ) { if ( ! $type ) { $type = cmplz_get_service_by_src( $src ); } $new_src = cmplz_default_placeholder( $type ); $new_src = apply_filters( "cmplz_placeholder_$type", $new_src, $src ); $new_src = apply_filters( 'cmplz_placeholder', $new_src, $type, $src ); return $new_src; } } if ( ! function_exists( 'cmplz_count_socialmedia' ) ) { /** * count the number of social media used on the site * * @return int */ function cmplz_count_socialmedia() { $sm = cmplz_get_option( 'socialmedia_on_site' ); if ( ! $sm ) { return 0; } if ( ! is_array( $sm ) ) { return 1; } return count( array_filter( $sm ) ); } } if ( ! function_exists( 'cmplz_download_to_site' ) ) { /** * Download a placeholder from youtube or video to this website * * @param string $src * @param bool|string $id * @param bool $use_filename //some filenames are too long to use. * * @return string url * * * @since 2.1.5 */ function cmplz_download_to_site( $src, $id = false, $use_filename = true ) { if ( strpos( $src, "https://" ) === false && strpos( $src, "http://" ) === false ) { $src = str_replace( '//', 'https://', $src ); } if ( ! $id ) { $id = time(); } require_once( ABSPATH . 'wp-admin/includes/file.php' ); $upload_dir = cmplz_upload_dir('placeholders'); //set the path $filename = $use_filename ? "-" . basename( $src ) : '.jpg'; $file = $upload_dir . $id . $filename; //set the url $new_src = cmplz_upload_url( "placeholders") . $id.$filename; //download file $tmpfile = download_url( $src, $timeout = 25 ); //check for errors if ( is_wp_error( $tmpfile ) ) { $new_src = cmplz_default_placeholder(); } else { //remove current file if ( file_exists( $file ) ) { unlink( $file ); } //in case the server prevents deletion, we check it again. if ( ! file_exists( $file ) ) { copy( $tmpfile, $file ); } } if ( is_string( $tmpfile ) && file_exists( $tmpfile ) ) { unlink( $tmpfile ); } // must unlink afterwards if ( file_exists( $file ) ) { try { $new_src = cmplz_create_webp( $file, $new_src ); } catch ( Exception $e ) { if ( defined( 'WP_DEBUG' ) && WP_DEBUG ) { error_log( $e->getMessage() ); } } } if ( ! file_exists( $file ) ) { return cmplz_default_placeholder(); } return $new_src; } } //if (!function_exists('cmplz_create_webp')){ // function cmplz_create_webp($file, $new_src) { // //check webp availability // if ( // !function_exists('imagecreatefromjpeg') || // !function_exists('imagecreatefrompng') || // !function_exists('imagewebp') || // !function_exists('imagedestroy') || // !function_exists('imagepalettetotruecolor') || // !function_exists('imagealphablending') || // !function_exists('imagesavealpha') // ) { // return $new_src; // } // // if ( stripos( $file, '.jpeg' ) !== false || stripos( $file, '.jpg' ) !== false ) { // $webp_file = str_replace( array( ".jpeg", '.jpg' ), ".webp", $file ); // $webp_new_src = str_replace( array( ".jpeg", '.jpg' ), ".webp", $new_src ); // $image = imagecreatefromjpeg( $file ); // imagewebp( $image, $webp_file, 80 ); // imagedestroy( $image ); // // return file_exists( $webp_file ) ? $webp_new_src : $new_src; // } elseif ( stripos( $file, '.png' ) !== false ) { // $webp_file = str_replace( '.png', ".webp", $file ); // $webp_new_src = str_replace( '.png', ".webp", $new_src ); // $image = imagecreatefrompng( $file ); // imagepalettetotruecolor( $image ); // imagealphablending( $image, true ); // imagesavealpha( $image, true ); // imagewebp( $image, $webp_file, 80 ); // imagedestroy( $image ); // // return file_exists( $webp_file ) ? $webp_new_src : $new_src; // } else { // return $new_src; // } // // } //} if (!function_exists('cmplz_create_webp')){ function cmplz_create_webp($file, $new_src) { switch ( $file ) { case strpos( $file, '.jpeg' )!==false: case strpos( $file, '.jpg' )!==false: $ext = array(".jpeg", '.jpg'); break; case strpos( $file, 'png' )!==false: $ext = '.png'; break; default: return $new_src; } //@todo: new filename is returned by save, so can be used for output instead of brute force extension replace. $webp_file = str_replace( $ext, ".webp", $file ); $webp_new_src = str_replace( $ext, ".webp", $new_src ); $image = wp_get_image_editor($file); $result = $image->save($webp_file, 'image/webp'); if ( is_wp_error( $result ) ) { return $new_src; } return file_exists($webp_file) ? $webp_new_src : $new_src; } } if ( ! function_exists( 'cmplz_used_cookies' ) ) { function cmplz_used_cookies() { $services_template = cmplz_get_template( 'cookiepolicy/services.php' ); $cookies_row = cmplz_get_template( 'cookiepolicy/cookies_row.php' ); $purpose_row = cmplz_get_template( 'cookiepolicy/purpose_row.php' ); $language = substr( get_locale(), 0, 2 ); $args = array( 'language' => $language, 'showOnPolicy' => true, 'hideEmpty' => true, 'ignored' => false ); if ( cmplz_get_option( 'wp_admin_access_users' ) === 'yes' ) { $args['isMembersOnly'] = 'all'; } $cookies = COMPLIANZ::$banner_loader->get_cookies_by_service( $args ); $use_cdb_links = cmplz_get_option( 'use_cdb_links' ) === 'yes'; $consent_per_service = cmplz_get_option( 'consent_per_service' ) === 'yes'; $cookie_list = COMPLIANZ::$cookie_blocker->cookie_list; $google_fonts = new CMPLZ_SERVICE('Google Fonts'); $servicesHTML = ''; foreach ( $cookies as $serviceID => $serviceData ) { $service = new CMPLZ_SERVICE( $serviceID, substr( get_locale(), 0, 2 ) ); //if google fonts is self hosted, don't include in the cookie policy if ( cmplz_get_option('self_host_google_fonts') === 'yes' && defined('CMPLZ_SELF_HOSTED_PLUGIN_ACTIVE') && ($serviceID == $google_fonts->ID || $service->isTranslationFrom == $google_fonts->ID) ) { continue; } if ( isset($cookie_list['marketing'][COMPLIANZ::$cookie_blocker->sanitize_service_name($service->name)]) ){ $topCategory = 'marketing'; } else if ( isset($cookie_list['statistics'][COMPLIANZ::$cookie_blocker->sanitize_service_name($service->name)]) ) { $topCategory = 'statistics'; } else if ( isset($cookie_list['preferences'][COMPLIANZ::$cookie_blocker->sanitize_service_name($service->name)]) ) { $topCategory = 'preferences'; } else { $topCategory = 'functional'; } $serviceCheckboxClass = $consent_per_service ? '' : 'cmplz-hidden'; $has_empty_cookies = false; $allPurposes = array(); $cookieHTML = ""; foreach ( $serviceData as $purpose => $service_cookies ) { $cookies_per_purpose_HTML = ""; foreach ( $service_cookies as $cookie ) { $has_empty_cookies = $has_empty_cookies || strlen( $cookie->retention ) == 0; $link_open = $link_close = ''; if ( $use_cdb_links && strlen( $cookie->slug ) !== 0 ) { $service_slug = ( empty($service->slug) ) ? 'unknown-service' : $service->slug; $link_open = '<a target="_blank" rel="noopener noreferrer nofollow" href="https://cookiedatabase.org/cookie/' . $service_slug . '/' . trailingslashit($cookie->slug) . '">'; $link_close = '</a>'; } $cookie_function = apply_filters('cmplz_cookie_function', ucfirst( $cookie->cookieFunction ), $cookie ); $cookies_per_purpose_HTML .= str_replace( array( '{name}', '{retention}', '{cookieFunction}', '{link_open}', '{link_close}' ), array( $cookie->name, $cookie->retention, $cookie_function, $link_open, $link_close ), $cookies_row ); } $cookieHTML .= str_replace( array( '{purpose}', '{cookies_per_purpose}' ), array( $purpose, $cookies_per_purpose_HTML ), $purpose_row ); $allPurposes[] = $purpose; } $service_name = $service->name; if ( !$service->ID || empty( $service_name ) ){ $service_name = __( 'Miscellaneous', 'complianz-gdpr' ); $serviceCheckboxClass = 'cmplz-hidden'; } $sharing = ''; if ( $service_name === 'Complianz' ) { $link = '<a target="_blank" rel="noopener noreferrer" href="https://complianz.io/legal/privacy-statement/">'; $sharing = __( 'This data is not shared with third parties.', 'complianz-gdpr' ) .' ' . cmplz_sprintf( __( 'For more information, please read the %s%s Privacy Statement%s.', 'complianz-gdpr' ), $link, $service_name, '</a>' ); } else if ( $service->sharesData ) { $attributes = "noopener noreferrer nofollow"; if ( $service->privacyStatementURL !== '' ) { $link = '<a target="_blank" rel="'.$attributes.'" href="' . $service->privacyStatementURL . '">'; $sharing = cmplz_sprintf( __( 'For more information, please read the %s%s Privacy Statement%s.', 'complianz-gdpr' ), $link, $service_name, '</a>' ); } } elseif ( !empty( $service->name ) ) { //don't state sharing info on misc services $sharing = __( 'This data is not shared with third parties.', 'complianz-gdpr' ); } else { $sharing = __( 'Sharing of data is pending investigation', 'complianz-gdpr' ); } $purposeDescription = ( ( !empty( $service_name ) ) && ( !empty( $service->serviceType ) ) ) ? cmplz_sprintf( _x( "We use %s for %s.", 'Legal document cookie policy', 'complianz-gdpr' ), $service_name, $service->serviceType ) : ''; if ( $use_cdb_links && !empty( $service->slug ) && $service->slug !== 'unknown-service' ) { $link_open = '<a target="_blank" rel="noopener noreferrer nofollow" href="https://cookiedatabase.org/service/' . $service->slug . '/">'; $purposeDescription .= ' ' . $link_open . __( 'Read more', "complianz-gdpr" ) . '</a>'; } if ( count($allPurposes)>1 ){ $p_key = array_search(__( 'Purpose pending investigation', 'complianz-gdpr' ), $allPurposes); if ($p_key!==false) unset($allPurposes[$p_key]); } $allPurposes = implode (", ", $allPurposes); $service_slug = str_replace(' ', '-', strtolower($service_name)); $servicesHTML .= str_replace( array( '{service}', '{service_slug}', '{sharing}', '{purposeDescription}', '{cookies}', '{allPurposes}', '{serviceCheckboxClass}', '{topCategory}' ), array( $service_name, $service_slug, $sharing, $purposeDescription, $cookieHTML, $allPurposes, $serviceCheckboxClass, $topCategory ), $services_template ); } $servicesHTML = '<div id="cmplz-cookies-overview">'.$servicesHTML.'</div>'; return str_replace( '{plugin_url}',cmplz_url, $servicesHTML); } } if (!function_exists('cmplz_has_consent')) { /** * @param string $category * * @return bool */ function cmplz_has_consent( $category ) { $consent_type = apply_filters( 'cmplz_user_consenttype', COMPLIANZ::$company->get_default_consenttype() ); $prefix = COMPLIANZ::$banner_loader->get_cookie_prefix(); $cookie_name = "{$prefix}{$category}"; if ( ! $consent_type ) { // If consent_type is not set, there's no consent management, we should // return true to activate all cookies. $has_consent = true; } elseif ( strpos( $consent_type, 'optout' ) !== false && (!isset( $_COOKIE[ $cookie_name ] )) ) { // If it's opt out and no cookie is set or it's false, we should also return true. $has_consent = true; } elseif ( isset( $_COOKIE[ $cookie_name ] ) && 'allow' === $_COOKIE[ $cookie_name ] ) { // All other situations, return only true if value is allow. $has_consent = true; } else { $has_consent = false; } return apply_filters( 'cmplz_has_consent', $has_consent, $category ); } } if (!function_exists('cmplz_has_service_consent')) { /** * Check if a service has consent * * @param string $service * * @return bool * */ function cmplz_has_service_consent( $service ) { $consent_type = apply_filters( 'cmplz_user_consenttype', COMPLIANZ::$company->get_default_consenttype() ); $prefix = COMPLIANZ::$banner_loader->get_cookie_prefix(); $cookie_name = "{$prefix}consented_services"; $consented_services = isset($_COOKIE[ $cookie_name ]) ? json_decode(stripslashes($_COOKIE[ $cookie_name ])) : false; if ( ! $consent_type ) { // If consent_type is not set, there's no consent management, we should // return true to activate all cookies. $has_consent = true; } elseif ( strpos( $consent_type, 'optout' ) !== false ) { // If it's opt out there's no consent per service, we should also return true. $has_consent = true; } elseif ( $consented_services && property_exists( $consented_services, $service ) && 1 == $consented_services->{$service} ) { // All other situations, return only true if value is allow. $has_consent = true; } else { $has_consent = false; } return apply_filters( 'cmplz_has_service_consent', $has_consent, $service ); } } /** * Check if this field is translatable * * @param $fieldname * * @return bool */ if ( ! function_exists( 'cmplz_translate' ) ) { function cmplz_translate( $value, $fieldname ) { if ( function_exists( 'pll__' ) ) { $value = pll__( $value ); } if ( function_exists( 'icl_translate' ) ) { $value = icl_translate( 'complianz', $fieldname, $value ); } $value = apply_filters( 'wpml_translate_single_string', $value, 'complianz', $fieldname ); return $value; } } if ( !function_exists('cmplz_get_server') ) { /** * Get server type * * @return string */ function cmplz_get_server() { $server_raw = strtolower( sanitize_text_field($_SERVER['SERVER_SOFTWARE']) ); //figure out what server they're using if ( strpos( $server_raw, 'apache' ) !== false ) { return 'Apache'; } elseif ( strpos( $server_raw, 'nginx' ) !== false ) { return 'NGINX'; } elseif ( strpos( $server_raw, 'litespeed' ) !== false ) { return 'LiteSpeed'; } else { //unsupported server return 'Not recognized'; } } } if (!function_exists('cmplz_sanitize_category')) { function cmplz_sanitize_category($category){ $cats = ['functional','preferences', 'statistics', 'marketing']; if ( !in_array( $category, $cats, true ) ) { $category = 'marketing'; } return $category; } } if (!function_exists('cmplz_sanitize_consenttype')) { function cmplz_sanitize_consenttype($consenttype){ $types = ['optin','optout', 'other', 'optinstats'];//optinstats might be used by wp consent api if ( !in_array( $consenttype, $types, true ) ) { $consenttype = 'other'; } return $consenttype; } } /** * Show a reference to cookiedatabase if user has accepted the API * * @return bool */ if ( ! function_exists( 'cmplz_cdb_reference_in_policy' ) ) { function cmplz_cdb_reference_in_policy() { $use_reference = COMPLIANZ::$banner_loader->use_cdb_api(); return apply_filters( 'cmplz_use_cdb_reference', $use_reference ); } } /** * Registrer a translation * * @param $fieldname * * @return bool */ if ( ! function_exists( 'cmplz_register_translation' ) ) { function cmplz_register_translation( $string, $fieldname ) { if ( ! is_string( $string ) || !is_string($fieldname) ) { return; } //polylang if ( function_exists( "pll_register_string" ) ) { pll_register_string( $fieldname, $string, 'complianz' ); } //wpml if ( function_exists( 'icl_register_string' ) ) { icl_register_string( 'complianz', $fieldname, $string ); } do_action( 'wpml_register_single_string', 'complianz', $fieldname, $string ); } } if ( ! function_exists( 'cmplz_default_placeholder' ) ) { /** * Return the default placeholder image * * @return string placeholder * @since 2.1.5 */ function cmplz_default_placeholder( $type = 'default' ) { //treat open streetmaps same as google maps. if ( $type === 'openstreetmaps' ) { $type = 'google-maps'; } $style = cmplz_get_option('placeholder_style'); $ratio = $type === 'google-maps' ? cmplz_get_option( 'google-maps-format' ) : ''; $path = cmplz_path . "assets/images/placeholders"; //check if this type exists as placeholder if ( file_exists( "$path/$type-$style-$ratio.jpg" ) ) { $img = "$type-$style-$ratio.jpg"; } else if ( file_exists( "$path/$type-$style.jpg" ) ) { $img = "$type-$style.jpg"; } else { $img = "default-$style.jpg"; } $img_url = cmplz_url . 'assets/images/placeholders/' . $img; //check for image in themedir/complianz-gpdr-premium $theme_img = trailingslashit( get_stylesheet_directory() ) . trailingslashit( basename( cmplz_path ) ) . $img; if ( file_exists( $theme_img ) ) { $img_url = trailingslashit( get_stylesheet_directory_uri() ) . trailingslashit( basename( cmplz_path ) ) . $img; } return apply_filters( 'cmplz_default_placeholder', $img_url, $type, $style ); } } if ( ! function_exists( 'cmplz_get_document_url' ) ) { /** * Get url to legal document * * @param string $region * * @return string URL */ function cmplz_get_document_url( $type, $region = 'eu' ) { return COMPLIANZ::$document->get_page_url( $type, $region ); } } if ( ! function_exists( 'cmplz_remote_file_exists' ) ) { /** * Check if a remote file exists * * @param string $url * * @return bool */ function cmplz_remote_file_exists( string $url ): bool { if ( empty($url) ) { return false; } try { $headers = @get_headers($url); if ($headers === false) { // URL is not accessible or some error occurred return false; } // Check if the HTTP status code starts with "200" (indicating success) return strpos($headers[0], '200') !== false; } catch (Exception $e) { } return false; } } if ( ! function_exists( 'cmplz_detected_firstparty_marketing' )) { /** * Check if we detect first party marketing scripts * @return bool */ function cmplz_detected_firstparty_marketing(){ global $cmplz_integrations_list; $active_plugins = array(); foreach ( $cmplz_integrations_list as $plugin => $details ) { if ( cmplz_integration_plugin_is_enabled( $plugin ) ) { $active_plugins[$plugin] = $details; } } $firstparty_plugins = array_filter(array_column($active_plugins, 'firstparty_marketing')); return count($firstparty_plugins)>0; } } if ( ! function_exists( 'cmplz_uses_gutenberg' ) ) { function cmplz_uses_gutenberg() { if ( function_exists( 'has_block' ) && !class_exists( 'Classic_Editor', false ) ) { return true; } return false; } } if ( ! function_exists( 'cmplz_get_used_consenttypes' ) ) { /** * Get list of consenttypes in use on this site, based on the selected regions * @param bool $add_labels * @return array consenttypes */ function cmplz_get_used_consenttypes( $add_labels = false ) { //get all regions in use on this site $regions = cmplz_get_regions(); //if manuanl override detected, add that region's consenttype here. $consent_types = array(); //for each region, get the consenttype foreach ( $regions as $region ) { if ( ! isset( COMPLIANZ::$config->regions[ $region ]['type'] ) ) { continue; } $consent_types[] = apply_filters( 'cmplz_consenttype', COMPLIANZ::$config->regions[ $region ]['type'], $region ); } //there's no way we can simply find the consenttype for the manually added region, due to fallback complexity. So we add all of them in that case. if ( isset( $_GET['cmplz_user_region']) ) { $consent_types[] = 'optin'; $consent_types[] = 'optout'; } //remove duplicates $consent_types = array_unique( $consent_types ); if ( $add_labels ) { $consent_types_labelled = array(); foreach ( $consent_types as $consent_type ) { $consent_types_labelled[$consent_type] = cmplz_consenttype_nicename($consent_type); } $consent_types = $consent_types_labelled; } return $consent_types; } } if ( ! function_exists( 'cmplz_short_date_format') ) { /** * Make sure the date formate is always the short version. If "F" (February) is used, replace with "M" (Feb) * @return string */ function cmplz_short_date_format(){ return str_replace( array('F', 'Y'), array('M', 'y'), get_option( 'date_format' ) ); } } if ( ! function_exists( 'cmplz_uses_preferences_cookies' ) ) { /** * Check if the site uses preferences cookies * * @return bool */ function cmplz_uses_preferences_cookies() { return cmplz_consent_mode() || cmplz_consent_api_active() || cmplz_get_option( 'consent_per_service' ) === 'yes'; } } if ( ! function_exists( 'cmplz_uses_statistic_cookies' ) ) { /** * Check if the site uses statistic cookies * * @return bool */ function cmplz_uses_statistic_cookies() { return cmplz_get_option( 'compile_statistics' ) !== 'no' || cmplz_uses_thirdparty('vimeo'); } } if ( ! function_exists( 'cmplz_uses_marketing_cookies' ) ) { /** * Check if the site uses marketing cookies * * @return bool */ function cmplz_uses_marketing_cookies() { $uses_marketing_cookies = cmplz_get_option( 'uses_ad_cookies' ) === 'yes' || cmplz_get_option( 'uses_firstparty_marketing_cookies' ) === 'yes' || cmplz_get_option( 'uses_thirdparty_services' ) === 'yes' || cmplz_get_option( 'uses_social_media' ) === 'yes'; return apply_filters( 'cmplz_uses_marketing_cookies', $uses_marketing_cookies ); } } if ( ! function_exists( 'cmplz_impressum_required' ) ) { /** * Check if the site requires an impressum * * @return bool */ function cmplz_impressum_required() { return cmplz_get_option( 'eu_consent_regions' ) === 'yes' && cmplz_get_option( 'impressum' ) !== 'none' ; } } if ( ! function_exists( 'cmplz_uses_optin' ) ) { /** * Check if the site uses one of the optin types * * @return bool */ function cmplz_uses_optin() { $regions = cmplz_get_regions(); //ensure a default in case of no regions, to prevent weird cookie banner wysiwyg issues. if (count($regions)===0) { return true; } return ( in_array( 'optin', cmplz_get_used_consenttypes() ) || in_array( 'optinstats', cmplz_get_used_consenttypes() ) ); } } if ( ! function_exists( 'cmplz_uses_optout' ) ) { function cmplz_uses_optout() { return ( in_array( 'optout', cmplz_get_used_consenttypes() ) ); } } if ( ! function_exists( 'cmplz_ab_testing_enabled' ) ) { function cmplz_ab_testing_enabled() { return apply_filters( 'cmplz_ab_testing_enabled', false ); } } if ( ! function_exists( 'cmplz_consenttype_nicename' ) ) { /** * Get nice name for consenttype * * @param string $consenttype * * @return string nicename */ function cmplz_consenttype_nicename( $consenttype ) { switch ( $consenttype ) { case 'optin': return __( 'Opt-in', 'complianz-gdpr' ); case 'optout': return __( 'Opt-out', 'complianz-gdpr' ); default : return __( 'All consent types', 'complianz-gdpr' ); } } } if ( ! function_exists( 'cmplz_uses_sensitive_data' ) ) { /** * Check if site uses sensitive data * * @return bool uses_sensitive_data */ function cmplz_uses_sensitive_data() { $special_data = array( 'bank-account', 'financial-information', 'medical', 'health-insurcance' ); foreach ( COMPLIANZ::$config->purposes as $key => $label ) { if ( ! empty( COMPLIANZ::$config->details_per_purpose_us ) ) { foreach ( $special_data as $special_data_key ) { $value = cmplz_get_option( $key . '_data_purpose_us' ); if ( isset( $value[ $special_data_key ] ) && $value[ $special_data_key ] ) { return true; } } } } return false; } } if ( ! function_exists( 'cmplz_get_consenttype_for_region' ) ) { /** * Get the consenttype which is used in this region * * @param string $region * * @return string consenttype */ function cmplz_get_consenttype_for_region( $region ) { //fallback if ( ! isset( COMPLIANZ::$config->regions[ $region ]['type'] ) ) { $consenttype = 'optin'; } else { $consenttype = COMPLIANZ::$config->regions[ $region ]['type']; } return apply_filters( 'cmplz_consenttype', $consenttype, $region ); } } if ( ! function_exists( 'cmplz_uses_consenttype' ) ) { /** * Check if a specific consenttype is used * * @param string $check_consenttype * @param string $region * * @return bool $uses_consenttype */ function cmplz_uses_consenttype( $check_consenttype, $region = false ) { if ( $region ) { //get consenttype for region $consenttype = cmplz_get_consenttype_for_region( $region ); if ( $consenttype === $check_consenttype ) { return true; } } else { //check if any region has a consenttype $check_consenttype $regions = cmplz_get_regions(); foreach ( $regions as $k_region ) { $consenttype = cmplz_get_consenttype_for_region( $k_region ); if ( $consenttype === $check_consenttype ) { return true; } } } return false; } } if ( ! function_exists( 'cmplz_get_default_banner_id' ) ) { /** * Get the default banner ID * * @return int default_ID */ function cmplz_get_default_banner_id() { $banner_id = cmplz_get_transient('cmplz_default_banner_id'); if ( !$banner_id ){ if ( !get_option('cmplz_cbdb_version') ) { //table not created yet. return 0; } global $wpdb; $cookiebanners = $wpdb->get_results( "select * from {$wpdb->prefix}cmplz_cookiebanners as cb where cb.default = true" ); //if nothing, try the first entry if ( empty( $cookiebanners ) ) { $cookiebanners = $wpdb->get_results( "select * from {$wpdb->prefix}cmplz_cookiebanners" ); } if ( ! empty( $cookiebanners ) ) { $banner_id = $cookiebanners[0]->ID; } cmplz_set_transient('cmplz_default_banner_id', $banner_id, HOUR_IN_SECONDS); } return $banner_id; } } if ( ! function_exists( 'cmplz_user_can_manage' ) ) { function cmplz_user_can_manage() { if ( current_user_can( apply_filters('cmplz_capability','manage_privacy') ) ) { return true; } return false; } } if ( ! function_exists( 'cmplz_get_cookiebanners' ) ) { /** * Get array of banner objects * * @param array $args * * @return array */ function cmplz_get_cookiebanners( $args = array() ) { $args = wp_parse_args( $args, array( 'status' => 'active' ) ); $sql = ''; global $wpdb; if ( isset($args['ID']) ) { $sql = 'AND cdb.ID = ' . (int) $args['ID']; } if ( isset( $args['default'] ) && $args['default'] === true ) { $sql = 'AND cdb.default = true LIMIT 1'; } if ( isset( $args['default'] ) && $args['default'] === false ) { $sql = 'AND cdb.default = false'; } if ( isset( $args['limit'] ) && $args['limit'] !== false ) { $sql = ' LIMIT ' . (int) $args['limit']; } $sql_string = empty($sql) ? 'default' : sanitize_title($sql); $cookiebanners = wp_cache_get('cmplz_cookiebanners_'.$sql_string, 'complianz'); if ( !$cookiebanners ){ $cookiebanners = $wpdb->get_results( "select * from {$wpdb->prefix}cmplz_cookiebanners as cdb where 1=1 $sql" ); wp_cache_set('cmplz_cookiebanners_'.$sql_string, $cookiebanners, 'complianz', HOUR_IN_SECONDS); } return $cookiebanners; } } if ( ! function_exists( 'cmplz_sanitize_language' ) ) { /** * Validate a language string * * @param $language * * @return bool|string */ function cmplz_sanitize_language( $language ) { $pattern = '/^[a-zA-Z]{2}$/'; if ( ! is_string( $language ) ) { return false; } $language = substr( $language, 0, 2 ); if ( (bool) preg_match( $pattern, $language ) ) { $language = strtolower( $language ); return $language; } return false; } } if ( ! function_exists( 'cmplz_sanitize_languages' ) ) { /** * Validate a languages array * * @param array $language * * @return array */ function cmplz_sanitize_languages( $languages ) { $output = array(); foreach ( $languages as $language ) { $output[] = cmplz_sanitize_language( $language ); } return $output; } } if ( ! function_exists( 'cmplz_remove_free_translation_files' ) ) { /** * Get a list of files from a directory, with the extensions as passed. */ function cmplz_remove_free_translation_files() { //can't use cmplz_path here, it may not have been defined yet on activation $path = plugin_dir_path(__FILE__); $path = dirname( $path, 2 ) . "/languages/plugins/"; $extensions = array( "po", "mo", "php" ); if ( $handle = opendir( $path ) ) { while ( false !== ( $file = readdir( $handle ) ) ) { if ( $file != "." && $file != ".." ) { $file = $path . '/' . $file; $ext = strtolower( pathinfo( $file, PATHINFO_EXTENSION ) ); if ( is_file( $file ) && in_array( $ext, $extensions ) && strpos( $file, 'complianz-gdpr' ) !== false && strpos( $file, 'backup' ) === false ) { unlink($file); } } } closedir( $handle ); } } } if ( ! function_exists( 'cmplz_has_free_translation_files' ) ) { /** * Get a list of files from a directory, with the extensions as passed. * * @return bool */ function cmplz_has_free_translation_files() { //can't use cmplz_path here, it may not have been defined yet on activation $path = plugin_dir_path(__FILE__); $path = dirname( $path, 2 ) . "/languages/plugins/"; if ( ! file_exists( $path ) ) { return false; } $has_free_files = false; $extensions = array( "po", "mo" ); if ( $handle = opendir( $path ) ) { while ( false !== ( $file = readdir( $handle ) ) ) { if ( $file != "." && $file != ".." ) { $file = $path . '/' . $file; $ext = strtolower( pathinfo( $file, PATHINFO_EXTENSION ) ); if ( is_file( $file ) && in_array( $ext, $extensions ) && strpos( $file, 'complianz-gdpr' ) !== false ) { $has_free_files = true; break; } } } closedir( $handle ); } return $has_free_files; } } if (!function_exists('array_key_first')) { function array_key_first(array $array) { reset($array); return key($array); } } if ( ! function_exists( 'cmplz_sprintf' ) ) { /** * Wrapper function for sprintf to prevent fatal errors when the %s variables in source and target do not match * @param string $format * @param mixed $values * @return string */ function cmplz_sprintf(){ $args = func_get_args(); $count = substr_count($args[0], '%s'); $args_count = count($args) - 1; if ( $args_count === $count ){ return call_user_func_array('sprintf', $args); } else { $output = $args[0]; if ( cmplz_admin_logged_in() ){ $output .= ' <a target="_blank" href="https://complianz.io/translation-error-sprintf-printf-too-few-arguments">(Translation error)</a>'; } return $output; } } } if ( !function_exists('cmplz_dnt_enabled') ) { /** * Premium should respect Do Not Track settings in browsers, if the user has enabled this setting. * * * */ function cmplz_dnt_enabled() { //only if the user has explicitly enabled this if ( cmplz_get_option('respect_dnt') !== 'no' ) { return ( ( isset($_SERVER['HTTP_DNT']) && $_SERVER['HTTP_DNT'] == 1 ) || isset($_SERVER['HTTP_SEC_GPC']) ); } return false; } } if ( ! function_exists( 'cmplz_printf' ) ) { /** * Wrapper function for printf to prevent fatal errors when the %s variables in source and target do not match * @param string $format * @param mixed $values * @echo string */ function cmplz_printf(){ $args = func_get_args(); $count = substr_count($args[0], '%s'); $args_count = count($args) - 1; if ( $args_count === $count ){ echo call_user_func_array('sprintf', $args); } else { $output = $args[0]; if ( cmplz_admin_logged_in() ){ $output .= ' <a target="_blank" href="https://complianz.io/translation-error-sprintf-printf-too-few-arguments">(Translation error)</a>'; } echo $output; } } } if ( ! function_exists('cmplz_quebec_notice')) { function cmplz_quebec_notice() { $text = cmplz_sprintf( __( "In September 2023 the Quebec bill 64 will be enforced in Canada. In order to keep your site compliant, %sopt-in must be implemented for Canada%s. Please Navigate to the %sWizard%s and enable opt-in for Canada.", "complianz-gdpr" ), '<strong>', '</strong>' , '<a href="' . admin_url( 'admin.php?page=cmplz-wizard&step=1' ) . '">', '</a>' ) . "<br><br>"; $text .= __( "Please be aware that this will activate opt-in for Canada, altering the banner and blocking non-functional scripts and cookies prior to consent. Please check the front-end of your site after activating opt-in.", "complianz-gdpr" ); return $text; } } if ( ! function_exists('cmplz_requires_quebec_notice') ) { function cmplz_requires_quebec_notice() { if ( array_key_exists('ca', cmplz_get_regions() ) && cmplz_get_option('sensitive_information_processed') !== 'yes' && cmplz_upgraded_to_current_version() ) { return true; } return false; } } if ( ! function_exists('cmplz_targets_quebec') ) { if ( cmplz_get_option('ca_targets_quebec') === 'yes') { return true; } return false; }