0

Ruby on Rails 3.2 と oauth2 gem で MapMyFitness API (www.mapmyapi.com) を使用しようとしています。まず、私のアプリは "get_auth_url" で auth_url を生成します。次にブラウザがそこに移動し、認証されるとコールバックが「mapmyfitness_callback」に返されます。「mapmyfitness_callback」は「ワークアウト」のリストも取得し、それらはブラウザーに表示されます。

問題は、ユーザーがワークアウトを選択してダウンロードするときです。選択したワークアウトを取得するには、「get_workout」を呼び出します。ただし、リクエストに適切なトークンを取得するのに苦労しています。

以下の行がクラッシュします。

workout_data = access_token.get('/v7.0/workout/' + workout_id, :params => { 'field_set' => 'time_series' }, :headers => {'Api-Key' => ENV['MMF_API_KEY'], 'Authorization' => auth_token}).body

with: OAuth2::Error (: {"oauth1_error":"Malformed Authorization header","oauth1_error_code":"OAUTH1:UNKNOWN"}): app/controllers/telemetry_controller.rb:60:in `get_workout'

コントローラ コード全体:

require 'oauth2'

class TelemetryController < ApplicationController

  def get_auth_url  
    auth_url = mmf_client.auth_code.authorize_url(:redirect_uri => 'http://localhost:3000/telemetry/mapmyfitness_callback')

    respond_to do |format|
      format.json{ render :json => {:auth_url => auth_url}.to_json }
    end  
  end

  def mapmyfitness_callback

    # Get user
    @code = params[:code]
    token = mmf_client.auth_code.get_token(@code, :redirect_uri => 'http://localhost:3000/telemetry/mapmyfitness_callback', :headers => {'Api-Key' => ENV['MMF_API_KEY']})
    mmf_user = JSON.parse(token.get('/v7.0/user/self', :headers => {'Api-Key' => ENV['MMF_API_KEY'], 'Authorization' => @code}).body)
    mmf_user_id = mmf_user['id']

    @auth_token = token.token

    # Get workouts
    mmf_workouts = JSON.parse(token.get('/v7.0/workout', :params => { 'user' => mmf_user_id }, :headers => {'Api-Key' => ENV['MMF_API_KEY'], 'Authorization' => @code}).body)

    @workout_list = Array.new
    mmf_workouts['_embedded']['workouts'].each do |workout|
      workout_data = {:name => workout['name'],
                      :id => workout['_links']['self'][0]['id']}
      @workout_list.push(workout_data)
    end        

    render :layout => false

  end

  def get_workout

    code = params[:code]
    auth_token = params[:auth_token]

    access_token = OAuth2::AccessToken.new(mmf_client, auth_token, {
        :mode => :query,
        :param_name => "oauth2_access_token",
    })    

    puts access_token.to_yaml

    # Get workout
    workout_id = params[:workout_id]
    workout_data = access_token.get('/v7.0/workout/' + workout_id, :params => { 'field_set' => 'time_series' }, :headers => {'Api-Key' => ENV['MMF_API_KEY'], 'Authorization' => auth_token}).body

    respond_to do |format|
      format.json{ render :json => {:mmf_workout_data => workout_data}.to_json }
    end

  end

  private

  def mmf_client

    client = OAuth2::Client.new(
        ENV['MMF_API_KEY'],
        ENV['MMF_SECRET_KEY'], 
        :authorize_url => "https://www.mapmyfitness.com/v7.0/oauth2/authorize/", 
        :token_url => "https://oauth2-api.mapmyapi.com/v7.0/oauth2/access_token/", 
        :site => "https://oauth2-api.mapmyapi.com"
    )

  end

end
4

2 に答える 2

0

私はそれを考え出した。get_workout は次のようにする必要があります。

  def get_workout

    auth_token = params[:auth_token]

    token = OAuth2::AccessToken.new(mmf_client, auth_token)

    # Get workout
    workout_id = params[:workout_id]
    workout_data = token.get('/v7.0/workout/' + workout_id, :params => { 'field_set' => 'time_series' }, :headers => {'Api-Key' => ENV['MMF_API_KEY'], 'Authorization' => auth_token}).body

    respond_to do |format|
      format.json{ render :json => {:mmf_workout_data => workout_data}.to_json }
    end

  end
于 2014-07-23T00:42:17.843 に答える