GOV.UK GA4 users monitoring
The GOV.UK GA4 users monitoring Looker Studio report provides information on users of GOV.UK GA4 data, including:
- the total number of users and service accounts with access to the GOV.UK GA4 data
- the number of users with unrecognised email addresses, or with disallowed email domains
- the number of users who have not accessed the data in the last six months
This report was first created in November 2024 to support the GOV.UK GA4 user administration carried out by the GOV.UK Insights and Analytics team.
Using the GOV.UK GA4 users monitoring report
Get access to the GOV.UK GA4 users monitoring report
The report can be viewed by anyone in the GDS performance analysts Google group.
Those in the GOV.UK Insights and Analytics team Google group are automatically granted ‘Edit’ permissions.
GOV.UK GA4 users monitoring data definitions
Field name | Definition | Notes |
---|---|---|
access_count | The number of times GA reporting data was accessed. Note that every report viewed can result in one or more data access events | From the GA4 access logs data |
access_mechanism | The mechanism through which a user accessed GA reporting data, for example ‘Google Analytics User Interface’ or ‘Google Analytics API’ | From the GA4 access logs data |
accessor_app_name | The name of the application that accessed Google Analytics reporting data, for example ‘Looker Studio’ or ‘Power BI’ | From the GA4 access logs data |
api_quota_category | The quota category for the Data API request, for example ‘Core’ or ‘Realtime’ | From the GA4 access logs data |
api_tokens_consumed | The number of property quota tokens consumed for Data API requests | From the GA4 access logs data |
domain | The email domain, taken from the user’s email address | Extracted from the GA4 user admin tool data |
epoch_time_micros | The unix microseconds since the epoch that the GA user accessed GA reporting data | From the GA4 access logs data |
last_accessed | The date value of the maximum (most recent) epoch_time_micros | A calculated field added to the data source |
report_type | The type of reporting data that the GA user accessed, for example ‘Realtime’ or ‘Free form exploration’ | From the GA4 access logs data |
spoc | The SPOC | From the GA4 user admin tool data |
status | The last status update in the GA4 user admin tool data, for example ‘created’ or ‘deleted’ | From the GA4 user admin tool data |
status_date | The date the user’s status was last updated by the GA4 user admin tool | From the GA4 user admin tool data |
user_email | The user’s email address | From the GA4 user admin tool data |
days_since_access | The date difference between today and the last_accessed date, subtracted from 0 to render it a positive integer | A calculated field added to the data source |
Record Count | A count of the records (rows) in the table | Default Looker Studio field |
How the GOV.UK GA4 users monitoring works
Data sources
The GOV.UK GA4 users monitoring report uses the ‘GOV.UK GA4 user monitoring’ data source. This is a custom query which pulls together data from a few different sources:
- the
all_users
table in the dataset created by the GA4 user admin tool - the
user_admin_log
table in the dataset created by the GA4 user admin tool - the GA4 access logs data
- the
spocs
table in the user admin tool dataset, pulling organisation and SPOC information from a Google Sheet
The all_users
table is filtered so that only users with GOV.UK GA4 data access are included in this dataset.
The GA4 access logs data is filtered to the Looker Studio date parameters.
This data source is very similar to the GOV.UK GA4 SPOC user report Looker Studio data source, but has been created as a separate Looker Studio data source as it does not use viewer email filtering.
The custom query is as follows:
WITH
ga4_users as (
SELECT
email AS user_email,
REGEXP_EXTRACT(email, r'@.+$') as domain
FROM `ga4-analytics-352613.user_admin.all_users`
WHERE binding LIKE 'properties/330577055%'
),
ga4_admin_log as(
SELECT
x.user_email,
x.status,
x.date
FROM (
SELECT
user_email,
status,
date,
row_number() over (partition by user_email order by date desc) as _rn
FROM `ga4-analytics-352613.user_admin.user_admin_log`
) x
WHERE x._rn = 1
),
ga4_logs as (
SELECT
epoch_time_micros,
user_email,
domain,
access_mechanism,
accessor_app_name,
api_quota_category,
report_type,
access_count,
api_tokens_consumed
FROM `ga4-analytics-352613.ga4_logs.ga4_logs`
WHERE TIMESTAMP_TRUNC(epoch_time_micros, DAY) BETWEEN PARSE_TIMESTAMP("%Y%m%d", @DS_START_DATE) AND PARSE_TIMESTAMP("%Y%m%d", @DS_END_DATE)
),
__spocs as (
SELECT
array(select trim(val) from unnest(split(trim(domain, '[]'))) val) AS email_domain,
array(select trim(val) from unnest(split(trim(spoc, '[]'))) val) AS spoc
FROM `ga4-analytics-352613.user_admin.spocs`
),
_spocs as (
SELECT
email_domain,
spoc
FROM __spocs, unnest(email_domain) email_domain
),
spocs as (
SELECT
email_domain,
spoc
FROM _spocs, unnest(spoc) spoc
GROUP BY 1, 2
)
SELECT
A.user_email,
A.domain,
B.status,
B.date as status_date,
C.* EXCEPT (user_email, domain),
S.spoc
FROM ga4_users A
LEFT JOIN ga4_admin_log B on A.user_email = B.user_email
LEFT JOIN ga4_logs C on A.user_email = C.user_email
LEFT JOIN spocs S on A.domain = S.email_domain