* Make required processing of request.
*
* @return true if processing must continue, false otherwise.
*/
protected boolean processRequest() throws Exception {
CommandRequest request = RequestContext.getCurrentContext().getRequest();
String pAction = request.getRequestObject().getParameter(Parameters.DISPATCH_ACTION);
String idPanel = request.getRequestObject().getParameter(Parameters.DISPATCH_IDPANEL);
if (StringUtils.isEmpty(pAction) || StringUtils.isEmpty(idPanel)) {
log.debug("Running pure factory action.");
CommandResponse response = factoryRequestHandler.handleRequest(request);
if (getRequest().getServletPath().indexOf("/" + URLMarkupGenerator.COMMAND_RUNNER) != -1) {
getControllerStatus().consumeURIPart(getControllerStatus().getURIToBeConsumed());
}
if (response != null) {
getControllerStatus().setResponse(response);
}
return true;
}
// Get the specified panel from the current page.
Section currentPage = getNavigationManager().getCurrentSection();
Panel panel = currentPage.getPanel(idPanel);
if (panel == null) {
// If not found then try to get the panel from wherever the request comes from.
panel = UIServices.lookup().getPanelsManager().getPaneltById(new Long(idPanel));
if (panel == null) {
log.error("Cannot dispatch to panel " + idPanel + ". Panel not found.");
return true;
}
// Ensure the panel's section is set as current.
// This is needed to support requests coming from pages reached after clicking the browser's back button.
NavigationManager.lookup().setCurrentSection(panel.getSection());
}
CodeBlockTrace trace = new PanelActionTrace(panel, pAction).begin();
try {
WorkspacePermission workspacePerm = WorkspacePermission.newInstance(panel.getWorkspace(), WorkspacePermission.ACTION_LOGIN);
if (UserStatus.lookup().hasPermission(workspacePerm)) {
SectionPermission sectionPerm = SectionPermission.newInstance(panel.getSection(), SectionPermission.ACTION_VIEW);
if (UserStatus.lookup().hasPermission(sectionPerm)) {
PanelProvider provider = panel.getInstance().getProvider();
if (provider.isEnabled()) {
PanelDriver handler = provider.getDriver();
request.getRequestObject().setAttribute(Parameters.RENDER_PANEL, panel);
CommandResponse response = handler.execute(panel, request);
request.getRequestObject().removeAttribute(Parameters.RENDER_PANEL);
if (response != null)
getControllerStatus().setResponse(response);
if (getRequest().getServletPath().indexOf("/" + URLMarkupGenerator.COMMAND_RUNNER) != -1) {
getControllerStatus().consumeURIPart(getControllerStatus().getURIToBeConsumed());
}