1 /*
2  * Copyright (C) 2012 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package android.webkit;
18 
19 import android.annotation.NonNull;
20 import android.annotation.SystemApi;
21 import android.content.Context;
22 import android.content.Intent;
23 import android.net.Uri;
24 
25 import java.util.List;
26 
27 /**
28  * This is the main entry-point into the WebView back end implementations, which the WebView
29  * proxy class uses to instantiate all the other objects as needed. The backend must provide an
30  * implementation of this interface, and make it available to the WebView via mechanism TBD.
31  * @hide
32  */
33 @SystemApi
34 public interface WebViewFactoryProvider {
35     /**
36      * This Interface provides glue for implementing the backend of WebView static methods which
37      * cannot be implemented in-situ in the proxy class.
38      */
39     interface Statics {
40         /**
41          * Implements the API method:
42          * {@link android.webkit.WebView#findAddress(String)}
43          */
findAddress(String addr)44         String findAddress(String addr);
45 
46         /**
47          * Implements the API method:
48          * {@link android.webkit.WebSettings#getDefaultUserAgent(Context) }
49          */
getDefaultUserAgent(Context context)50         String getDefaultUserAgent(Context context);
51 
52         /**
53          * Used for tests only.
54          */
freeMemoryForTests()55          void freeMemoryForTests();
56 
57         /**
58          * Implements the API method:
59          * {@link android.webkit.WebView#setWebContentsDebuggingEnabled(boolean) }
60          */
setWebContentsDebuggingEnabled(boolean enable)61         void setWebContentsDebuggingEnabled(boolean enable);
62 
63         /**
64          * Implements the API method:
65          * {@link android.webkit.WebView#clearClientCertPreferences(Runnable) }
66          */
clearClientCertPreferences(Runnable onCleared)67         void clearClientCertPreferences(Runnable onCleared);
68 
69         /**
70          * Implements the API method:
71          * {@link android.webkit.WebView#setSlowWholeDocumentDrawEnabled(boolean) }
72          */
enableSlowWholeDocumentDraw()73         void enableSlowWholeDocumentDraw();
74 
75         /**
76          * Implement the API method
77          * {@link android.webkit.WebChromeClient.FileChooserParams#parseResult(int, Intent)}
78          */
parseFileChooserResult(int resultCode, Intent intent)79         Uri[] parseFileChooserResult(int resultCode, Intent intent);
80 
81         /**
82          * Implement the API method
83          * {@link android.webkit.WebView#startSafeBrowsing(Context , ValueCallback<Boolean>)}
84          */
initSafeBrowsing(Context context, ValueCallback<Boolean> callback)85         void initSafeBrowsing(Context context, ValueCallback<Boolean> callback);
86 
87         /**
88         * Implement the API method
89         * {@link android.webkit.WebView#setSafeBrowsingWhitelist(List<String>,
90         * ValueCallback<Boolean>)}
91         */
setSafeBrowsingWhitelist(List<String> hosts, ValueCallback<Boolean> callback)92         void setSafeBrowsingWhitelist(List<String> hosts, ValueCallback<Boolean> callback);
93 
94         /**
95          * Implement the API method
96          * {@link android.webkit.WebView#getSafeBrowsingPrivacyPolicyUrl()}
97          */
98         @NonNull
getSafeBrowsingPrivacyPolicyUrl()99         Uri getSafeBrowsingPrivacyPolicyUrl();
100     }
101 
getStatics()102     Statics getStatics();
103 
104     /**
105      * Construct a new WebViewProvider.
106      * @param webView the WebView instance bound to this implementation instance. Note it will not
107      * necessarily be fully constructed at the point of this call: defer real initialization to
108      * WebViewProvider.init().
109      * @param privateAccess provides access into WebView internal methods.
110      */
createWebView(WebView webView, WebView.PrivateAccess privateAccess)111     WebViewProvider createWebView(WebView webView, WebView.PrivateAccess privateAccess);
112 
113     /**
114      * Gets the singleton GeolocationPermissions instance for this WebView implementation. The
115      * implementation must return the same instance on subsequent calls.
116      * @return the single GeolocationPermissions instance.
117      */
getGeolocationPermissions()118     GeolocationPermissions getGeolocationPermissions();
119 
120     /**
121      * Gets the singleton CookieManager instance for this WebView implementation. The
122      * implementation must return the same instance on subsequent calls.
123      *
124      * @return the singleton CookieManager instance
125      */
getCookieManager()126     CookieManager getCookieManager();
127 
128     /**
129      * Gets the TokenBindingService instance for this WebView implementation. The
130      * implementation must return the same instance on subsequent calls.
131      *
132      * @deprecated this method only returns {@code null}
133      * @return the TokenBindingService instance (which is always {@code null})
134      */
getTokenBindingService()135     TokenBindingService getTokenBindingService();
136 
137     /**
138      * Gets the TracingController instance for this WebView implementation. The
139      * implementation must return the same instance on subsequent calls.
140      *
141      * @return the TracingController instance
142      */
getTracingController()143     TracingController getTracingController();
144 
145     /**
146      * Gets the ServiceWorkerController instance for this WebView implementation. The
147      * implementation must return the same instance on subsequent calls.
148      *
149      * @return the ServiceWorkerController instance
150      */
getServiceWorkerController()151     ServiceWorkerController getServiceWorkerController();
152 
153     /**
154      * Gets the singleton WebIconDatabase instance for this WebView implementation. The
155      * implementation must return the same instance on subsequent calls.
156      *
157      * @return the singleton WebIconDatabase instance
158      */
getWebIconDatabase()159     WebIconDatabase getWebIconDatabase();
160 
161     /**
162      * Gets the singleton WebStorage instance for this WebView implementation. The
163      * implementation must return the same instance on subsequent calls.
164      *
165      * @return the singleton WebStorage instance
166      */
getWebStorage()167     WebStorage getWebStorage();
168 
169     /**
170      * Gets the singleton WebViewDatabase instance for this WebView implementation. The
171      * implementation must return the same instance on subsequent calls.
172      *
173      * @return the singleton WebViewDatabase instance
174      */
getWebViewDatabase(Context context)175     WebViewDatabase getWebViewDatabase(Context context);
176 
177     /**
178      * Gets the singleton PacProcessor instance.
179      * @return the PacProcessor instance
180      */
181     @NonNull
getPacProcessor()182     default PacProcessor getPacProcessor() {
183         throw new UnsupportedOperationException("Not implemented");
184     }
185 
186     /**
187      * Gets the classloader used to load internal WebView implementation classes. This interface
188      * should only be used by the WebView Support Library.
189      */
getWebViewClassLoader()190     ClassLoader getWebViewClassLoader();
191 }
192