xref: /aosp_15_r20/external/cronet/net/dns/httpssvc_metrics.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2020 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #ifndef NET_DNS_HTTPSSVC_METRICS_H_
6*6777b538SAndroid Build Coastguard Worker #define NET_DNS_HTTPSSVC_METRICS_H_
7*6777b538SAndroid Build Coastguard Worker 
8*6777b538SAndroid Build Coastguard Worker #include <optional>
9*6777b538SAndroid Build Coastguard Worker #include <string>
10*6777b538SAndroid Build Coastguard Worker #include <string_view>
11*6777b538SAndroid Build Coastguard Worker #include <vector>
12*6777b538SAndroid Build Coastguard Worker 
13*6777b538SAndroid Build Coastguard Worker #include "base/containers/flat_set.h"
14*6777b538SAndroid Build Coastguard Worker #include "base/time/time.h"
15*6777b538SAndroid Build Coastguard Worker #include "net/base/net_export.h"
16*6777b538SAndroid Build Coastguard Worker 
17*6777b538SAndroid Build Coastguard Worker namespace net {
18*6777b538SAndroid Build Coastguard Worker 
19*6777b538SAndroid Build Coastguard Worker // These values are persisted to logs. Entries should not be renumbered and
20*6777b538SAndroid Build Coastguard Worker // numeric values should never be reused. (See HttpssvcDnsRcode in
21*6777b538SAndroid Build Coastguard Worker // tools/metrics/histograms/enums.xml.)
22*6777b538SAndroid Build Coastguard Worker enum HttpssvcDnsRcode {
23*6777b538SAndroid Build Coastguard Worker   kTimedOut = 0,
24*6777b538SAndroid Build Coastguard Worker   kUnrecognizedRcode,
25*6777b538SAndroid Build Coastguard Worker   kMissingDnsResponse,
26*6777b538SAndroid Build Coastguard Worker   kNoError,
27*6777b538SAndroid Build Coastguard Worker   kFormErr,
28*6777b538SAndroid Build Coastguard Worker   kServFail,
29*6777b538SAndroid Build Coastguard Worker   kNxDomain,
30*6777b538SAndroid Build Coastguard Worker   kNotImp,
31*6777b538SAndroid Build Coastguard Worker   kRefused,
32*6777b538SAndroid Build Coastguard Worker   kMaxValue = kRefused,
33*6777b538SAndroid Build Coastguard Worker };
34*6777b538SAndroid Build Coastguard Worker 
35*6777b538SAndroid Build Coastguard Worker // Translate an RCODE value to the |HttpssvcDnsRcode| enum, which is used for
36*6777b538SAndroid Build Coastguard Worker // HTTPSSVC experimentation. The goal is to keep these values in a small,
37*6777b538SAndroid Build Coastguard Worker // contiguous range in order to satisfy the UMA enumeration function's
38*6777b538SAndroid Build Coastguard Worker // requirements. This function never returns |kTimedOut| |kUnrecognizedRcode|,
39*6777b538SAndroid Build Coastguard Worker // or |kMissingDnsResponse|.
40*6777b538SAndroid Build Coastguard Worker enum HttpssvcDnsRcode TranslateDnsRcodeForHttpssvcExperiment(uint8_t rcode);
41*6777b538SAndroid Build Coastguard Worker 
42*6777b538SAndroid Build Coastguard Worker // Tool for aggregating HTTPS RR metrics. Accumulates metrics via the Save*
43*6777b538SAndroid Build Coastguard Worker // methods. Records metrics to UMA on destruction.
44*6777b538SAndroid Build Coastguard Worker // TODO(crbug.com/1366422): Rework this class once we've finished with
45*6777b538SAndroid Build Coastguard Worker // HTTPS-related rollouts and have decided what metrics we want to keep
46*6777b538SAndroid Build Coastguard Worker // permanently.
47*6777b538SAndroid Build Coastguard Worker class NET_EXPORT_PRIVATE HttpssvcMetrics {
48*6777b538SAndroid Build Coastguard Worker  public:
49*6777b538SAndroid Build Coastguard Worker   explicit HttpssvcMetrics(bool secure);
50*6777b538SAndroid Build Coastguard Worker   ~HttpssvcMetrics();
51*6777b538SAndroid Build Coastguard Worker   HttpssvcMetrics(HttpssvcMetrics&) = delete;
52*6777b538SAndroid Build Coastguard Worker   HttpssvcMetrics(HttpssvcMetrics&&) = delete;
53*6777b538SAndroid Build Coastguard Worker 
54*6777b538SAndroid Build Coastguard Worker   // May be called many times.
55*6777b538SAndroid Build Coastguard Worker   void SaveForAddressQuery(base::TimeDelta resolve_time,
56*6777b538SAndroid Build Coastguard Worker                            enum HttpssvcDnsRcode rcode);
57*6777b538SAndroid Build Coastguard Worker 
58*6777b538SAndroid Build Coastguard Worker   // Save the fact that the non-integrity queries failed. Prevents metrics from
59*6777b538SAndroid Build Coastguard Worker   // being recorded.
60*6777b538SAndroid Build Coastguard Worker   void SaveAddressQueryFailure();
61*6777b538SAndroid Build Coastguard Worker 
62*6777b538SAndroid Build Coastguard Worker   // Must only be called once.
63*6777b538SAndroid Build Coastguard Worker   void SaveForHttps(enum HttpssvcDnsRcode rcode,
64*6777b538SAndroid Build Coastguard Worker                     const std::vector<bool>& condensed_records,
65*6777b538SAndroid Build Coastguard Worker                     base::TimeDelta https_resolve_time);
66*6777b538SAndroid Build Coastguard Worker 
67*6777b538SAndroid Build Coastguard Worker  private:
68*6777b538SAndroid Build Coastguard Worker   std::string BuildMetricName(std::string_view leaf_name) const;
69*6777b538SAndroid Build Coastguard Worker 
70*6777b538SAndroid Build Coastguard Worker   // Records all the aggregated metrics to UMA.
71*6777b538SAndroid Build Coastguard Worker   void RecordMetrics();
72*6777b538SAndroid Build Coastguard Worker 
73*6777b538SAndroid Build Coastguard Worker   const bool secure_;
74*6777b538SAndroid Build Coastguard Worker   // RecordIntegrityMetrics() will do nothing when |disqualified_| is true.
75*6777b538SAndroid Build Coastguard Worker   bool disqualified_ = false;
76*6777b538SAndroid Build Coastguard Worker   bool already_recorded_ = false;
77*6777b538SAndroid Build Coastguard Worker   std::optional<enum HttpssvcDnsRcode> rcode_https_;
78*6777b538SAndroid Build Coastguard Worker   size_t num_https_records_ = 0;
79*6777b538SAndroid Build Coastguard Worker   std::optional<bool> is_https_parsable_;
80*6777b538SAndroid Build Coastguard Worker   // We never make multiple HTTPS queries per DnsTask, so we only need
81*6777b538SAndroid Build Coastguard Worker   // one TimeDelta for the HTTPS query.
82*6777b538SAndroid Build Coastguard Worker   std::optional<base::TimeDelta> https_resolve_time_;
83*6777b538SAndroid Build Coastguard Worker   std::vector<base::TimeDelta> address_resolve_times_;
84*6777b538SAndroid Build Coastguard Worker };
85*6777b538SAndroid Build Coastguard Worker 
86*6777b538SAndroid Build Coastguard Worker }  // namespace net
87*6777b538SAndroid Build Coastguard Worker 
88*6777b538SAndroid Build Coastguard Worker #endif  // NET_DNS_HTTPSSVC_METRICS_H_
89