com.gargoylesoftware.htmlunit.util.FalsifyingWebConnection Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vaadin-client-compiler-deps Show documentation
Show all versions of vaadin-client-compiler-deps Show documentation
Vaadin is a web application framework for Rich Internet Applications (RIA).
Vaadin enables easy development and maintenance of fast and
secure rich web
applications with a stunning look and feel and a wide browser support.
It features a server-side architecture with the majority of the logic
running
on the server. Ajax technology is used at the browser-side to ensure a
rich
and interactive user experience.
/*
* Copyright (c) 2002-2011 Gargoyle Software Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.gargoylesoftware.htmlunit.util;
import java.io.IOException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;
import com.gargoylesoftware.htmlunit.WebClient;
import com.gargoylesoftware.htmlunit.WebConnection;
import com.gargoylesoftware.htmlunit.WebRequest;
import com.gargoylesoftware.htmlunit.WebResponse;
import com.gargoylesoftware.htmlunit.WebResponseData;
/**
* Extension of {@link WebConnectionWrapper} providing facility methods to deliver something other than
* what the wrapped connection would deliver.
*
* @version $Revision: 6204 $
* @author Marc Guillemot
*/
public abstract class FalsifyingWebConnection extends WebConnectionWrapper {
/**
* Constructs a WebConnection object wrapping provided WebConnection.
* @param webConnection the webConnection that does the real work
* @throws IllegalArgumentException if the connection is null
*/
public FalsifyingWebConnection(final WebConnection webConnection) throws IllegalArgumentException {
super(webConnection);
}
/**
* Constructs an instance and places itself as connection of the WebClient.
* @param webClient the WebClient which WebConnection should be wrapped
* @throws IllegalArgumentException if the WebClient is null
*/
public FalsifyingWebConnection(final WebClient webClient) throws IllegalArgumentException {
super(webClient);
}
/**
* Delivers the content for an alternate URL as if it comes from the requested URL.
* @param webRequest the original web request
* @param url the URL from which the content should be retrieved
* @return the response
* @throws IOException if a problem occurred
*/
protected WebResponse deliverFromAlternateUrl(final WebRequest webRequest, final URL url)
throws IOException {
final URL originalUrl = webRequest.getUrl();
webRequest.setUrl(url);
final WebResponse resp = super.getResponse(webRequest);
resp.getWebRequest().setUrl(originalUrl);
return resp;
}
/**
* Builds a WebResponse with new content, preserving all other information.
* @param wr the web response to adapt
* @param newContent the new content to place in the response
* @return a web response with the new content
* @throws IOException if an encoding problem occurred
*/
protected WebResponse replaceContent(final WebResponse wr, final String newContent) throws IOException {
final byte[] body = newContent.getBytes(wr.getContentCharset());
final WebResponseData wrd = new WebResponseData(body, wr.getStatusCode(), wr.getStatusMessage(),
wr.getResponseHeaders());
return new WebResponse(wrd, wr.getWebRequest().getUrl(), wr.getWebRequest().getHttpMethod(),
wr.getLoadTime());
}
/**
* Creates a faked WebResponse for the request with the provided content.
* @param wr the web request for which a response should be created
* @param content the content to place in the response
* @param contentType the content type of the response
* @return a web response with the provided content
* @throws IOException if an encoding problem occurred
*/
protected WebResponse createWebResponse(final WebRequest wr, final String content,
final String contentType) throws IOException {
return createWebResponse(wr, content, contentType, 200, "OK");
}
/**
* Creates a faked WebResponse for the request with the provided content.
* @param wr the web request for which a response should be created
* @param content the content to place in the response
* @param contentType the content type of the response
* @param responseCode the HTTP code for the response
* @param responseMessage the HTTP message for the response
* @return a web response with the provided content
* @throws IOException if an encoding problem occurred
*/
protected WebResponse createWebResponse(final WebRequest wr, final String content,
final String contentType, final int responseCode, final String responseMessage) throws IOException {
final List headers = new ArrayList();
final String encoding = "UTF-8";
headers.add(new NameValuePair("content-type", contentType + "; charset=" + encoding));
final byte[] body = content.getBytes(encoding);
final WebResponseData wrd = new WebResponseData(body, responseCode, responseMessage, headers);
return new WebResponse(wrd, wr.getUrl(), wr.getHttpMethod(), 0);
}
}