google-api-ruby-clientからGoogle Adsense Management APIを操作する方法
何をしたいか?
google-api-ruby-client
を利用して、Google Adsenseの収益情報を取得したい
概要(何が書いてあるか)
- https://github.com/google/google-api-ruby-client のサンプルを参考に、プロジェクトの作成の仕方から、認証情報の作り方、Adsense用のコード
どこにハマったか?
google-api-ruby-client
のversion 0.9以降の方法がなかなか見つからず試行錯誤した- 特に、認証周りがよく分からず、苦労した
最終的には、googleのサンプルコードをベースに作成することでレポート取得ができることができた。
手順
googleのサンプルをベースにAdsense用のコードを作成する。(「Adsense用コード」参照) https://github.com/google/google-api-ruby-client
以下の手順で’google-api-samples’コマンドを実行する。
- プロジェクトの作成
- API Managerで利用したいAPI(ここではAdsense Management API)を有効化
- 利用するAPIに応じた認証を作成
- ‘.env’ファイルに「3.」で作成した認証情報を設定
- google-api-samples コマンドを実行し認証
以下、README.md より抜粋。
Depending on which particular samples you want to run, different steps may be required. Some samples, like Pub/Sub, require a service account, others like Drive, Calendar, and YouTube require an OAuth Client ID. And in some cases like Translate, only an API key is needed.
- Create a project at https://console.developers.google.com
- Go to the
API Manager
and enable the APIs you’d like to try - Go to
Credentials
and create the appropriate type of credential for the sample- For keys, use ‘Server key’ as the type
- For OAuth Client IDs, use ‘Other’ as the type
- For service accounts, use the ‘JSON’ key type
1. プロジェクトの作成
https://console.developers.google.com からプロジェクトを作成する。
data:image/s3,"s3://crabby-images/bb7bb/bb7bb15b59b5ca3a9d68a0f002dd3af41819926a" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/46b97/46b979cccdf2eab701983b2cc287a468be3fae48" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
2. API Managerで利用したいAPI(ここではAdsense Management API)を有効化
data:image/s3,"s3://crabby-images/59cc2/59cc2876e7531f77885ebc93dc902a4836355a39" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/262cb/262cb93a3520fa0ec5fda16bd560263d2899c1a8" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
3. 利用するAPIに応じた認証を作成
data:image/s3,"s3://crabby-images/c2bbe/c2bbe31eeaf2acc04de75b7ab44d6a411a1f7b0a" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/d235f/d235fd38806085fc0eb4f0688c1ed27a321dc8e0" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/c2b11/c2b11724d614fd84abecb0fb2e433ff28173f926" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/06401/064013a63309c8563642ad8d54915c10278018b2" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/f8c7f/f8c7fc2b744539580b7169c14a4413a04c227fd5" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/713d8/713d8561d440dac61f710a7353a3262a048865b6" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/e46f7/e46f79fb034c4afee5a6d69905586000770157f2" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
data:image/s3,"s3://crabby-images/c5c66/c5c66943ae1e6eacd681ff8c38c0fe263c328662" alt="google-api-ruby-clientからGoogle Adsense Management APIを操作する方法"
4. ‘.env’ファイルに「3.」で作成した認証情報を設定
‘dotenv’は、プロジェクト直下の.env
を環境変数としてロードする。
先ほど、作成した認証情報のClient ID
とClient sercret
を書く。
GOOGLE_CLIENT_ID=CLIENT_ID
GOOGLE_CLIENT_SECRET=CLIENT_SECRET
GOOGLE_APPLICATION_CREDENTIALS=hogehoge.json
GOOGLE_CREDENTIAL_STORE=credentials.yaml
5. 5. google-api-samples コマンドを実行し認証
google-api-samples コマンドを実行して出力されたURLにアクセスして、認証を行う。
Adsense用コード
Google Analyticsのサンプルコードを参考に、Adsense用のプログラムを作成した。
# This software includes the work that is distributed in the Apache License 2.0
require 'google/apis/adsense_v1_4'
require 'base_cli'
module Samples
class Adsense < BaseCli
Adsense = Google::Apis::AdsenseV1_4
desc 'show_report ACCOUNT_ID', 'Show report for the given adsense account ID'
method_option :start, type: :string, required: true
method_option :end, type: :string, required: true
def show_report(account_id)
adsense = Adsense::AdSenseService.new
adsense.authorization = user_credentials_for(Adsense::AUTH_ADSENSE)
result = adsense.generate_account_report(account_id,
options[:start],
options[:end],
:metric => 'EARNINGS')
puts result
end
end
end
参考
dotenv
環境変数を読み込ませる。
thor
コマンドラインインターフェース(CLI)のツールキット
- erikhuda/thor: Thor is a toolkit for building powerful command-line interfaces.
- Ruby の CLI ツールの作成を支援する、 thor gem の基本について。 #thor #ruby
Next Action
- OAuthの認証周りの考え方がいまいち完全に理解していないため、まとめる。
- ダッシュボード化を検討していて、以下のサンプルが面白そう ButecoOpenSource/dashboard: Status Dashboard
Related contents
data:image/s3,"s3://crabby-images/0493e/0493e3fc68441e80a4ab9fe9959eca187426bce7" alt="Eyecatch"
TECH
2016.02.10
data:image/s3,"s3://crabby-images/cba01/cba017b13677837384ebd86137774f9e3c797726" alt="Eyecatch"
TECH
2019.06.23
data:image/s3,"s3://crabby-images/24c53/24c5341581288dfd196107ee00cdeb4a9fffe106" alt="Eyecatch"
TECH
2017.09.08
data:image/s3,"s3://crabby-images/24c53/24c5341581288dfd196107ee00cdeb4a9fffe106" alt="Eyecatch"
TECH
2017.09.08
data:image/s3,"s3://crabby-images/0493e/0493e3fc68441e80a4ab9fe9959eca187426bce7" alt="Eyecatch"
TECH
2017.06.25
data:image/s3,"s3://crabby-images/0493e/0493e3fc68441e80a4ab9fe9959eca187426bce7" alt="Eyecatch"
TECH
2017.06.24
data:image/s3,"s3://crabby-images/8084c/8084c737f7cb034b42fc0032d63b2511ab26f922" alt="Eyecatch"
TECH
2017.02.19
data:image/s3,"s3://crabby-images/0493e/0493e3fc68441e80a4ab9fe9959eca187426bce7" alt="Eyecatch"
TECH
2015.03.27