19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2008 The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.webkit;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.Bitmap;
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.http.SslError;
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Message;
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.KeyEvent;
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class WebViewClient {
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Give the host application a chance to take over the control when a new
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * url is about to be loaded in the current WebView. If WebViewClient is not
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * provided, by default WebView will ask Activity Manager to choose the
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * proper handler for the url. If WebViewClient is provided, return true
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * means the host application handles the url, while return false means the
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * current WebView handles the url.
33a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param url The url to be loaded.
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return True if the host application wants to leave the current WebView
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         and handle the url itself, otherwise return false.
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean shouldOverrideUrlLoading(WebView view, String url) {
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return false;
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Notify the host application that a page has started loading. This method
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * is called once for each main frame load so a page with iframes or
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * framesets will call onPageStarted one time for the main frame. This also
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * means that onPageStarted will not be called when the contents of an
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * embedded frame changes, i.e. clicking a link whose target is an iframe.
49a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param url The url to be loaded.
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param favicon The favicon for this page if it already exists in the
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            database.
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onPageStarted(WebView view, String url, Bitmap favicon) {
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Notify the host application that a page has finished loading. This method
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * is called only for main frame. When onPageFinished() is called, the
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * rendering picture may not be updated yet. To get the notification for the
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * new Picture, use {@link WebView.PictureListener#onNewPicture}.
63a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param url The url of the page.
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onPageFinished(WebView view, String url) {
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Notify the host application that the WebView will load the resource
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * specified by the given url.
73a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param url The url of the resource the WebView will load.
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onLoadResource(WebView view, String url) {
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
81c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * Notify the host application of a resource request and allow the
82c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * application to return the data.  If the return value is null, the WebView
83c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * will continue to load the resource as usual.  Otherwise, the return
84c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * response and data will be used.  NOTE: This method is called by the
85c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * network thread so clients should exercise caution when accessing private
86c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * data.
87c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     *
88c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * @param view The {@link android.webkit.WebView} that is requesting the
89c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     *             resource.
90c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * @param url The raw url of the resource.
91c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     * @return A {@link android.webkit.WebResourceResponse} containing the
92c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     *         response information or null if the WebView should load the
93c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     *         resource itself.
94c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott     */
95c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott    public WebResourceResponse shouldInterceptRequest(WebView view,
96c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott            String url) {
97c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott        return null;
98c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott    }
99c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott
100c12544a201667383bc3dfb4bd3ad62d98cacd24fPatrick Scott    /**
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Notify the host application that there have been an excessive number of
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * HTTP redirects. As the host application if it would like to continue
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * trying to load the resource. The default behavior is to send the cancel
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * message.
105a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param cancelMsg The message to send if the host wants to cancel
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param continueMsg The message to send if the host wants to continue
1096a5b0ecae5dc89a951e1e204bc007f50f944c5d1Patrick Scott     * @deprecated This method is no longer called. When the WebView encounters
1106a5b0ecae5dc89a951e1e204bc007f50f944c5d1Patrick Scott     *             a redirect loop, it will cancel the load.
1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
112b5503c168a49f0f2b1372678f87d874e7d82aaadKristian Monsen    @Deprecated
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onTooManyRedirects(WebView view, Message cancelMsg,
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Message continueMsg) {
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        cancelMsg.sendToTarget();
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
11805c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    // These ints must match up to the hidden values in EventHandler.
11905c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Generic error */
12005c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_UNKNOWN = -1;
12105c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Server or proxy hostname lookup failed */
12205c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_HOST_LOOKUP = -2;
12305c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Unsupported authentication scheme (not basic or digest) */
12405c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_UNSUPPORTED_AUTH_SCHEME = -3;
12505c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** User authentication failed on server */
12605c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_AUTHENTICATION = -4;
12705c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** User authentication failed on proxy */
12805c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_PROXY_AUTHENTICATION = -5;
12905c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Failed to connect to the server */
13005c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_CONNECT = -6;
13105c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Failed to read or write to the server */
13205c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_IO = -7;
13305c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Connection timed out */
13405c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_TIMEOUT = -8;
13505c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Too many redirects */
13605c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_REDIRECT_LOOP = -9;
13705c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Unsupported URI scheme */
13805c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_UNSUPPORTED_SCHEME = -10;
13905c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Failed to perform SSL handshake */
14005c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_FAILED_SSL_HANDSHAKE = -11;
14105c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Malformed URL */
14205c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_BAD_URL = -12;
14305c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Generic file error */
14405c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_FILE = -13;
14505c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** File not found */
14605c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_FILE_NOT_FOUND = -14;
14705c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    /** Too many requests during this load */
14805c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott    public static final int ERROR_TOO_MANY_REQUESTS = -15;
14905c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott
1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
15105c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott     * Report an error to the host application. These errors are unrecoverable
15205c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott     * (i.e. the main resource is unavailable). The errorCode parameter
15305c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott     * corresponds to one of the ERROR_* constants.
1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
155447811c64f60d29a5c0bf2d7ba94b91c68fe2612Patrick Scott     * @param errorCode The error code corresponding to an ERROR_* value.
15605c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott     * @param description A String describing the error.
15705c9ed9ce1d920c322ee1431cfed64541f0acf3cPatrick Scott     * @param failingUrl The url that failed to load.
1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onReceivedError(WebView view, int errorCode,
1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            String description, String failingUrl) {
1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * As the host application if the browser should resend data as the
1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * requested page was a result of a POST. The default is to not resend the
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * data.
167a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param dontResend The message to send if the browser should not resend
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param resend The message to send if the browser should resend data
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onFormResubmission(WebView view, Message dontResend,
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            Message resend) {
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        dontResend.sendToTarget();
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Notify the host application to update its visited links database.
179a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param url The url being visited.
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param isReload True if this url is being reloaded.
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void doUpdateVisitedHistory(WebView view, String url,
1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            boolean isReload) {
1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
189fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * Notify the host application that an SSL error occurred while loading a
190fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * resource. The host application must call either handler.cancel() or
191fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * handler.proceed(). Note that the decision may be retained for use in
192fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * response to future SSL errors. The default behavior is to cancel the
193fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * load.
194a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param handler An SslErrorHandler object that will handle the user's
1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            response.
1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param error The SSL error object.
1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onReceivedSslError(WebView view, SslErrorHandler handler,
2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            SslError error) {
2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handler.cancel();
2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
206fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * Notify the host application that an SSL error occurred while loading a
207fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * resource, but the WebView but chose to proceed anyway based on a
208fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * decision retained from a previous response to onReceivedSslError().
209fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     * @hide
210fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block     */
211fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block    public void onProceededAfterSslError(WebView view, SslError error) {
212fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block    }
213fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block
214fe33a75cc8883dc5d50dd5a2fb0eac702f2a6992Steve Block    /**
215a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * Notify the host application to handle a SSL client certificate
216a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * request (display the request to the user and ask whether to
217a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * proceed with a client certificate or not). The host application
218a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * has to call either handler.cancel() or handler.proceed() as the
219a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * connection is suspended and waiting for the response. The
220a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * default behavior is to cancel, returning no client certificate.
221a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
222a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * @param view The WebView that is initiating the callback.
223a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * @param handler An ClientCertRequestHandler object that will
224a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *            handle the user's response.
225a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * @param host_and_port The host and port of the requesting server.
226a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
227a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     * @hide
228a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     */
229a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom    public void onReceivedClientCertRequest(WebView view,
230a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom            ClientCertRequestHandler handler, String host_and_port) {
231a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom        handler.cancel();
232a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom    }
233a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom
234a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom    /**
2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Notify the host application to handle an authentication request. The
2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * default behavior is to cancel the request.
237a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param handler The HttpAuthHandler that will handle the user's response.
2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param host The host requiring authentication.
2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param realm A description to help store user credentials for future
2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            visits.
2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onReceivedHttpAuthRequest(WebView view,
2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            HttpAuthHandler handler, String host, String realm) {
2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        handler.cancel();
2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Give the host application a chance to handle the key event synchronously.
2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * e.g. menu shortcut key events need to be filtered this way. If return
2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * true, WebView will not handle the key event. If return false, WebView
2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * will always handle the key event, so none of the super in the view chain
2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * will see the key event. The default behavior returns false.
255a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param event The key event.
2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return True if the host application wants to handle the key event
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         itself, otherwise return false
2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean shouldOverrideKeyEvent(WebView view, KeyEvent event) {
2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return false;
2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Notify the host application that a key was not handled by the WebView.
2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Except system keys, WebView always consumes the keys in the normal flow
2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * or if shouldOverrideKeyEvent returns true. This is called asynchronously
2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * from where the key is dispatched. It gives the host application an chance
2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * to handle the unhandled key events.
271a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view The WebView that is initiating the callback.
2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param event The key event.
2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onUnhandledKeyEvent(WebView view, KeyEvent event) {
2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Notify the host application that the scale applied to the WebView has
2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * changed.
281a14775949c97a616196f5293209b092ee3d4e9a9Brian Carlstrom     *
2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param view he WebView that is initiating the callback.
2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param oldScale The old scale factor
2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param newScale The new scale factor
2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void onScaleChanged(WebView view, float oldScale, float newScale) {
2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
28885a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott
28985a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott    /**
29085a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     * Notify the host application that a request to automatically log in the
29185a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     * user has been processed.
29285a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     * @param view The WebView requesting the login.
29385a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     * @param realm The account realm used to look up accounts.
29485a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     * @param account An optional account. If not null, the account should be
29585a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     *                checked against accounts on the device. If it is a valid
29685a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     *                account, it should be used to log in the user.
29785a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     * @param args Authenticator specific arguments used to log in the user.
29885a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott     */
29985a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott    public void onReceivedLoginRequest(WebView view, String realm,
30085a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott            String account, String args) {
30185a50ff48b2331913cc87f483eafba9f231c8c8cPatrick Scott    }
3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
303