[Cocoa] Get rid of WK_ macros for nullability
[WebKit-https.git] / Source / WebKit2 / UIProcess / API / Cocoa / WKNavigationDelegate.h
1 /*
2  * Copyright (C) 2014 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. AND ITS CONTRIBUTORS ``AS IS''
14  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23  * THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 #import <WebKit/WKFoundation.h>
27
28 #if WK_API_ENABLED
29
30 #import <Foundation/Foundation.h>
31
32 NS_ASSUME_NONNULL_BEGIN
33
34 @class WKNavigation;
35 @class WKNavigationAction;
36 @class WKNavigationResponse;
37 @class WKWebView;
38
39 /*! @enum WKNavigationActionPolicy
40  @abstract The policy to pass back to the decision handler from the
41  webView:decidePolicyForNavigationAction:decisionHandler: method.
42  @constant WKNavigationActionPolicyCancel   Cancel the navigation.
43  @constant WKNavigationActionPolicyAllow    Allow the navigation to continue.
44  */
45 typedef NS_ENUM(NSInteger, WKNavigationActionPolicy) {
46     WKNavigationActionPolicyCancel,
47     WKNavigationActionPolicyAllow,
48 } WK_ENUM_AVAILABLE(10_10, 8_0);
49
50 /*! @enum WKNavigationResponsePolicy
51  @abstract The policy to pass back to the decision handler from the webView:decidePolicyForNavigationResponse:decisionHandler: method.
52  @constant WKNavigationResponsePolicyCancel   Cancel the navigation.
53  @constant WKNavigationResponsePolicyAllow    Allow the navigation to continue.
54  */
55 typedef NS_ENUM(NSInteger, WKNavigationResponsePolicy) {
56     WKNavigationResponsePolicyCancel,
57     WKNavigationResponsePolicyAllow,
58 } WK_ENUM_AVAILABLE(10_10, 8_0);
59
60 /*! A class conforming to the WKNavigationDelegate protocol can provide
61  methods for tracking progress for main frame navigations and for deciding
62  policy for main frame and subframe navigations.
63  */
64 @protocol WKNavigationDelegate <NSObject>
65
66 @optional
67
68 /*! @abstract Decides whether to allow or cancel a navigation.
69  @param webView The web view invoking the delegate method.
70  @param navigationAction Descriptive information about the action
71  triggering the navigation request.
72  @param decisionHandler The decision handler to call to allow or cancel the
73  navigation. The argument is one of the constants of the enumerated type WKNavigationActionPolicy.
74  @discussion If you do not implement this method, the web view will load the request or, if appropriate, forward it to another application.
75  */
76 - (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler;
77
78 /*! @abstract Decides whether to allow or cancel a navigation after its
79  response is known.
80  @param webView The web view invoking the delegate method.
81  @param navigationResponse Descriptive information about the navigation
82  response.
83  @param decisionHandler The decision handler to call to allow or cancel the
84  navigation. The argument is one of the constants of the enumerated type WKNavigationResponsePolicy.
85  @discussion If you do not implement this method, the web view will allow the response, if the web view can show it.
86  */
87 - (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(WKNavigationResponse *)navigationResponse decisionHandler:(void (^)(WKNavigationResponsePolicy))decisionHandler;
88
89 /*! @abstract Invoked when a main frame navigation starts.
90  @param webView The web view invoking the delegate method.
91  @param navigation The navigation.
92  */
93 - (void)webView:(WKWebView *)webView didStartProvisionalNavigation:(null_unspecified WKNavigation *)navigation;
94
95 /*! @abstract Invoked when a server redirect is received for the main
96  frame.
97  @param webView The web view invoking the delegate method.
98  @param navigation The navigation.
99  */
100 - (void)webView:(WKWebView *)webView didReceiveServerRedirectForProvisionalNavigation:(null_unspecified WKNavigation *)navigation;
101
102 /*! @abstract Invoked when an error occurs while starting to load data for
103  the main frame.
104  @param webView The web view invoking the delegate method.
105  @param navigation The navigation.
106  @param error The error that occurred.
107  */
108 - (void)webView:(WKWebView *)webView didFailProvisionalNavigation:(null_unspecified WKNavigation *)navigation withError:(NSError *)error;
109
110 /*! @abstract Invoked when content starts arriving for the main frame.
111  @param webView The web view invoking the delegate method.
112  @param navigation The navigation.
113  */
114 - (void)webView:(WKWebView *)webView didCommitNavigation:(null_unspecified WKNavigation *)navigation;
115
116 /*! @abstract Invoked when a main frame navigation completes.
117  @param webView The web view invoking the delegate method.
118  @param navigation The navigation.
119  */
120 - (void)webView:(WKWebView *)webView didFinishNavigation:(null_unspecified WKNavigation *)navigation;
121
122 /*! @abstract Invoked when an error occurs during a committed main frame
123  navigation.
124  @param webView The web view invoking the delegate method.
125  @param navigation The navigation.
126  @param error The error that occurred.
127  */
128 - (void)webView:(WKWebView *)webView didFailNavigation:(null_unspecified WKNavigation *)navigation withError:(NSError *)error;
129
130 /*! @abstract Invoked when the web view needs to respond to an authentication challenge.
131  @param webView The web view that received the authentication challenge.
132  @param challenge The authentication challenge.
133  @param completionHandler The completion handler you must invoke to respond to the challenge. The
134  disposition argument is one of the constants of the enumerated type
135  NSURLSessionAuthChallengeDisposition. When disposition is NSURLSessionAuthChallengeUseCredential,
136  the credential argument is the credential to use, or nil to indicate continuing without a
137  credential.
138  @discussion If you do not implement this method, the web view will respond to the authentication challenge with the NSURLSessionAuthChallengeRejectProtectionSpace disposition.
139  */
140 - (void)webView:(WKWebView *)webView didReceiveAuthenticationChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition disposition, NSURLCredential *_Nullable credential))completionHandler;
141
142 /*! @abstract Invoked when the web view's web content process is terminated.
143  @param webView The web view whose underlying web content process was terminated.
144  */
145 - (void)webViewWebContentProcessDidTerminate:(WKWebView *)webView WK_AVAILABLE(10_11, 9_0);
146
147 @end
148
149 NS_ASSUME_NONNULL_END
150
151 #endif