/** * Copyright (c) 2009--2015 Red Hat, Inc. * * This software is licensed to you under the GNU General Public License, * version 2 (GPLv2). There is NO WARRANTY for this software, express or * implied, including the implied warranties of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. You should have received a copy of GPLv2 * along with this software; if not, see * http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt. * * Red Hat trademarks are not licensed under GPLv2. No permission is * granted to use or replicate Red Hat trademarks that are incorporated * in this software or its documentation. */ package com.redhat.rhn.frontend.action.kickstart; import com.redhat.rhn.common.db.datasource.DataResult; import com.redhat.rhn.domain.rhnset.RhnSetElement; import com.redhat.rhn.domain.user.User; import com.redhat.rhn.frontend.struts.RequestContext; import com.redhat.rhn.manager.kickstart.KickstartCryptoKeyCommand; import com.redhat.rhn.manager.kickstart.KickstartLister; import com.redhat.rhn.manager.rhnset.RhnSetDecl; import org.apache.struts.action.ActionForm; import java.util.Iterator; import java.util.List; import java.util.Map; import javax.servlet.http.HttpServletRequest; /** * KickstartKeysEditAction - Action to handle associating GPG/SSL keys with a Kickstart * @version $Rev: 1 $ */ public class KickstartCryptoKeysSubmitAction extends BaseKickstartListSubmitAction { public static final String UPDATE_METHOD = "kickstart.cryptokeys.jsp.submit"; /** * {@inheritDoc} */ protected void operateOnRemovedElements(List<RhnSetElement> elements, HttpServletRequest request) { RequestContext rctx = new RequestContext(request); KickstartCryptoKeyCommand cmd = new KickstartCryptoKeyCommand( rctx.getRequiredParam(RequestContext.KICKSTART_ID), rctx.getCurrentUser()); cmd.removeKeysById(getPrimaryElementIds(elements)); cmd.store(); } /** * {@inheritDoc} */ protected void operateOnAddedElements(List<RhnSetElement> elements, HttpServletRequest request) { RequestContext rctx = new RequestContext(request); KickstartCryptoKeyCommand cmd = new KickstartCryptoKeyCommand( rctx.getRequiredParam(RequestContext.KICKSTART_ID), rctx.getCurrentUser()); cmd.addKeysByIds(getPrimaryElementIds(elements)); cmd.store(); } /** * * {@inheritDoc} */ public RhnSetDecl getSetDecl() { return RhnSetDecl.GPGSSL_KEYS; } protected DataResult getDataResult(User user, ActionForm formIn, HttpServletRequest request) { RequestContext rctx = new RequestContext(request); return KickstartLister.getInstance(). cryptoKeysInOrg(rctx.getCurrentUser().getOrg()); } protected void processMethodKeys(Map<String, String> map) { map.put(UPDATE_METHOD, "operateOnDiff"); } protected Iterator getCurrentItemsIterator(RequestContext ctx) { KickstartCryptoKeyCommand cmd = new KickstartCryptoKeyCommand( ctx.getRequiredParam(RequestContext.KICKSTART_ID), ctx.getCurrentUser()); return cmd.getCryptoKeys().iterator(); } }