All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bonitasoft.engine.page.IsTaskAvailableForUserRule Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (C) 2019 Bonitasoft S.A.
 * Bonitasoft, 32 rue Gustave Eiffel - 38000 Grenoble
 * This library is free software; you can redistribute it and/or modify it under the terms
 * of the GNU Lesser General Public License as published by the Free Software Foundation
 * version 2.1 of the License.
 * This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU Lesser General Public License for more details.
 * You should have received a copy of the GNU Lesser General Public License along with this
 * program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
 * Floor, Boston, MA 02110-1301, USA.
 **/
package org.bonitasoft.engine.page;

import java.io.Serializable;
import java.util.Map;

import org.bonitasoft.engine.commons.exceptions.SBonitaException;
import org.bonitasoft.engine.commons.exceptions.SExecutionException;
import org.bonitasoft.engine.core.process.instance.api.ActivityInstanceService;
import org.bonitasoft.engine.core.process.instance.api.exceptions.SActivityInstanceNotFoundException;
import org.bonitasoft.engine.core.process.instance.api.exceptions.SActivityReadException;
import org.bonitasoft.engine.core.process.instance.model.SHumanTaskInstance;
import org.bonitasoft.engine.core.process.instance.model.archive.SAHumanTaskInstance;
import org.bonitasoft.engine.persistence.SBonitaReadException;
import org.bonitasoft.engine.session.SessionService;
import org.bonitasoft.engine.sessionaccessor.SessionAccessor;

/**
 * @author Emmanuel Duchastenier, Anthony Birembaut
 */
public class IsTaskAvailableForUserRule implements AuthorizationRule {

    ActivityInstanceService activityInstanceService;

    SessionService sessionService;

    SessionAccessor sessionAccessor;

    public IsTaskAvailableForUserRule(ActivityInstanceService activityInstanceService, SessionService sessionService,
            SessionAccessor sessionAccessor) {
        this.activityInstanceService = activityInstanceService;
        this.sessionService = sessionService;
        this.sessionAccessor = sessionAccessor;
    }

    @Override
    public boolean isAllowed(final String key, final Map context) throws SExecutionException {
        @SuppressWarnings("unchecked")
        final Map queryParameters = (Map) context
                .get(URLAdapterConstants.QUERY_PARAMETERS);
        String[] idParamValue = new String[0];
        if (queryParameters != null) {
            idParamValue = queryParameters.get(URLAdapterConstants.ID_QUERY_PARAM);
        }
        long taskInstanceId;
        if (idParamValue == null || idParamValue.length == 0) {
            throw new IllegalArgumentException("The parameter \"id\" is missing from the original URL");
        } else {
            taskInstanceId = Long.parseLong(idParamValue[0]);
            try {
                long userId = sessionService.getSession(sessionAccessor.getSessionId()).getUserId();
                return isTaskAvailableForOrExecutedByUser(taskInstanceId, userId);
            } catch (final SBonitaException e) {
                throw new SExecutionException(
                        "Unable to figure out if the task " + taskInstanceId + " is available for the user.", e);
            }
        }
    }

    protected boolean isTaskAvailableForOrExecutedByUser(long taskInstanceId, long userId)
            throws SActivityReadException, SBonitaReadException, SActivityInstanceNotFoundException {
        try {
            final SHumanTaskInstance humanTaskInstance = activityInstanceService.getHumanTaskInstance(taskInstanceId);
            long assigneeId = humanTaskInstance.getAssigneeId();
            if (assigneeId > 0) {
                return userId == assigneeId;
            } else {
                return activityInstanceService.isTaskPendingForUser(taskInstanceId, userId);
            }
        } catch (SActivityInstanceNotFoundException e) {
            final SAHumanTaskInstance archivedHumanTaskInstance = activityInstanceService
                    .getLastArchivedFlowNodeInstance(SAHumanTaskInstance.class, taskInstanceId);
            if (archivedHumanTaskInstance != null) {
                return userId == archivedHumanTaskInstance.getExecutedBy();
            } else {
                throw e;
            }
        }
    }

    @Override
    public String getId() {
        return AuthorizationRuleConstants.IS_TASK_AVAILABLE_FOR_USER;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy