Perl で Google Analytics のアクセス解析データを取得しようとしたとき、ウェブ上の記事をさらっとなぞるだけではうまくいかなかった。どの記事もやや古く、そのとおりになぞっても失敗した。また、Google API 側の UI 等が大きく変更されていて目的のデータへたどり着けなかったりもした。
なので、試行錯誤の結果うまくいった方法をメモ程度に残しておきます。
あらかじめ知っておくこと
Net::Google::Analytics を使って Google Analytics のデータを取得します。
この記事を書いてる 2017 年 7 月時点でのモジュールバージョンは 3.05 でした。現在のところこのモジュールは Google Analytics API v3 に対応してるそうなので、最新版である API v4 ではなくレガシーな API v3 を使ってデータを取得する格好になります。
必要なもの
Google Analytics の [表示と分析] 権限を持っている Google アカウントが必要です。
作業をはじめる前にログインしておきます。
API への OAuth2 認証準備をする
API でデータにアクセスするためには、まず認証をパスする必要があります。いろいろな認証方法が Google から提供されていますが、Net::Google::Analytics は OAuth2 での認証が必要なので、その準備を行います。
Google Analytics API v3 を有効化する
まず API ダッシュボードにアクセスします。
まだプロジェクトが作られていなければ、おそらく作成を要求されると思います。お好きな名前と ID で新規プロジェクトを作成してください。
そして、[+] APIを有効にする から「Analytics API」を探して有効にしてください。ここで、似たような名前の「Google Analytics Reporting API」がありますが、こちらは API v4 のようです。
OAuth2 認証情報を作成する
次に API 認証情報にアクセスします。
- まず、認証情報を作成 [▼] から OAuth クライアントID を選択します。
- 同意画面の設定を求められるので、お好きなサービス名を設定して保存してください。今回この入力内容に大きな意味はないです。
- アプリケーションの種類を尋ねられたら、ウェブアプリケーションを選びます。
- クライアント ID の名前を求められたら、お好きな名前を入力してください。
-
承認済みのリダイレクト URI には下記の URL を入力してください。
https://developers.google.com/oauthplayground
- 作成ボタンを押すとクライアント ID とクライアントシークレットが表示されます。後で必要になるので控えておいてください。
OAuth 2.0 Playground で認証をパスする
このリンクから Google の OAuth 2.0 Playground にアクセスします。
※必要な設定値が自動入力される URL です。気になる方はクエリを見たら何が設定されるのかだいたい分かると思います。
- 画面右の設定項目 OAuth Client ID と OAuth Client secret に、先ほど控えておいた クライアント ID とクライアントシークレット をそれぞれ入力して Close します。
- アクティブに切り替わった Authorize APIs ボタンをクリックします。
- 画面が切り替わり、API アクセスの許可を求められますので、一応メッセージを読んでから許可します。
- また画面が切り替わるので、アクティブになっている Exchange authorization code for tokens ボタンを押します。
- すると画面右側に HTTP レスポンスとして JSON が表示されますので、その中の refresh_token を控えます。
Net::Google::Analytics が要求する profile_id なるものを取得する
これは簡単です。
Google Analytics にログインし、データを取りたいビューのビュー設定を開き、ビュー IDを控えます。
※これが Net::Google::Analytics が要求する profile_id です。
Net::Google::Analytics でアクセス解析データを取得する
ここまでできれば、あとは大丈夫かと思います。
試しに CPAN に載っているコード を実行してみて、うまくいけば成功です。
あとは、CPAN の説明ページにデータ取得方法や該当する API リファレンスへのリンクが掲載されていますので、いろいろ試すとよいと思います。
なお、最初の方でも書きましたが、最新の API は v4 です。Net::Google::Analytics ではひとつ古い v3 を利用することになるので、リンク先のリファレンスの内容が若干違う場合があることは注意が必要です。