19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/* 29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2006 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 Project/** 189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * A test EventHandler: Logs everything received 199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.net.http; 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.net.http.Headers; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@hide} 279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class LoggingEventHandler implements EventHandler { 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void requestSent() { 319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler:requestSent()"); 329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void status(int major_version, 359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int minor_version, 369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int code, /* Status-Code value */ 379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String reason_phrase) { 389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (HttpLog.LOGV) { 399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler:status() major: " + major_version + 409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project " minor: " + minor_version + 419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project " code: " + code + 429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project " reason: " + reason_phrase); 439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void headers(Headers headers) { 479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (HttpLog.LOGV) { 489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler:headers()"); 499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v(headers.toString()); 509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void locationChanged(String newLocation, boolean permanent) { 549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (HttpLog.LOGV) { 559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler: locationChanged() " + newLocation + 569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project " permanent " + permanent); 579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void data(byte[] data, int len) { 619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (HttpLog.LOGV) { 629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler: data() " + len + " bytes"); 639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // HttpLog.v(new String(data, 0, len)); 659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void endData() { 679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (HttpLog.LOGV) { 689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler: endData() called"); 699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void certificate(SslCertificate certificate) { 739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (HttpLog.LOGV) { 749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler: certificate(): " + certificate); 759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void error(int id, String description) { 799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (HttpLog.LOGV) { 809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler: error() called Id:" + id + 819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project " description " + description); 829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 854c8db8a4feb2afbd9d5f94ff09c7167ca34076c4Grace Kloba public boolean handleSslErrorRequest(SslError error) { 869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (HttpLog.LOGV) { 879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project HttpLog.v("LoggingEventHandler: handleSslErrorRequest():" + error); 889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 894c8db8a4feb2afbd9d5f94ff09c7167ca34076c4Grace Kloba // return false so that the caller thread won't wait forever 904c8db8a4feb2afbd9d5f94ff09c7167ca34076c4Grace Kloba return false; 919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 93