Mercurial > dive4elements > gnv-client
view gnv/src/main/java/de/intevation/gnv/action/SelectArtifactFactoryAction.java @ 682:d3062dc8626a
Application is now sensitive to changes of the preferred browser language in the current session (issue30).
gnv/trunk@853 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Mon, 29 Mar 2010 08:46:21 +0000 |
parents | 15ac78a91d1b |
children | d49e8695786c |
line wrap: on
line source
/** * */ package de.intevation.gnv.action; import java.util.Collection; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; 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.w3c.dom.Node; import de.intevation.gnv.action.sessionmodel.SessionModel; import de.intevation.gnv.action.sessionmodel.SessionModelFactory; import de.intevation.gnv.artifactdatabase.client.ArtifactDatabaseClient; import de.intevation.gnv.artifactdatabase.client.ArtifactDatabaseClientFactory; import de.intevation.gnv.artifactdatabase.objects.ArtifactDescription; import de.intevation.gnv.artifactdatabase.objects.ArtifactObject; import de.intevation.gnv.util.XMLUtils; import de.intevation.gnv.util.XSLTransformer; /** * @author Tim Englich <tim.englich@intevation.de> * */ public class SelectArtifactFactoryAction extends DescribeUIAction { /** * the logger, used to log exceptions and additonaly information */ private static Logger log = Logger .getLogger(SelectArtifactFactoryAction.class); /** * @see de.intevation.gnv.action.ArtifactDatabaseActionBase#execute(org.apache.struts.action.ActionMapping, * org.apache.struts.action.ActionForm, * javax.servlet.http.HttpServletRequest, * javax.servlet.http.HttpServletResponse) */ @Override public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception { log.debug("SelectArtifactFactoryAction.execute"); String selectedArtifactFactoryID = request .getParameter("artifactFactory"); log.debug("Selected ArtifactFactory ==> " + selectedArtifactFactoryID); try { SessionModel sm = SessionModelFactory.getInstance() .getSessionModel(request); Collection<ArtifactObject> artifactFactories = sm .getArtifactFactories(); // Removes the Artifactspecific Attributes from the SessionModel- sm.resetModel(); if (artifactFactories == null || artifactFactories.isEmpty()) { new FetchArtifactFactoriesAction().execute(mapping, form, request, response); } sm.selectArtifactFactory(selectedArtifactFactoryID); ArtifactObject af = sm.getSelectedArtifactFactory(); ; ArtifactDatabaseClient adc = ArtifactDatabaseClientFactory .getInstance() .getArtifactDatabaseClient(getLocale(request)); ArtifactObject artifact = adc.createNewArtifact(af); sm.setCurrentArtifact(artifact); return super.execute(mapping, form, request, response); } catch (Exception e) { log.error(e, e); request.setAttribute( CommunicationKeys.REQUEST_EXCEPTION_MESSAGE_ID, e .getMessage()); return super.getExceptionForward(mapping); } } /** * Constructor */ public SelectArtifactFactoryAction() { } }