343083 make socket params available
git-svn-id: svn+ssh://dev.eclipse.org/svnroot/rt/org.eclipse.jetty/jetty/trunk@3027 7e9141cc-0065-0410-87d8-b60c137991c4
This commit is contained in:
parent
ed46fbf209
commit
e38ed57324
|
@ -1,5 +1,5 @@
|
||||||
jetty-7.4.1-SNAPSHOT
|
jetty-7.4.1-SNAPSHOT
|
||||||
+ 343083 Set nested dispatch type.
|
+ 343083 Set nested dispatch type and connection
|
||||||
+ 343277 add support for a context white list
|
+ 343277 add support for a context white list
|
||||||
+ 343352 make sure that jetty.osgi.boot is activated when a WAB is registered
|
+ 343352 make sure that jetty.osgi.boot is activated when a WAB is registered
|
||||||
|
|
||||||
|
|
|
@ -33,45 +33,45 @@ import org.eclipse.jetty.util.log.Log;
|
||||||
|
|
||||||
public class NestedConnection extends HttpConnection
|
public class NestedConnection extends HttpConnection
|
||||||
{
|
{
|
||||||
protected NestedConnection(final NestedConnector connector, final NestedEndPoint endp, final HttpServletRequest request, HttpServletResponse response,String nestedIn)
|
protected NestedConnection(final NestedConnector connector, final NestedEndPoint endp, final HttpServletRequest outerRequest, HttpServletResponse outerResponse,String nestedIn)
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
super(connector,
|
super(connector,
|
||||||
endp,
|
endp,
|
||||||
connector.getServer(),
|
connector.getServer(),
|
||||||
new NestedParser(),
|
new NestedParser(),
|
||||||
new NestedGenerator(connector.getResponseBuffers(),endp,response,nestedIn),
|
new NestedGenerator(connector.getResponseBuffers(),endp,outerResponse,nestedIn),
|
||||||
new NestedRequest());
|
new NestedRequest());
|
||||||
|
|
||||||
((NestedRequest)_request).setConnection(this);
|
((NestedRequest)_request).setConnection(this);
|
||||||
|
|
||||||
// Set the request line
|
// Set the request line
|
||||||
_request.setDispatcherType(DispatcherType.REQUEST);
|
_request.setDispatcherType(DispatcherType.REQUEST);
|
||||||
_request.setScheme(request.getScheme());
|
_request.setScheme(outerRequest.getScheme());
|
||||||
_request.setMethod(request.getMethod());
|
_request.setMethod(outerRequest.getMethod());
|
||||||
String uri=request.getQueryString()==null?request.getRequestURI():(request.getRequestURI()+"?"+request.getQueryString());
|
String uri=outerRequest.getQueryString()==null?outerRequest.getRequestURI():(outerRequest.getRequestURI()+"?"+outerRequest.getQueryString());
|
||||||
_request.setUri(new HttpURI(uri));
|
_request.setUri(new HttpURI(uri));
|
||||||
_request.setPathInfo(request.getRequestURI());
|
_request.setPathInfo(outerRequest.getRequestURI());
|
||||||
_request.setQueryString(request.getQueryString());
|
_request.setQueryString(outerRequest.getQueryString());
|
||||||
_request.setProtocol(request.getProtocol());
|
_request.setProtocol(outerRequest.getProtocol());
|
||||||
|
|
||||||
_request.setAttribute("isSecure",new Boolean(request.isSecure()));
|
_request.setAttribute("isSecure",new Boolean(outerRequest.isSecure()));
|
||||||
|
|
||||||
// Set the headers
|
// Set the headers
|
||||||
HttpFields fields = getRequestFields();
|
HttpFields fields = getRequestFields();
|
||||||
for (Enumeration<String> e=request.getHeaderNames();e.hasMoreElements();)
|
for (Enumeration<String> e=outerRequest.getHeaderNames();e.hasMoreElements();)
|
||||||
{
|
{
|
||||||
String header=e.nextElement();
|
String header=e.nextElement();
|
||||||
String value=request.getHeader(header);
|
String value=outerRequest.getHeader(header);
|
||||||
fields.add(header,value);
|
fields.add(header,value);
|
||||||
}
|
}
|
||||||
|
|
||||||
_request.setCookies(request.getCookies());
|
_request.setCookies(outerRequest.getCookies());
|
||||||
|
|
||||||
for (Enumeration<String> e=request.getAttributeNames();e.hasMoreElements();)
|
for (Enumeration<String> e=outerRequest.getAttributeNames();e.hasMoreElements();)
|
||||||
{
|
{
|
||||||
String attr=e.nextElement();
|
String attr=e.nextElement();
|
||||||
_request.setAttribute(attr,request.getAttribute(attr));
|
_request.setAttribute(attr,outerRequest.getAttribute(attr));
|
||||||
}
|
}
|
||||||
|
|
||||||
// System.err.println(_request.getMethod()+" "+_request.getUri()+" "+_request.getProtocol());
|
// System.err.println(_request.getMethod()+" "+_request.getUri()+" "+_request.getProtocol());
|
||||||
|
|
|
@ -72,9 +72,9 @@ public class NestedConnector extends AbstractConnector
|
||||||
*/
|
*/
|
||||||
public void service(ServletRequest outerRequest, ServletResponse outerResponse) throws IOException, ServletException
|
public void service(ServletRequest outerRequest, ServletResponse outerResponse) throws IOException, ServletException
|
||||||
{
|
{
|
||||||
HttpServletRequest request = (HttpServletRequest)outerRequest;
|
HttpServletRequest outerServletRequest = (HttpServletRequest)outerRequest;
|
||||||
HttpServletResponse response = (HttpServletResponse)outerResponse;
|
HttpServletResponse outerServletResponse = (HttpServletResponse)outerResponse;
|
||||||
NestedConnection connection=new NestedConnection(this,new NestedEndPoint(request,response),request,response,_serverInfo);
|
NestedConnection connection=new NestedConnection(this,new NestedEndPoint(outerServletRequest,outerServletResponse),outerServletRequest,outerServletResponse,_serverInfo);
|
||||||
connection.service();
|
connection.service();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,15 +25,52 @@ import org.eclipse.jetty.io.bio.StreamEndPoint;
|
||||||
|
|
||||||
public class NestedEndPoint extends StreamEndPoint
|
public class NestedEndPoint extends StreamEndPoint
|
||||||
{
|
{
|
||||||
public NestedEndPoint(HttpServletRequest request, HttpServletResponse response)
|
private final HttpServletRequest _outerRequest;
|
||||||
|
|
||||||
|
public NestedEndPoint(HttpServletRequest outerRequest, HttpServletResponse outerResponse)
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
super(request.getInputStream(),response.getOutputStream());
|
super(outerRequest.getInputStream(),outerResponse.getOutputStream());
|
||||||
|
_outerRequest=outerRequest;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ServletInputStream getServletInputStream()
|
public ServletInputStream getServletInputStream()
|
||||||
{
|
{
|
||||||
return (ServletInputStream)getInputStream();
|
return (ServletInputStream)getInputStream();
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
|
public String getLocalAddr()
|
||||||
|
{
|
||||||
|
return _outerRequest.getLocalAddr();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getLocalHost()
|
||||||
|
{
|
||||||
|
return _outerRequest.getLocalName();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getLocalPort()
|
||||||
|
{
|
||||||
|
return _outerRequest.getLocalPort();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getRemoteAddr()
|
||||||
|
{
|
||||||
|
return _outerRequest.getRemoteAddr();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getRemoteHost()
|
||||||
|
{
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return _outerRequest.getRemoteHost();
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public int getRemotePort()
|
||||||
|
{
|
||||||
|
return _outerRequest.getRemotePort();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue