discourse/lib/current_user.rb

50 lines
1.0 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2013-02-06 03:16:51 +08:00
module CurrentUser
def self.has_auth_cookie?(env)
Discourse.current_user_provider.new(env).has_auth_cookie?
end
2013-02-15 16:23:40 +08:00
def self.lookup_from_env(env)
Discourse.current_user_provider.new(env).current_user
end
# can be used to pretend current user does no exist, for CSRF attacks
def clear_current_user
@current_user_provider = Discourse.current_user_provider.new({})
end
def log_on_user(user, opts = {})
current_user_provider.log_on_user(user, session, cookies, opts)
user.logged_in
end
def log_off_user
2017-07-28 09:20:09 +08:00
current_user_provider.log_off_user(session, cookies)
2013-02-15 16:23:40 +08:00
end
def is_api?
current_user_provider.is_api?
end
def is_user_api?
current_user_provider.is_user_api?
end
2013-02-06 03:16:51 +08:00
def current_user
current_user_provider.current_user
end
2013-03-26 09:04:28 +08:00
def refresh_session(user)
2017-07-28 09:20:09 +08:00
current_user_provider.refresh_session(user, session, cookies)
end
private
2013-03-26 09:04:28 +08:00
def current_user_provider
@current_user_provider ||= Discourse.current_user_provider.new(request.env)
2013-02-06 03:16:51 +08:00
end
end