我正在尝试将OAuth2 for Server to Server Applications与Google's Content API for Shopping结合使用google-api-client gem和Ruby on Rails 3.2.5。此外,我已按照Content API文档中的规定设置了我的商家帐户。
这是我发现的最佳方式:
使用this sample中的第1 - 23行作为起点,我已经开始编写以下模块用于后台作业:
require 'httparty'
require 'google/api_client'
module GoogleProducts
GOOGLE_CONFIG = YAML.load_file(File.join(Rails.root, "config", "google.yml"))[Rails.env]
CLIENT_ID = "XXXXXXXXXXXX@developer.gserviceaccount.com"
MERCHANT_ID = "XXXXXXX"
SCOPE = "https://www.googleapis.com/auth/structuredcontent"
KEY_FILE_PATH = File.join(Rails.root, "config", "my-privatekey.p12")
KEY_FILE_PASS = "XXXXXXXXXX"
def self.add_item(item_id)
self.fetch_token
xml = self.gen_item_xml(item_id)
headers = {"Content-type" => "application/atom+xml", "Content-Length" => xml.length.to_s}
url = "https://content.googleapis.com/content/v1/#{MERCHANT_ID}/items/products/generic?access_token=#{$gp_token}"
response = HTTParty.post(url, :body => xml, :headers => headers).parsed_response
end
def self.gen_item_xml(item_id)
#building product xml
end
private
def self.fetch_token
api_client = Google::APIClient.new(:authorization => :oauth2)
key = Google::APIClient::PKCS12.load_key(KEY_FILE_PATH, KEY_FILE_PASS)
asserter = Google::APIClient::JWTAsserter.new(CLIENT_ID, SCOPE, key)
begin
api_client.authorization = asserter.authorize
#todo - store in something other than a global
$gp_token = api_client.authorization.access_token
rescue Signet::AuthorizationError => e
puts e.message
ensure
return $gp_token
end
end
end
一切似乎都运行良好 - 身份验证,身份验证令牌的处理 - 直到我尝试实际添加一个项目,当我这样做时,我得到以下内容:
<errors xmlns='http://schemas.google.com/g/2005'>
<error>
<domain>GData</domain>
<code>ServiceForbiddenException</code>
<internalReason>Could not find authenticated customer</internalReason>
</error>
</errors>
有什么想法吗?
答案 0 :(得分:6)
经过多次痛苦和精神上的辛劳,我终于解决了我的问题!
由于我使用的是OAuth 2 Server to Server authentication,hjblok给出的建议不适用(谢谢你试一试!)。
我只是将与我的服务帐户密钥相关联的电子邮件地址从Google API控制台(例如XXXXXXXXXXXX@developer.gserviceaccount.com
)添加到我的Google Merchant帐户(商家管理页面上的Settings > Users
),然后工作
如果需要澄清,请随时发表评论!
答案 1 :(得分:0)
Google Content API文档说明您需要在Google Merchant Center的“设置”页面中进行设置:
https://developers.google.com/shopping-content/getting-started/usingapi-products
答案 2 :(得分:0)
编辑在深入了解Google的API文档后重写了答案
您是否已尝试使用Google的OAuth 2.0 playground?我能够成功访问https://content.googleapis.com/content/v1/#{MERCHANT_ID}/items/products/generic
。
GET
调用了https://content.googleapis.com/content/v1/1234567/items/products/generic
个请求。由于1234567
不是有效MERCHANT_ID
,因此会返回错误。但错误消息包含实际属于您帐户的MERCHANT_ID
。MERCHANT_ID
。这将返回一个HTTP/1.1 200 OK
,其中包含正文中的请求项。此外,我不确定,但Google API是否期望授权标头与access_token
($gp_token
)一起出现?在OAuth 2.0 playground内,此授权标头用于发送access_token
。
我还找到了结构化内容API演示页面(https://google-content-api-tools.appspot.com/demo/demo.html),该页面更适用于购物内容API。