blob: f51ecccdc9e46e5ecf41741a806ce69a5caf7093 [file] [log] [blame]
/*******************************************************************************
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.ofbiz.workeffort.workeffort;
import java.util.Map;
import org.apache.ofbiz.base.util.Debug;
import org.apache.ofbiz.base.util.UtilMisc;
import org.apache.ofbiz.entity.Delegator;
import org.apache.ofbiz.entity.GenericEntityException;
import org.apache.ofbiz.entity.GenericValue;
import org.apache.ofbiz.entity.util.EntityQuery;
import org.apache.ofbiz.service.GenericServiceException;
import org.apache.ofbiz.service.LocalDispatcher;
import org.apache.ofbiz.service.ModelService;
/**
* WorkEffortPartyAssignmentServices - Services to handle form input and other data changes.
*/
public class WorkEffortPartyAssignmentServices {
public static final String module = WorkEffortPartyAssignmentServices.class.getName();
public static void updateWorkflowEngine(GenericValue wepa, GenericValue userLogin, LocalDispatcher dispatcher) {
// if the WorkEffort is an ACTIVITY, check for accept or complete new status...
Delegator delegator = wepa.getDelegator();
GenericValue workEffort = null;
try {
workEffort = EntityQuery.use(delegator).from("WorkEffort").where("workEffortId", wepa.get("workEffortId")).queryOne();
} catch (GenericEntityException e) {
Debug.logWarning(e, module);
}
if (workEffort != null && "ACTIVITY".equals(workEffort.getString("workEffortTypeId"))) {
// TODO: restrict status transitions
String statusId = (String) wepa.get("statusId");
Map<String, Object> context = UtilMisc.toMap("workEffortId", wepa.get("workEffortId"), "partyId", wepa.get("partyId"),
"roleTypeId", wepa.get("roleTypeId"), "fromDate", wepa.get("fromDate"),
"userLogin", userLogin);
if ("CAL_ACCEPTED".equals(statusId)) {
// accept the activity assignment
try {
Map<String, Object> results = dispatcher.runSync("wfAcceptAssignment", context);
if (results != null && results.get(ModelService.ERROR_MESSAGE) != null)
Debug.logWarning((String) results.get(ModelService.ERROR_MESSAGE), module);
} catch (GenericServiceException e) {
Debug.logWarning(e, module);
}
} else if ("CAL_COMPLETED".equals(statusId)) {
// complete the activity assignment
try {
Map<String, Object> results = dispatcher.runSync("wfCompleteAssignment", context);
if (results != null && results.get(ModelService.ERROR_MESSAGE) != null)
Debug.logWarning((String) results.get(ModelService.ERROR_MESSAGE), module);
} catch (GenericServiceException e) {
Debug.logWarning(e, module);
}
} else if ("CAL_DECLINED".equals(statusId)) {
// decline the activity assignment
try {
Map<String, Object> results = dispatcher.runSync("wfDeclineAssignment", context);
if (results != null && results.get(ModelService.ERROR_MESSAGE) != null)
Debug.logWarning((String) results.get(ModelService.ERROR_MESSAGE), module);
} catch (GenericServiceException e) {
Debug.logWarning(e, module);
}
} else {// do nothing...
}
}
}
}