📄 groupsearchusersaction.java
字号:
/*
* OPIAM Suite
*
* Distributable under LGPL license.
* See terms of license at gnu.org.
*/
package opiam.admin.applis.demo.actions;
import opiam.admin.applis.demo.beans.Person;
import opiam.admin.applis.demo.forms.GroupSearchForm;
import opiam.admin.faare.SearchResult;
import opiam.admin.faare.service.UserContext;
import opiam.admin.faare.service.services.SortService;
import opiam.admin.faare.service.services.StandardService;
import opiam.admin.faare.struts.actions.SecureAction;
import opiam.admin.faare.struts.service.StrutsService;
import opiam.admin.faare.struts.utils.SessionContext;
import org.apache.log4j.Logger;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.action.ActionMessage;
import org.apache.struts.action.ActionMessages;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.List;
/**
* This class allows to search the users to add to the group.
*/
public class GroupSearchUsersAction extends SecureAction
{
/** Instance of the log4j logger.
* Used to generate the execution traces. */
private static Logger _logger =
Logger.getLogger(ProfileAction.class.getName());
/**
* This method is called to execute the action.
*
* @param mapping Struts mapping data.
* @param actionForm FormBean associated with the action.
* @param request HTTP request.
* @param httpServletResponse HTTP response.
*
* @return An ActionForward.
*
* @throws IOException An I/O exception if failed or interrupted I/O operations occurs.
* @throws ServletException A ServletException if the servlet has a problem.
*/
public ActionForward secureExecute(ActionMapping mapping,
ActionForm actionForm,
HttpServletRequest request,
HttpServletResponse httpServletResponse
) throws IOException, ServletException
{
SessionContext sessionContext = null;
UserContext userContext = null;
ActionMessages msgErrors = new ActionMessages();
try
{
// Gets the session.
HttpSession session = request.getSession();
// Gets the session context.
sessionContext = SessionContext.getInstance(session);
// Gets the user context.
userContext = sessionContext.getUserContext();
String sessionResultName = "groupUsersSearchResult";
// Removes the "searchResult" attribute in the session.
session.removeAttribute(sessionResultName);
// Checks if at least one field is not empty.
// Returns to the search page if all the fields are empty.
GroupSearchForm gsf = (GroupSearchForm) actionForm;
if (((gsf.getGivenName() == null) ||
(gsf.getGivenName().trim().compareToIgnoreCase("") == 0)) &&
((gsf.getName() == null) ||
(gsf.getName().trim().compareToIgnoreCase("") == 0)) &&
((gsf.getDepartment() == null) ||
(gsf.getDepartment().trim().compareToIgnoreCase("") == 0)) &&
((gsf.getSite() == null) ||
(gsf.getSite().trim().compareToIgnoreCase("") == 0)))
{
return (mapping.findForward("success"));
}
// Creates the search parameters from the "personSearch" request
// defined in the requests_conf.xml.
List args =
StrutsService.getSearchArgument("personSearch", actionForm,
sessionContext.getUserContext()
);
// Calls the StandardService to search the entries.
SearchResult searchResult =
StandardService.search(args, sessionContext.getUserContext());
// writes the results number on the output defined in the
// logger_config.properties.
_logger.debug("***** result size = " +
searchResult.getLResults().size()
);
// If there is only one result, returns the visualization page.
if (searchResult.getLResults().size() > 1)
{
// Calls the SortService to sort the results list according to the
// "name" attribute.
SortService.sort(searchResult.getLResults(), Person.class, "name",
sessionContext.getUserContext()
);
// You can also use the search method of the StandardService class
// which allows to sort the search results according to an
// attributes array.
}
// Sets the result of the search on the session.
session.setAttribute(sessionResultName, searchResult);
// Returns the URI corresponding to the action success
// as defined in the action configuration in the struts-config.xml.
return (mapping.findForward("success"));
}
catch (Exception se)
{
_logger.error(se.getMessage());
msgErrors.add(ActionMessages.GLOBAL_MESSAGE,
new ActionMessage("error.service.unknown")
);
saveErrors(request, msgErrors);
return (mapping.findForward("service_error"));
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -