Class: Fcid::SessionController
- Inherits:
-
ApplicationController
- Object
- ApplicationController
- Fcid::SessionController
- Defined in:
- app/controllers/fcid/session_controller.rb
Instance Method Summary collapse
- #create ⇒ Object
- #destroy ⇒ Object
- #new ⇒ Object
- #oauth ⇒ Object
-
#sync ⇒ Object
sync user infomation from fcid.net.
Instance Method Details
#create ⇒ Object
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
# File 'app/controllers/fcid/session_controller.rb', line 35 def create if fcid_user = Fcid::User.authenticate(params[:username_or_email], params[:password]) ::User.sync(fcid_user["id"]) self.current_user = ::User.find(fcid_user["id"]) end if logged_in? respond_to do |format| format.html do flash[:notice] = "登录成功。" url = params[:redirect_to] || session[:redirect_to] || root_path session.delete :redirect_to redirect_to url end format.js do end end else flash[:error] = "登录失败,请确认你输入的信息是正确的,或者此用户未被激活" redirect_to new_fcid_session_path end end |
#destroy ⇒ Object
64 65 66 67 68 69 70 71 |
# File 'app/controllers/fcid/session_controller.rb', line 64 def destroy .delete :auth_token .delete :fcid_auth_token #删除passport上面的cookie,防止再次通过passport上的cookie登录 session.delete :user session.delete :user_id flash[:notice] = "您已经成功退出系统。" redirect_to(:back) end |
#new ⇒ Object
58 59 60 61 62 |
# File 'app/controllers/fcid/session_controller.rb', line 58 def new if params[:redirect_to] session[:redirect_to] = params[:redirect_to] end end |
#oauth ⇒ Object
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
# File 'app/controllers/fcid/session_controller.rb', line 4 def oauth oauth_token,oauth_verifier = params[:oauth_token] , params[:oauth_verifier] if oauth_token && oauth_verifier @access_token = session[:request_token].get_access_token :oauth_verifier => oauth_verifier hash = Hash.from_xml @access_token.get("/users/me.xml").body user_hash = hash['user'] # ::User.sync(@user['id']) user = ::User.find_or_initialize_by_id(user_hash['id']) user_hash.each_pair do |key,value| # user[key] = value end user[:uname] = user_hash['username'] user[:avatar] = user_hash['avatar'] user[:access_token] = @access_token.token user[:access_secret] = @access_token.secret user.save! self.current_user = user url = params[:redirect_to] || session[:redirect_to] || root_path session.delete :redirect_to redirect_to url else # 先检测是否登录了 fcid @request_token = Fcid.consumer.get_request_token session[:request_token] = @request_token redirect_to @request_token. + "&dialog=1" end rescue OAuth::Unauthorized=> e (flash[:error] = "无权访问,请确认配置文件设置是否正确(api_key,api_secret)") && redirect_to(:back) end |
#sync ⇒ Object
sync user infomation from fcid.net
74 75 76 77 78 |
# File 'app/controllers/fcid/session_controller.rb', line 74 def sync ::User.sync(current_user.id) if logged_in? flash[:notice] = "同步成功" redirect_to_back_or_default '/' end |