/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
package org.mozilla.gecko.sync.net;
import java.io.IOException;
import java.security.GeneralSecurityException;
import ch.boye.httpclientandroidlib.HttpResponse;
import ch.boye.httpclientandroidlib.client.ClientProtocolException;
import ch.boye.httpclientandroidlib.client.methods.HttpRequestBase;
import ch.boye.httpclientandroidlib.impl.client.DefaultHttpClient;
/**
* ResourceDelegate implementers must ensure that HTTP responses
* are fully consumed to ensure that connections are returned to
* the pool:
*
* EntityUtils.consume(entity);
* @author rnewman
*
*/
public interface ResourceDelegate {
// Request augmentation.
AuthHeaderProvider getAuthHeaderProvider();
void addHeaders(HttpRequestBase request, DefaultHttpClient client);
// Response handling.
/**
* Override this to handle an HttpResponse.
*
* ResourceDelegate implementers must ensure that HTTP responses are
* fully consumed to ensure that connections are returned to the pool, for
* example by calling EntityUtils.consume(response.getEntity())
.
*/
void handleHttpResponse(HttpResponse response);
void handleHttpProtocolException(ClientProtocolException e);
void handleHttpIOException(IOException e);
// During preparation.
void handleTransportException(GeneralSecurityException e);
// Connection parameters.
int connectionTimeout();
int socketTimeout();
}