Server : Apache System : Linux pod-100823:apache2_74:v0.5.7 5.4.0-1138-gcp #147~18.04.1-Ubuntu SMP Mon Oct 7 21:46:26 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33.7 Disable Function : apache_child_terminate,apache_get_modules,apache_get_version,apache_getenv,apache_note,apache_setenv,disk_free_space,disk_total_space,diskfreespace,dl,exec,fastcgi_finish_request,link,opcache_compile_file,opcache_get_configuration,opcache_invalidate,opcache_is_script_cached,opcache_reset,passthru,pclose,pcntl_exec,popen,posix_getpid,posix_getppid,posix_getpwuid,posix_kill,posix_mkfifo,posix_setegid,posix_seteuid,posix_setgid,posix_setpgid,posix_setsid,posix_setuid,posix_uname,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,realpath_cache_get,shell_exec,show_source,symlink,system Directory : /nas/content/live/attorneyexperi/wp-content/plugins/redirection/models/ |
<?php class Red_Flusher { const DELETE_HOOK = 'redirection_log_delete'; const DELETE_FREQ = 'daily'; const DELETE_MAX = 20000; const DELETE_KEEP_ON = 10; // 10 minutes public function flush() { $options = red_get_options(); $total = $this->expire_logs( 'redirection_logs', $options['expire_redirect'] ); $total += $this->expire_logs( 'redirection_404', $options['expire_404'] ); if ( $total >= self::DELETE_MAX ) { $next = time() + ( self::DELETE_KEEP_ON * 60 ); // There are still more logs to clear - keep on doing until we're clean or until the next normal event if ( $next < wp_next_scheduled( self::DELETE_HOOK ) ) { wp_schedule_single_event( $next, self::DELETE_HOOK ); } } $this->optimize_logs(); } private function optimize_logs() { global $wpdb; $rand = wp_rand( 1, 5000 ); if ( $rand === 11 ) { $wpdb->query( "OPTIMIZE TABLE {$wpdb->prefix}redirection_logs" ); } elseif ( $rand === 12 ) { $wpdb->query( "OPTIMIZE TABLE {$wpdb->prefix}redirection_404" ); } } private function expire_logs( $table, $expiry_time ) { global $wpdb; if ( $expiry_time > 0 ) { // Known values // phpcs:ignore $logs = $wpdb->get_var( $wpdb->prepare( "SELECT COUNT(*) FROM {$wpdb->prefix}{$table} WHERE created < DATE_SUB(NOW(), INTERVAL %d DAY)", $expiry_time ) ); if ( $logs > 0 ) { // Known values // phpcs:ignore $wpdb->query( $wpdb->prepare( "DELETE FROM {$wpdb->prefix}{$table} WHERE created < DATE_SUB(NOW(), INTERVAL %d DAY) LIMIT %d", $expiry_time, self::DELETE_MAX ) ); return min( self::DELETE_MAX, $logs ); } } return 0; } public static function schedule() { $options = red_get_options(); if ( $options['expire_redirect'] > 0 || $options['expire_404'] > 0 ) { if ( ! wp_next_scheduled( self::DELETE_HOOK ) ) { wp_schedule_event( time(), self::DELETE_FREQ, self::DELETE_HOOK ); } } else { self::clear(); } } public static function clear() { wp_clear_scheduled_hook( self::DELETE_HOOK ); } }