64 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * WP Captcha
 | |
|  * https://getwpcaptcha.com/
 | |
|  * (c) WebFactory Ltd, 2022 - 2023, www.webfactoryltd.com
 | |
|  */
 | |
| 
 | |
| class WPCaptcha_Stats extends WPCaptcha
 | |
| {
 | |
|     static public $stats_cutoff = 1;
 | |
| 
 | |
|     /**
 | |
|      * Get statistics
 | |
|      *
 | |
|      * @since 5.0
 | |
|      *
 | |
|      * @param string $type locks|fails
 | |
|      * @param int $ndays period for statistics
 | |
|      * @return bool
 | |
|      */
 | |
|     static function get_stats($type = "locks", $ndays = 60)
 | |
|     {
 | |
|         global $wpdb;
 | |
|         
 | |
|         $days = array();
 | |
|         for ($i = $ndays; $i >= 0; $i--){
 | |
|             $days[date("Y-m-d", strtotime('-' . $i . ' days'))] = 0;
 | |
|         }
 | |
| 
 | |
|         if ($type == 'locks') {
 | |
|             $results = $wpdb->get_results("SELECT COUNT(*) as count,DATE_FORMAT(accesslock_date, '%Y-%m-%d') AS date FROM " . $wpdb->wpcatcha_accesslocks . " GROUP BY DATE_FORMAT(accesslock_date, '%Y%m%d')");
 | |
|         } else {
 | |
|             $results = $wpdb->get_results("SELECT COUNT(*) as count,DATE_FORMAT(login_attempt_date, '%Y-%m-%d') AS date FROM " . $wpdb->wpcatcha_login_fails . " GROUP BY DATE_FORMAT(login_attempt_date, '%Y%m%d')");
 | |
|         }
 | |
| 
 | |
|         $total = 0;
 | |
| 
 | |
|         foreach ($results as $day) {
 | |
|             if(array_key_exists($day->date, $days)){
 | |
|                 $days[$day->date] = $day->count;
 | |
|                 $total += $day->count;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if ($total < self::$stats_cutoff) {
 | |
|             $stats['days'] = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20);
 | |
|             $stats['count'] = array(3, 4, 67, 76, 45, 32, 134, 6, 65, 65, 56, 123, 156, 156, 123, 156, 67, 88, 54, 178);
 | |
|             $stats['total'] = $total;
 | |
| 
 | |
|             return $stats;
 | |
|         }
 | |
| 
 | |
|         $stats = array('days' => array(), 'count' => array(), 'total' => 0);
 | |
|         foreach ($days as $day => $count) {
 | |
|             $stats['days'][] = $day;
 | |
|             $stats['count'][] = $count;
 | |
|             $stats['total'] += $count;
 | |
|         }
 | |
|         $stats['period'] = $ndays;
 | |
|         return $stats;
 | |
|     } // get_stats
 | |
| 
 | |
| } // class
 |