素敵なサムシングを独断と偏見で一方的に紹介するブログ(´・ω・`)

投稿日: 2019年9月17日
最終更新日:

【universal-analytics】ElectronにGoogleAnalyticsを導入して機能の利用・アクセス解析をする方法【Vue-cli】

YouTubeも見てね♪

Anker PowerCor

created by Rinker
Anker
¥3,990 (2025/01/05 12:09:11時点 Amazon調べ-詳細)

旅行には必須の大容量モバイルバッテリー!

【最新機種】GoPro hero11 Black

created by Rinker
¥61,300 (2025/01/05 20:59:47時点 楽天市場調べ-詳細)

最新機種でVlogの思い出を撮影しよう!

ペヤング ソースやきそば 120g×18個

created by Rinker
ペヤング
¥3,280 (2025/01/05 12:33:38時点 Amazon調べ-詳細)

とりあえず保存食として買っておけば間違いなし!

レッドブル エナジードリンク 250ml×24本

created by Rinker
Red Bull(レッドブル)
¥4,000 (2025/01/05 12:33:39時点 Amazon調べ-詳細)

翼を授けよう!

ドラゴンクエスト メタリックモンスターズギャラリー メタルキング

created by Rinker
スクウェア・エニックス(SQUARE ENIX)
¥3,940 (2025/01/05 12:41:47時点 Amazon調べ-詳細)

みんな大好き経験値の塊をデスクに常備しておこう!

Bauhutte ( バウヒュッテ ) 昇降式 L字デスク ブラック BHD-670H-BK

created by Rinker
Bauhutte(バウヒュッテ)
¥15,855 (2025/01/05 12:09:12時点 Amazon調べ-詳細)

メインデスクの横に置くのにぴったりなおしゃれな可動式ラック!

サンディスク microSD 128GB

スマホからSwitchまで使える大容量MicroSDカード!

ElectronアプリケーションにGoogleAnalyticsを導入したい

簡単に導入出来ると思ってた時期が僕にもありました。

Electronでアプリケーションを作る際に、公開することを見越してアクセス解析を仕込もうと思いました。

ElectronもWebの技術で作成されているので、簡単に入れれるだろうと思っていましたが、結構ハマったので備忘録として記事に残したいと思います。

試したこと

まずは、それっぽいnpmモジュールがあったのでいろいろ試しました。

electron-google-analytics vue-analytics など試しましたが、ローカルでは動いたのですがビルドしてアプリケーション化すると動かなくなったり、ページ遷移が別のユーザーとして集計されてしまったりと、思い通りの動きになりませんでした。(筆者の実装の問題かもしれませんが。orz)

ビルドするとドメインを持たない

Electornは開発時はローカルにサーバーを立てて動いているので、http通信によるドメイン(localhost)が自動振られますが、アプリケーション化するとhttp通信では無くなるので、ドメインが振られなったりブラウザキャッシュが使えなくなったり正常にGoogleAnalyticsへの送信が出来ない原因と思われる事象がネット上に転がっており先駆者の方達も結構苦労しているようでした。

開発者ツールのRequest URLRequest Headersを見ると違いがわかると思います。

ローカル起動の場合

アプリケーション起動の場合

universal-analyticsで全て解決

そんな中、universal-analyticsを使ってみたところ特に苦労せずにGoogleAnalyticsの導入を実現する事が出来ました。

universal-analytics
A node module for Google’s Universal Analytics tracking via the Measurement Protocol.

This module allows tracking data (or rather, users) from within a Node.js application. Tracking is initiated on the server side and, if required, does not require any more tracking in the browser.universal-analytics – npm

手順

universal-analyticsをインストール

まずはyarnコマンドでuniversal-analyticsを依存関係に追加しましょう。

遷移時のイベント送信の追加

次に、Vue-Routerで遷移が発生した際にGoogleAnalyticsイベントを送信する処理を追加します。

router.afterEachを使えば、定義している全てのrouteに対して遷移時に共通処理を差し込むことが可能になります。

今回はto変数に入っている遷移先のパスと名称を渡すようにしています。

ClientIDの付与

今回はGoogleAnalyticsへのClientIDを生成するためにnode-machine-idというモジュールを使ってマシンに対するUUIDを取得・発行しています。

Cross-platform unique machine (desktop) id discoverynode-machine-id – npm

また、その際にstrictCidFormat: trueとしてClientIDの値をUUID以外も許容するようにしています。

ここでポイントなのは、第二引数のホストをhttp://localhostにすることです。

他の指定でも良いのかもしれませんが、Electronアプリは前述の通りビルドしてしまうと、ホストを持たないのでとりあえずはこれで良い気がしています。

また、開発時の操作はGoogleAnalyticsに送信したくないので、process.env.NODE_ENVproductionの場合のみ送信するようにしました。

確認

では、実際にビルドしてアプリを立ち上げて機能遷移してみましょう。

起動時

遷移時

正常に、同一ユーザーとしてアクセス解析がされるようになりました♪

ClientID

CliendIDもしっかりと送られていますね♪

GoogleAnalytics

Electronログ

終わりに

以上のように、 universal-analyticsを使えば簡単にElectronアプリの機能単位の利用具合を集計・解析する事が可能になりました。

どのような機能がどれだけ使われているか?という数字も、いずれは武器になったり機能改善に繋がるので、皆さんも是非入れてみてはいかがでしょうか♪

CATEGORIES & TAGS

IT