2016-06-25 10 views
0

私はsoundcloud APIを含むアプリケーションで作業しています。既存のユーザーレコードを更新する方法

私はユーザーのログインとモデルを持っています。私はsoundcloud_idとトークンを既存のユーザーに追加したいと思いますが、ユーザーレコードを何とか更新できません。 何が間違っていますか?

てSoundcloudコントローラ

class SoundcloudController < ApplicationController 


     def connect 
     # create client object with app credentials 
     client = Soundcloud.new(:client_id => ENV["SOUNDCLOUD_CLIENT_ID"], 
           :client_secret => ENV["SOUNDCLOUD_CLIENT_SECRET"], 
           :redirect_uri => "http://localhost:3000/soundcloud/oauth-callback", 
           :response_type => 'code') 

     # redirect user to authorize URL 
     redirect_to client.authorize_url(:grant_type => 'authorization_code', :scope => 'non-expiring', :display => 'popup') 
     end 

     def connected 
     # create client object with app credentials 
     client = Soundcloud.new(:client_id => ENV["SOUNDCLOUD_CLIENT_ID"], 
        :client_secret => ENV["SOUNDCLOUD_CLIENT_SECRET"], 
        :redirect_uri => "http://localhost:3000/soundcloud/oauth-callback") 

     # exchange authorization code for access token 
     access_token = client.exchange_token(:code => params[:code]) 
     client = Soundcloud.new(:access_token => access_token["access_token"]) 

     # make an authenticated call 
     soundcloud_user = client.get('/me') 
     unless User.where(:soundcloud_user_id => soundcloud_user["id"]).present? 
     #User.create_from_soundcloud(soundcloud_user, access_token) 
     UsersController.add_soundcloud_account(soundcloud_user, access_token) 
     end 
     sign_in_user = User.where(:soundcloud_user_id => soundcloud_user["id"]) 

     #create user sessions 
     #session[:user_id] = sign_in_user.first.id 
     redirect_to root_url, notice: "Signed in!" 
     end 

     def destroy 
     end 
    end 

ユーザーコントローラ

あなたが @current_usersaveを呼び出し、メソッドにセッション情報を渡す必要があり
class UsersController < ApplicationController 


     def new 
     @user = User.new 
     end 

     #create a user and redirect to home 
     def create 
     @user = User.new(user_params) 
     if @user.save 
      session[:user_id] = @user.id 
      redirect_to '/' 
     else 
      redirect_to '/signup' 
     end 
     end 


     def self.add_soundcloud_account(soundcloud_user, access_token) 
     @current_user ||= User.find(session[:user_id]) 
     @current_user.soundcloud_user_id = soundcloud_user["id"] 
     @current_user.soundcloud_access_token = access_token["access_token"] 
     end 

     private 
     def user_params 
     params.require(:user).permit(:first_name, :last_name, :email, :password) 
     end 
    end 

答えて

1

:それが呼び出された

def self.add_soundcloud_account(user_id, soundcloud_user, access_token) 
    @current_user ||= User.find(user_id) 
    @current_user.soundcloud_user_id = soundcloud_user["id"] 
    @current_user.soundcloud_access_token = access_token["access_token"] 
    @current_user.save 
end 

このように:

UsersController.add_soundcloud_account(session[:user_id], soundcloud_user, access_token) 

しかし、add_soundcloud_accountメソッドがコントローラに属しているかどうかわかりません。私はそれをサービスで、あるいはちょうどUserモデルで見たいと思うでしょう。

+0

私はそのメソッドにアクセスするたびにerorを取得します。「未定義のローカル変数またはメソッドSession for UsersController:Class」 – AbNadi

+0

が更新されました。リファクタリングの考えを加えました。 – danielrsmith

+0

それは、感謝の仲間が動作します。 – AbNadi