parent
0b2a18a197
commit
845f20b2ee
@ -0,0 +1,2 @@
|
||||
module LimitForbidControl
|
||||
end
|
@ -0,0 +1,56 @@
|
||||
class LimitForbidControl::Base
|
||||
def initialize
|
||||
end
|
||||
|
||||
def cache_key
|
||||
raise 'Please overwrite method :cache_Key'
|
||||
end
|
||||
|
||||
def forbid_cache_key
|
||||
"#{cache_key}:forbid"
|
||||
end
|
||||
|
||||
def allow_times
|
||||
5
|
||||
end
|
||||
|
||||
def cumulative_expires
|
||||
1.days
|
||||
end
|
||||
|
||||
def forbid_expires
|
||||
1.hours
|
||||
end
|
||||
|
||||
def forbid?
|
||||
Rails.cache.read(forbid_cache_key)
|
||||
end
|
||||
|
||||
def increment!
|
||||
value = Rails.cache.read(cache_key)
|
||||
value = value.to_i + 1
|
||||
|
||||
# 锁定
|
||||
if value > allow_times.to_i
|
||||
Rails.cache.write(forbid_cache_key, true, expires_in: forbid_expires)
|
||||
Rails.cache.delete(cache_key)
|
||||
else
|
||||
Rails.cache.write(cache_key, value, expires_in: cumulative_expires)
|
||||
end
|
||||
end
|
||||
|
||||
def clear
|
||||
Rails.cache.delete(forbid_cache_key)
|
||||
Rails.cache.delete(cache_key)
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def redis_cache?
|
||||
Rails.cache.is_a?(ActiveSupport::Cache::RedisStore)
|
||||
end
|
||||
|
||||
def day
|
||||
Time.current.strftime('%Y%m%d')
|
||||
end
|
||||
end
|
@ -0,0 +1,25 @@
|
||||
class LimitForbidControl::SendEmailCode < LimitForbidControl::Base
|
||||
attr_reader :email
|
||||
|
||||
def initialize(email)
|
||||
super()
|
||||
@email = email
|
||||
end
|
||||
|
||||
def allow_times
|
||||
EduSetting.get('daily_send_email_code_times').presence || 5
|
||||
end
|
||||
|
||||
def forbid_expires
|
||||
num = EduSetting.get('daily_send_email_code_forbid_time').presence.to_i
|
||||
num.zero? ? 10.minutes : num.to_i.hours
|
||||
end
|
||||
|
||||
def cumulative_expires
|
||||
1.hours
|
||||
end
|
||||
|
||||
def cache_key
|
||||
@_cache_key ||= "limit_forbid_control:#{day}:send_email_code:#{email}"
|
||||
end
|
||||
end
|
@ -0,0 +1,25 @@
|
||||
class LimitForbidControl::UserLogin < LimitForbidControl::Base
|
||||
attr_reader :user
|
||||
|
||||
def initialize(user)
|
||||
super()
|
||||
@user = user
|
||||
end
|
||||
|
||||
def allow_times
|
||||
EduSetting.get('daily_error_password_times').presence || 5
|
||||
end
|
||||
|
||||
def forbid_expires
|
||||
num = EduSetting.get('daily_error_password_forbid_time').presence.to_i
|
||||
num.zero? ? 1.hours : num.to_i.hours
|
||||
end
|
||||
|
||||
def cumulative_expires
|
||||
1.days
|
||||
end
|
||||
|
||||
def cache_key
|
||||
@_cache_key ||= "limit_forbid_control:#{day}:user_login:#{user.id}"
|
||||
end
|
||||
end
|
Loading…
Reference in new issue