Rubber-stamped by Chris Dumez.
[WebKit-https.git] / Source / WebCore / platform / network / cocoa / NetworkLoadMetrics.mm
1 /*
2  * Copyright (C) 2015 Apple, Inc.  All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 #import "config.h"
27 #import "NetworkLoadMetrics.h"
28
29 #import <WebCore/NSURLConnectionSPI.h>
30
31 namespace WebCore {
32
33 static double timingValue(NSDictionary *timingData, NSString *key)
34 {
35     if (id object = [timingData objectForKey:key])
36         return [object doubleValue];
37     return 0.0;
38 }
39     
40 void copyTimingData(NSDictionary *timingData, NetworkLoadMetrics& timing)
41 {
42     if (!timingData)
43         return;
44     
45     // This is not the navigationStart time in monotonic time, but the other times are relative to this time
46     // and only the differences between times are stored.
47     double referenceStart = timingValue(timingData, @"_kCFNTimingDataFetchStart");
48     
49     double domainLookupStart = timingValue(timingData, @"_kCFNTimingDataDomainLookupStart");
50     double domainLookupEnd = timingValue(timingData, @"_kCFNTimingDataDomainLookupEnd");
51     double connectStart = timingValue(timingData, @"_kCFNTimingDataConnectStart");
52     double secureConnectionStart = timingValue(timingData, @"_kCFNTimingDataSecureConnectionStart");
53     double connectEnd = timingValue(timingData, @"_kCFNTimingDataConnectEnd");
54     double requestStart = timingValue(timingData, @"_kCFNTimingDataRequestStart");
55     double responseStart = timingValue(timingData, @"_kCFNTimingDataResponseStart");
56     
57     timing.domainLookupStart = Seconds(domainLookupStart <= 0 ? Seconds(-1) : Seconds::fromMilliseconds(domainLookupStart - referenceStart));
58     timing.domainLookupEnd = Seconds(domainLookupEnd <= 0 ? Seconds(-1) : Seconds::fromMilliseconds(domainLookupEnd - referenceStart));
59     timing.connectStart = Seconds(connectStart <= 0 ? Seconds(-1) : Seconds::fromMilliseconds(connectStart - referenceStart));
60     timing.secureConnectionStart = Seconds(secureConnectionStart <= 0 ? Seconds(-1) : Seconds::fromMilliseconds(secureConnectionStart - referenceStart));
61     timing.connectEnd = Seconds(connectEnd <= 0 ? Seconds(-1) : Seconds::fromMilliseconds(connectEnd - referenceStart));
62     timing.requestStart = Seconds(requestStart <= 0 ? Seconds(0) : Seconds::fromMilliseconds(requestStart - referenceStart));
63     timing.responseStart = Seconds(responseStart <= 0 ? Seconds(0) : Seconds::fromMilliseconds(responseStart - referenceStart));
64
65     // NOTE: responseEnd is not populated in this code path.
66 }
67
68 #if !HAVE(TIMINGDATAOPTIONS)
69 void setCollectsTimingData()
70 {
71     static dispatch_once_t onceToken;
72     dispatch_once(&onceToken, ^{
73         [NSURLConnection _setCollectsTimingData:YES];
74         [NSURLConnection _collectTimingDataWithOptions:TimingDataCollectionNStatsOff | TimingDataCollectionConnectionDataOff];
75     });
76 }
77 #endif
78     
79 }