-
Notifications
You must be signed in to change notification settings - Fork 25
/
ttfb.sql
124 lines (116 loc) · 3.3 KB
/
ttfb.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
# Update this monthly.
DECLARE QUERY_DATE DATE DEFAULT '2024-11-01';
# Add/edit platforms in alphabetical order here.
DECLARE PLATFORMS ARRAY<STRUCT<regex STRING, name STRING>> DEFAULT [
('awex', '000webhost'),
('x-ah-environment', 'Acquia'),
('alproxy', 'AlwaysData'),
('automattic.com/work-with-us', 'Automattic'),
('wpvip.com/careers', 'Automattic'),
('wordpress.com', 'Automattic'),
('a9130478a60e5f9135f765b23f26593b', 'Automattic'),
('flywheel', 'Flywheel'),
('framer/', 'Framer'),
('fly-request-id', 'Fly.io'),
('x-github-request', 'GitHub Pages'),
('dps/', 'GoDaddy Website Builder'),
('hostinger', 'Hostinger'),
('zyro.com', 'Hostinger Website Builder'),
('hubspot', 'HubSpot'),
('x-kinsta-cache', 'Kinsta'),
('x-lw-cache', 'Liquid Web'),
('netlify', 'Netlify'),
('x-pantheon-styx-hostname', 'Pantheon'),
('seravo', 'Seravo'),
('x-shopify-stage', 'Shopify'),
('shopify', 'Shopify'),
('b7440e60b07ee7b8044761568fab26e8', 'SiteGround'),
('624d5be7be38418a3e2a818cc8b7029b', 'SiteGround'),
('6b7412fb82ca5edfd0917e3957f05d89', 'SiteGround'),
('squarespace', 'Squarespace'),
('x-vercel-id', 'Vercel'),
('web1', 'Web1'),
('weebly', 'Weebly'),
('x-wix-request-id', 'Wix'),
('wp-cloud', 'WP-Cloud'),
('wpe-backend', 'WP Engine'),
('wp engine atlas', 'WP Engine Atlas'),
('wp engine', 'WP Engine'),
('zoneos', 'Zone.eu')
];
WITH crux AS (
SELECT
IF(device = 'desktop', 'desktop', 'mobile') AS client,
CONCAT(origin, '/') AS url,
CASE
WHEN SAFE_DIVIDE(fast_ttfb, (fast_ttfb + avg_ttfb + slow_ttfb)) >= 0.75 THEN 'Good'
WHEN SAFE_DIVIDE(slow_ttfb, (fast_ttfb + avg_ttfb + slow_ttfb)) >= 0.25 THEN 'Poor'
WHEN fast_ttfb IS NOT NULL THEN 'Needs Improvement'
ELSE NULL
END AS ttfb
FROM
`chrome-ux-report.materialized.device_summary`
WHERE
date = QUERY_DATE AND
device IN ('desktop', 'phone') AND
fast_ttfb IS NOT NULL
),
requests AS (
SELECT
client,
root_page,
JSON_VALUE(summary, '$.respOtherHeaders') AS respOtherHeaders,
JSON_VALUE(summary, '$.resp_x_powered_by') AS resp_x_powered_by,
JSON_VALUE(summary, '$.resp_via') AS resp_via,
JSON_VALUE(summary, '$.resp_server') AS resp_server
FROM
`httparchive.all.requests`
WHERE
date = QUERY_DATE AND
is_main_document
),
platform_regex AS (
SELECT
STRING_AGG(
# Escape special chars
REGEXP_REPLACE(regex, r'([\.\*\+\?\|\(\)\[\]\{\}\^\$])', r'\\\1'),
r'|'
) AS pattern
FROM
UNNEST(PLATFORMS)
),
detected_platforms AS (
SELECT
client,
url,
name AS platform
FROM
UNNEST(PLATFORMS)
JOIN (
SELECT
client,
root_page AS url,
REGEXP_EXTRACT(LOWER(CONCAT(IFNULL(respOtherHeaders, ''), IFNULL(resp_x_powered_by, ''), IFNULL(resp_via, ''), IFNULL(resp_server, ''))), (SELECT pattern FROM platform_regex)) AS regex
FROM
requests)
USING
(regex)
)
SELECT DISTINCT
platform,
client,
COUNT(DISTINCT url) AS n,
COUNT(DISTINCT IF(ttfb = 'Good', url, NULL)) / COUNT(DISTINCT url) AS fast,
COUNT(DISTINCT IF(ttfb = 'Needs Improvement', url, NULL)) / COUNT(DISTINCT url) AS avg,
COUNT(DISTINCT IF(ttfb = 'Poor', url, NULL)) / COUNT(DISTINCT url) AS slow
FROM
detected_platforms
JOIN
crux
USING
(client, url)
GROUP BY
platform,
client
ORDER BY
fast DESC