whereRaw( '(`created_at` >= NOW() - INTERVAL ? SECOND)', array((int)$subscription_limit_window) )->count(); if($subscription_count > 0) { $timeout = $subscription_limit_base * pow(2, $subscription_count - 1); $existing_user = SubscriberIP::where('ip', $subscriber_ip) ->whereRaw( '(`created_at` >= NOW() - INTERVAL ? SECOND)', array((int)$timeout) )->findOne(); if(!empty($existing_user)) { return $timeout; } } } } $ip = SubscriberIP::create(); $ip->ip = $subscriber_ip; $ip->save(); self::purge($subscription_limit_window); return false; } static function purge($interval) { return SubscriberIP::whereRaw( '(`created_at` < NOW() - INTERVAL ? SECOND)', array($interval) )->deleteMany(); } }