Grav Google Analytics Plugin
The Google Analytics Plugin for Grav CMS allows you to integrate and configure Google Analytics without the need to touch any code within your Grav site.
Features
- Choose the Google Analytics code position in the HTML document (head or body).
- Renaming of the Global (gtag) Object
- Debug Mode
- Custom Cookie Configuration. Name prefix, domain and expiration time are configurable.
- DNT header support
- Blocking IP Addresses
- Opt Out (disable tracking by the user)
- Multi-Language Support for the Grav Administration Panel
Installation
Installing the Google Analytics plugin can be done in one of two ways. The GPM (Grav Package Manager) installation method enables you to quickly and easily install the plugin with a simple terminal command, while the manual method enables you to do so via a zip file.
GPM Installation (Preferred)
The simplest way to install this plugin is via the Grav Package Manager (GPM) through your system's terminal (also called the command line). From the root of your Grav install type:
bin/gpm install ganalytics
This will install the Google Analytics plugin into your /user/plugins
directory within Grav. Its files can be found under /your/site/grav/user/plugins/ganalytics
.
Manual Installation
To install this plugin, just download the zip version of this repository and unzip it under /your/site/grav/user/plugins
. Then, rename the folder to ganalytics
. You can find these files on GitHub or via GetGrav.org.
You should now have all the plugin files under
/your/site/grav/user/plugins/ganalytics
NOTE: This plugin is a modular component for Grav which requires Grav to operate.
Configuration
Before configuring this plugin, you should copy the user/plugins/ganalytics/ganalytics.yaml
to user/config/plugins/ganalytics.yaml
and only edit that copy.
Here is the default configuration and an explanation of available options:
enabled: true
trackingId: ""
position: "head"
objectName: "gtag"
dnt: true
blockedIps: []
blockedIpRanges: ["private", "loopback", "link-local"]
blockingCookie: "blockGA"
cookieConfig: false
cookiePrefix: ""
cookieDomain: ""
cookieExpires: 63072000
optOutEnabled: false
optOutMessage: "Google tracking is now disabled."
debugMode: false
-
enabled
Toggles if the Google Analytics plugin is turned on or off. -
trackingId
The Google Analytics Tracking ID. This value is required. (You can also use environment variables by enteringenv:VAR_NAME
as value) -
position
Code Position in the HTML document (head
orbody
). Default ishead
. -
objectName
The name for the global (gtag) object. Default isgtag
. -
dnt
Enables Do Not Track header support. When enabled, Google Analytics code will not be embedded if a client sends DNT header. Most browsers do not send this header by default. Header support in the plugin isenabled
by default though. -
blockedIps
Here you can blacklist IP addresses. For those the Google Analytics script will not be embedded. -
blockedIpRanges
Here you can blacklist IPv4 and/or IPv6 address ranges in the form["192.177.204.1-192.177.204.254", "2001:db8::1-2001:db8::fe", ...]
. In addition to numerical ranges, the keywords "private", "loopback", "link-local" designate special IPv4 and IPv6 ranges (see RFCs 6890, 4193, 4291). For blacklisted ranges the Google Analytics script will not be embedded. By default, all three ranges are blocked. If you are using a reverse proxy that redirects traffic to the grav installation, you may need to remove "private". -
blockingCookie
The name of a blocking cookie. When such a cookie is set, the Google Analytics script will not be embedded. Default istblockGA
-
cookieConfig
: Toggles if the a custom cookie configuration should be used. -
cookiePrefix
The cookie name prefix. -
cookieDomain
The cookie domain. Optional, Google default is top level domain plus one subdomain (eTLD +1). For example Grav site under https://example.com would use example.com for the cookie domain, and https://subdomain.example.com would also use example.com for the cookie domain. -
cookieExpires
The cookie expiration time in seconds. Google default is 2 years (63072000
seconds) -
optOutEnabled
Toggles if opt out function is turned on or off. -
optOutMessage
Confirmation message shown to the user when opt out function is called -
debugMode
Toggles if Google Analytics debug mode is enabled or disabled.
Usage
- Sign in to your Google Analytics account.
- Select the Admin tab.
- Select an account from the dropdown in the ACCOUNT column.
- Select a property from the dropdown in the PROPERTY column.
- Under PROPERTY, click Data Streams > you_data_stream_name.
- Copy the MEASUREMENT ID (a string like G-XXXXXXXXXX)
- Add it to the configuration of this plugin.
To give your users the possibility to disable Google Analytics tracking you have to enable "opt out" in this plugin and put the following link somewhere in your pages, e.g. in your Privacy Declaration:
<a href="javascript:gaOptout()">Disable Google Analytics</a>
The link must be inserted as HTML tags and not in markdown syntax. When this link is clicked, then the official ga-disable-cookie is set and Google stopps tracking this visitor. For more Info about disabling the Google Analytics tracking see: https://developers.google.com/analytics/devguides/collection/gtagjs/user-opt-out
Upgrading from 1.x
First versions of the plugin were compatible only with Universal Analytics (analytics.js). Version 2.0 onwards only supports Google Analytics 4 (gtag.js). Universal Analytics is no longer supported. This means you have to migrate your Universal Analytics properties to Google Analytics 4 data streams before performing the upgrade.
- Sign in to your Google Analytics account and migrate a property used by this plugin to GA4 data stream. Keep in mind that GA4 uses totally different data model and gathering techniques. Google provides detailed guide on what to expect form GA4, how it compares to UA, and what exact steps you need to take to migrate your property.
- After migration is complete on Google side, upgrade Grav Google Analytics plugin.
- Set new tracking ID in the plugin's configuration. It needs to match MEASUREMENT ID of you GA4 data stream. Old UA tracking ID won't work anymore.
- If you were using opt-out configuration it will be automatically reset for all your users. They will need to make opt-out decision again based on your configured policy.
After upgrade you will probably notice that a lot of old plugin configuration options are gone. That's because Google has changed how these options work in GA4. In particular:
anonymizeIp
andforceSsl
options are removed because they are now enforced on Google side and cannot be disabled.async
option is removed because GA4 always uses async mode.cookieName
option was renamed tocookiePrefix
because you cannot change full cookie name anymore.objectName
default value was renamed fromga
togtag
to keep it inline with standard GA4 snippet. If you were using customobjectName
it won't be changed.debugTrace
option was removed anddebugStatus
was renamed todebugMode
. GA4 doesn't have debug tracing mode.
Note: due to a bug in Grav CMS framework all these changes are not migrated automatically. At the moment these configuration options need to be removed/renamed manually.