Skip to content

Commit

Permalink
Added HTTP Request information to the sys dom
Browse files Browse the repository at this point in the history
Copied from Perforce
 Change: 110742
  • Loading branch information
Palmr committed May 11, 2016
1 parent abc5802 commit cd2515e
Showing 1 changed file with 24 additions and 0 deletions.
24 changes: 24 additions & 0 deletions src/main/java/net/foxopen/fox/dom/handler/SysDOMHandler.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import net.foxopen.fox.ContextLabel;
import net.foxopen.fox.XFUtil;
import net.foxopen.fox.auth.AuthUtil;
import net.foxopen.fox.database.UCon;
import net.foxopen.fox.database.UConStatementResult;
import net.foxopen.fox.database.parser.ParsedStatement;
Expand All @@ -20,6 +21,7 @@
import net.foxopen.fox.thread.stack.ModuleCallStack;
import net.foxopen.fox.thread.stack.ModuleStateChangeListener;

import javax.servlet.http.HttpServletRequest;
import java.net.InetAddress;
import java.net.UnknownHostException;

Expand Down Expand Up @@ -100,12 +102,34 @@ private void refreshEngineURL(RequestURIBuilder pRequestURIBuilder) {
mSysDOM.getCreate1ENoCardinalityEx("portal_urls/engine_url").setText(pRequestURIBuilder.convertToAbsoluteURL(lEngineURL));
}

/**
* Refreshes the DOM's client info element.
* @param pRequestContext For getting the client request object and finding client info.
*/
private void refreshRequestInfo(RequestContext pRequestContext) {
HttpServletRequest lHttpRequest = pRequestContext.getFoxRequest().getHttpRequest();

mSysDOM.getCreate1ENoCardinalityEx("request_info/http_method").setText(lHttpRequest.getMethod());
mSysDOM.getCreate1ENoCardinalityEx("request_info/request_uri").setText(lHttpRequest.getRequestURI());
mSysDOM.getCreate1ENoCardinalityEx("request_info/remote_address").setText(lHttpRequest.getRemoteAddr());
mSysDOM.getCreate1ENoCardinalityEx("request_info/forwarded_for").setText(lHttpRequest.getHeader(AuthUtil.X_FORWARDED_FOR_HEADER_NAME));
mSysDOM.getCreate1ENoCardinalityEx("request_info/user_agent").setText(lHttpRequest.getHeader("user-agent"));
mSysDOM.getCreate1ENoCardinalityEx("request_info/referer").setText(lHttpRequest.getHeader("referer"));

String lQS = XFUtil.nvl(lHttpRequest.getQueryString());
String lQueryString = lQS.substring(0, Math.min(lQS.length(), 4000));
mSysDOM.getCreate1ENoCardinalityEx("request_info/query_string").setText(lQueryString);
}

@Override
public void open(ActionRequestContext pRequestContext) {

//Engine access URL may change throughout a thread's life (i.e. if bootstrapped on a different app server) - refresh it every churn
refreshEngineURL(pRequestContext.createURIBuilder());

// Refresh information about the request every churn
refreshRequestInfo(pRequestContext);

//Refresh sysdate and sysdatetime components
try {
UCon lUCon = pRequestContext.getContextUCon().getUCon("Sys DOM");
Expand Down

0 comments on commit cd2515e

Please sign in to comment.