Chromium Code Reviews| Index: chrome/browser/page_load_metrics/observers/ads_detection.cc |
| diff --git a/chrome/browser/page_load_metrics/observers/ads_detection.cc b/chrome/browser/page_load_metrics/observers/ads_detection.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7d16d492e22e46fe27c224a5b37e1c9ff4520988 |
| --- /dev/null |
| +++ b/chrome/browser/page_load_metrics/observers/ads_detection.cc |
| @@ -0,0 +1,30 @@ |
| +// Copyright 2017 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/page_load_metrics/observers/ads_detection.h" |
| + |
| +#include "base/strings/string_util.h" |
| +#include "url/gurl.h" |
| + |
| +bool IsAdFrame(base::StringPiece frame_name, const GURL& frame_url) { |
| + // Google ads are prevalent and easy to track, so we'll start by tracking |
| + // those. Note that the frame name can be very large, so be careful to avoid |
| + // full string searches if possible. |
| + // TODO(jkarlin): Track other ad networks that are easy to identify. |
| + |
| + if (base::StartsWith(frame_name, "google_ads_iframe", |
|
Charlie Reis
2017/06/30 23:28:45
Sanity check: Any page can trigger TDI by naming i
Łukasz Anforowicz
2017/07/01 00:10:53
Correct. Thanks for raising this angle - I honest
|
| + base::CompareCase::SENSITIVE) || |
| + base::StartsWith(frame_name, "google_ads_frame", |
| + base::CompareCase::SENSITIVE)) { |
| + return true; |
| + } |
| + |
| + if (frame_url.host_piece() == "tpc.googlesyndication.com" && |
| + base::StartsWith(frame_url.path_piece(), "/safeframe", |
| + base::CompareCase::SENSITIVE)) { |
| + return true; |
| + } |
| + |
| + return false; |
| +} |