/* * Copyright (c) 2010-2011 Lockheed Martin Corporation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.eurekastreams.server.action.execution.profile; import java.io.Serializable; import java.util.ArrayList; import java.util.List; import org.apache.commons.logging.Log; import org.eurekastreams.commons.actions.InlineExecutionStrategyExecutor; import org.eurekastreams.commons.actions.TaskHandlerExecutionStrategy; import org.eurekastreams.commons.actions.context.PrincipalActionContext; import org.eurekastreams.commons.actions.context.TaskHandlerActionContext; import org.eurekastreams.commons.exceptions.ExecutionException; import org.eurekastreams.commons.logging.LogFactory; import org.eurekastreams.commons.server.UserActionRequest; import org.eurekastreams.server.action.request.notification.CreateNotificationsRequest; import org.eurekastreams.server.action.request.notification.CreateNotificationsRequest.RequestType; import org.eurekastreams.server.action.request.notification.GroupRemovedNotificationsRequest; import org.eurekastreams.server.action.request.notification.TargetEntityNotificationsRequest; import org.eurekastreams.server.action.request.profile.ReviewPendingGroupRequest; import org.eurekastreams.server.domain.DomainGroup; import org.eurekastreams.server.domain.Person; import org.eurekastreams.server.persistence.DomainGroupMapper; import org.eurekastreams.server.persistence.mappers.cache.AddPrivateGroupIdToCachedCoordinatorAccessList; /** * A coordinator decides the fate of a pending group. */ public class ReviewPendingGroupExecution implements TaskHandlerExecutionStrategy<PrincipalActionContext> { /** * Logger. */ private final Log log = LogFactory.make(); /** * The group mapper. */ private final DomainGroupMapper groupMapper; /** * Used to update Cache when private group is approved. */ private final AddPrivateGroupIdToCachedCoordinatorAccessList addPrivateGroupIdToCachedListMapper; /** Execution strategy for deleting a group. */ private final TaskHandlerExecutionStrategy deleteGroupExecution; /** * Constructor. * * @param inGroupMapper * the group mapper to use to find the domain group. * @param inAddPrivateGroupIdToCachedListMapper * mapper to update cache when a private group is approved * @param inDeleteGroupExecution * Execution strategy for deleting a group. */ public ReviewPendingGroupExecution(final DomainGroupMapper inGroupMapper, final AddPrivateGroupIdToCachedCoordinatorAccessList inAddPrivateGroupIdToCachedListMapper, final TaskHandlerExecutionStrategy inDeleteGroupExecution) { groupMapper = inGroupMapper; addPrivateGroupIdToCachedListMapper = inAddPrivateGroupIdToCachedListMapper; deleteGroupExecution = inDeleteGroupExecution; } /** * Execute the action, approving or declining the DomainGroup request. * * @param inActionContext * the action context containing the principal and request * @return true on success */ @Override public Serializable execute(final TaskHandlerActionContext<PrincipalActionContext> inActionContext) { try { ReviewPendingGroupRequest request = (ReviewPendingGroupRequest) inActionContext.getActionContext() .getParams(); DomainGroup group = groupMapper.findByShortName(request.getGroupShortName()); final long groupId = group.getId(); if (log.isInfoEnabled()) { log.info((request.getApproved() ? "Approving" : "Disapproving") + " pending group '" + request.getGroupShortName() + "' with id " + groupId); } notifyCoordinators(inActionContext, group, request); if (request.getApproved()) { group.setPending(false); groupMapper.flush(); if (!group.isPublicGroup()) { addPrivateGroupIdToCachedListMapper.execute(groupId); } } else { new InlineExecutionStrategyExecutor().execute(deleteGroupExecution, groupId, inActionContext); } } catch (Exception e) { throw new ExecutionException(e); } return true; } /** * Notify the group's coordinators of the decision. * * @param inActionContext * Context (needed for async actions). * @param group * The group. * @param request * The group approve/deny request. * @throws Exception * On notifier failure (shouldn't, since the notifier just queues an action). */ private void notifyCoordinators(final TaskHandlerActionContext<PrincipalActionContext> inActionContext, final DomainGroup group, final ReviewPendingGroupRequest request) throws Exception { CreateNotificationsRequest notifRequest; if (request.getApproved()) { notifRequest = new TargetEntityNotificationsRequest(RequestType.REQUEST_NEW_GROUP_APPROVED, 0L, group.getId()); } else { List<Long> recipients = new ArrayList<Long>(); for (Person coord : group.getCoordinators()) { recipients.add(coord.getId()); } notifRequest = new GroupRemovedNotificationsRequest(RequestType.REQUEST_NEW_GROUP_DENIED, 0L, group.getName(), recipients); } inActionContext.getUserActionRequests().add( new UserActionRequest(CreateNotificationsRequest.ACTION_NAME, null, notifRequest)); } }