/* * @(#)AuthorizationHandler.java 0.3-3 06/05/2001 * * This file is part of the HTTPClient package * Copyright (C) 1996-2001 Ronald Tschalär * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307, USA * * For questions, suggestions, bug-reports, enhancement-requests etc. * I may be contacted at: * * ronald@innovation.ch * * The HTTPClient's home page is located at: * * http://www.innovation.ch/java/HTTPClient/ * */ package HTTPClient; import java.io.IOException; /** * This is the interface that an Authorization handler must implement. You * can implement your own auth handler to add support for auth schemes other * than the ones handled by the default handler, to use a different UI for * soliciting usernames and passwords, or for using an altogether different * way of getting the necessary auth info. * * @see AuthorizationInfo#setAuthHandler(HTTPClient.AuthorizationHandler) * @version 0.3-3 06/05/2001 * @author Ronald Tschalär */ public interface AuthorizationHandler { /** * This method is called whenever a 401 or 407 response is received and * no candidate info is found in the list of known auth info. Usually * this method will query the user for the necessary info. * *
If the returned info is not null it will be added to the list of * known info. If the info is valid for more than one (host, port, realm, * scheme) tuple then this method must add the corresponding auth infos * itself. * *
This method must check req.allow_ui and only attempt
* user interaction if it's true.
*
* @param challenge the parsed challenge from the server; the host,
* port, scheme, realm and params are set to the
* values given by the server in the challenge.
* @param req the request which provoked this response.
* @param resp the full response.
* @return the authorization info to use when retrying the request,
* or null if the request is not to be retried. The necessary
* info includes the host, port, scheme and realm as given in
* the challenge parameter, plus either the basic
* cookie or any necessary params.
* @exception AuthSchemeNotImplException if the authorization scheme
* in the challenge cannot be handled.
* @exception IOException if an exception occurs while processing the
* challenge
*/
AuthorizationInfo getAuthorization(AuthorizationInfo challenge,
RoRequest req, RoResponse resp)
throws AuthSchemeNotImplException, IOException;
/**
* This method is called whenever auth info is chosen from the list of
* known info in the AuthorizationInfo class to be sent with a request.
* This happens when either auth info is being preemptively sent or if
* a 401 response is retrieved and a matching info is found in the list
* of known info. The intent of this method is to allow the handler to
* fix up the info being sent based on the actual request (e.g. in digest
* authentication the digest-uri, nonce and response-digest usually need
* to be recalculated).
*
* @param info the authorization info retrieved from the list of
* known info.
* @param req the request this info is targeted for.
* @param challenge the authorization challenge received from the server
* if this is in response to a 401, or null if we are
* preemptively sending the info.
* @param resp the full 401 response received, or null if we are
* preemptively sending the info.
* @return the authorization info to be sent with the request, or null
* if none is to be sent.
* @exception AuthSchemeNotImplException if the authorization scheme
* in the info cannot be handled.
* @exception IOException if an exception occurs while fixing up the
* info
*/
AuthorizationInfo fixupAuthInfo(AuthorizationInfo info, RoRequest req,
AuthorizationInfo challenge, RoResponse resp)
throws AuthSchemeNotImplException, IOException;
/**
* Sometimes even non-401 responses will contain headers pertaining to
* authorization (such as the "Authentication-Info" header). Therefore
* this method is invoked for each response received, even if it is not
* a 401 or 407 response. In case of a 401 or 407 response the methods
* fixupAuthInfo()
and getAuthorization()
are
* invoked after this method.
*
* @param resp the full Response
* @param req the Request which provoked this response
* @param prev the previous auth info sent, or null if none was sent
* @param prxy the previous proxy auth info sent, or null if none was sent
* @exception IOException if an exception occurs during the reading of
* the headers.
*/
void handleAuthHeaders(Response resp, RoRequest req,
AuthorizationInfo prev, AuthorizationInfo prxy)
throws IOException;
/**
* This method is similar to handleAuthHeaders
except that
* it is called if any headers in the trailer were sent. This also
* implies that it is invoked after any fixupAuthInfo()
or
* getAuthorization()
invocation.
*
* @param resp the full Response
* @param req the Request which provoked this response
* @param prev the previous auth info sent, or null if none was sent
* @param prxy the previous proxy auth info sent, or null if none was sent
* @exception IOException if an exception occurs during the reading of
* the trailers.
* @see #handleAuthHeaders(HTTPClient.Response, HTTPClient.RoRequest, HTTPClient.AuthorizationInfo, HTTPClient.AuthorizationInfo)
*/
void handleAuthTrailers(Response resp, RoRequest req,
AuthorizationInfo prev, AuthorizationInfo prxy)
throws IOException;
}