本文整理汇总了Java中org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue.getInitiatorWorkflowId方法的典型用法代码示例。如果您正苦于以下问题:Java DocumentRouteHeaderValue.getInitiatorWorkflowId方法的具体用法?Java DocumentRouteHeaderValue.getInitiatorWorkflowId怎么用?Java DocumentRouteHeaderValue.getInitiatorWorkflowId使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue
的用法示例。
在下文中一共展示了DocumentRouteHeaderValue.getInitiatorWorkflowId方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: canBlanketApprove
import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue; //导入方法依赖的package包/类
/**
* Implements {@link org.kuali.rice.kew.doctype.service.DocumentTypePermissionService#canBlanketApprove(String, org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue)}
*/
public boolean canBlanketApprove(String principalId, DocumentRouteHeaderValue document) {
validatePrincipalId(principalId);
validateDocument(document);
DocumentType documentType = document.getDocumentType();
String initiatorPrincipalId = document.getInitiatorWorkflowId();
String documentStatus = document.getDocRouteStatus();
validateDocumentType(documentType);
validateDocumentStatus(documentStatus);
validatePrincipalId(initiatorPrincipalId);
final Boolean result;
if (documentType.isBlanketApproveGroupDefined()) {
boolean initiatorAuthorized = true;
if (documentType.getInitiatorMustBlanketApprovePolicy().getPolicyValue()) {
initiatorAuthorized = executeInitiatorPolicyCheck(principalId, initiatorPrincipalId, documentStatus);
}
result = initiatorAuthorized && documentType.isBlanketApprover(principalId);
} else {
Map<String, String> permissionDetails = buildDocumentTypePermissionDetails(documentType, documentStatus, null, null);
result = getPermissionService().isAuthorizedByTemplate(principalId, KewApiConstants.KEW_NAMESPACE,
KewApiConstants.BLANKET_APPROVE_PERMISSION, permissionDetails, new HashMap<String, String>());
}
return result;
}
示例2: canRoute
import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue; //导入方法依赖的package包/类
/**
* Implements {@link org.kuali.rice.kew.doctype.service.DocumentTypePermissionService#canRoute(String, org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue)}
*/
public boolean canRoute(String principalId, DocumentRouteHeaderValue document) {
validatePrincipalId(principalId);
validateDocument(document);
String documentId = document.getDocumentId();
DocumentType documentType = document.getDocumentType();
String documentStatus = document.getDocRouteStatus();
String initiatorPrincipalId = document.getInitiatorWorkflowId();
validateDocumentType(documentType);
validateDocumentStatus(documentStatus);
validatePrincipalId(initiatorPrincipalId);
if (!documentType.isPolicyDefined(org.kuali.rice.kew.api.doctype.DocumentTypePolicy.INITIATOR_MUST_ROUTE)) {
Map<String, String> permissionDetails = buildDocumentTypePermissionDetails(documentType, documentStatus, null, null);
Map<String, String> roleQualifiers = buildDocumentRoleQualifiers(document, permissionDetails.get(KewApiConstants.ROUTE_NODE_NAME_DETAIL));
if (LOG.isDebugEnabled()) {
LOG.debug("Permission details values: " + permissionDetails);
LOG.debug("Role qualifiers values: " + roleQualifiers);
}
if (useKimPermission(KewApiConstants.KEW_NAMESPACE, KewApiConstants.ROUTE_PERMISSION, permissionDetails, true)) {
return getPermissionService().isAuthorizedByTemplate(principalId, KewApiConstants.KEW_NAMESPACE,
KewApiConstants.ROUTE_PERMISSION, permissionDetails, roleQualifiers);
}
}
if (documentType.getInitiatorMustRoutePolicy().getPolicyValue()) {
return executeInitiatorPolicyCheck(principalId, initiatorPrincipalId, documentStatus);
}
return true;
}
示例3: canSave
import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue; //导入方法依赖的package包/类
/**
* Implements {@link org.kuali.rice.kew.doctype.service.DocumentTypePermissionService#canSave(String, org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue)}
*/
public boolean canSave(String principalId, DocumentRouteHeaderValue document) {
validatePrincipalId(principalId);
validateDocument(document);
String documentId = document.getDocumentId();
DocumentType documentType = document.getDocumentType();
String documentStatus = document.getDocRouteStatus();
String initiatorPrincipalId = document.getInitiatorWorkflowId();
List<String> routeNodeNames = document.getCurrentNodeNames();
validateDocumentType(documentType);
validateRouteNodeNames(routeNodeNames);
validateDocumentStatus(documentStatus);
validatePrincipalId(initiatorPrincipalId);
if (!documentType.isPolicyDefined(org.kuali.rice.kew.api.doctype.DocumentTypePolicy.INITIATOR_MUST_SAVE)) {
List<Map<String, String>> permissionDetailList = buildDocumentTypePermissionDetailsForNodes(documentType, routeNodeNames, documentStatus, null);
boolean foundAtLeastOnePermission = false;
// loop over permission details, only one of them needs to be authorized
for (Map<String, String> permissionDetails : permissionDetailList) {
Map<String, String> roleQualifiers = buildDocumentRoleQualifiers(document, permissionDetails.get(KewApiConstants.ROUTE_NODE_NAME_DETAIL));
if (useKimPermission(KewApiConstants.KEW_NAMESPACE, KewApiConstants.SAVE_PERMISSION, permissionDetails, true)) {
foundAtLeastOnePermission = true;
if (getPermissionService().isAuthorizedByTemplate(principalId, KewApiConstants.KEW_NAMESPACE,
KewApiConstants.SAVE_PERMISSION, permissionDetails, roleQualifiers)) {
return true;
}
}
}
// if we found defined KIM permissions, but not of them have authorized this user, return false
if (foundAtLeastOnePermission) {
return false;
}
}
if (documentType.getInitiatorMustSavePolicy().getPolicyValue()) {
return executeInitiatorPolicyCheck(principalId, initiatorPrincipalId, documentStatus);
}
return true;
}
示例4: canAddRouteLogMessage
import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue; //导入方法依赖的package包/类
@Override
public boolean canAddRouteLogMessage(String principalId, DocumentRouteHeaderValue document) {
validatePrincipalId(principalId);
validateDocument(document);
String documentId = document.getDocumentId();
DocumentType documentType = document.getDocumentType();
String documentStatus = document.getDocRouteStatus();
String initiatorPrincipalId = document.getInitiatorWorkflowId();
validateDocumentType(documentType);
validateDocumentStatus(documentStatus);
validatePrincipalId(initiatorPrincipalId);
Map<String, String> permissionDetails = buildDocumentTypePermissionDetails(documentType, documentStatus, null, null);
Map<String, String> roleQualifiers = buildDocumentRoleQualifiers(document, permissionDetails.get(KewApiConstants.ROUTE_NODE_NAME_DETAIL));
if (LOG.isDebugEnabled()) {
LOG.debug("Permission details values: " + permissionDetails);
LOG.debug("Role qualifiers values: " + roleQualifiers);
}
if (useKimPermission(KewApiConstants.KEW_NAMESPACE, KewApiConstants.ADD_MESSAGE_TO_ROUTE_LOG, permissionDetails, false)) {
return getPermissionService().isAuthorizedByTemplate(principalId, KewApiConstants.KEW_NAMESPACE,
KewApiConstants.ADD_MESSAGE_TO_ROUTE_LOG, permissionDetails, roleQualifiers);
}
return false;
}
示例5: getDocumentInitiatorPrincipalId
import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue; //导入方法依赖的package包/类
@Override
public String getDocumentInitiatorPrincipalId(String documentId) {
if (StringUtils.isEmpty(documentId)) {
throw new RiceIllegalArgumentException("documentId was blank or null");
}
DocumentRouteHeaderValue header = KEWServiceLocator.getRouteHeaderService().getRouteHeader(documentId, false);
if ( header == null) {
return null;
}
return header.getInitiatorWorkflowId();
}
示例6: validateRouteHeader
import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue; //导入方法依赖的package包/类
public void validateRouteHeader(DocumentRouteHeaderValue routeHeader){
LOG.debug("Enter validateRouteHeader(..)");
List errors = new ArrayList();
if (routeHeader.getDocRouteStatus() == null || routeHeader.getDocRouteStatus().trim().equals("")) {
errors.add(new WorkflowServiceErrorImpl("RouteHeader route status null.", "routeheader.routestatus.empty"));
} else if (!KewApiConstants.DOCUMENT_STATUSES.containsKey(routeHeader.getDocRouteStatus())){
errors.add(new WorkflowServiceErrorImpl("RouteHeader route status invalid.", "routeheader.routestatus.invalid"));
}
if(routeHeader.getDocRouteLevel() == null || routeHeader.getDocRouteLevel().intValue() < 0){
errors.add(new WorkflowServiceErrorImpl("RouteHeader route level invalid.", "routeheader.routelevel.invalid"));
}
if(routeHeader.getDateLastModified() == null){
errors.add(new WorkflowServiceErrorImpl("RouteHeader status modification date empty.", "routeheader.statusmoddate.empty"));
}
if(routeHeader.getCreateDate() == null){
errors.add(new WorkflowServiceErrorImpl("RouteHeader status create date empty.", "routeheader.createdate.empty"));
}
if(routeHeader.getDocVersion() == null || routeHeader.getDocVersion().intValue() < 0){
errors.add(new WorkflowServiceErrorImpl("RouteHeader doc version invalid.", "routeheader.docversion.invalid"));
}
if (routeHeader.getInitiatorWorkflowId () == null || routeHeader.getInitiatorWorkflowId().trim().equals("")) {
errors.add(new WorkflowServiceErrorImpl("RouteHeader initiator null.", "routeheader.initiator.empty"));
}
else
{
Principal principal = KimApiServiceLocator.getIdentityService().getPrincipal(routeHeader.getInitiatorWorkflowId());
if(principal == null)
{
errors.add(new WorkflowServiceErrorImpl("RouteHeader initiator id invalid.", "routeheader.initiator.invalid"));
}
}
if(!StringUtils.isBlank(routeHeader.getDocumentTypeId())){
DocumentType docType = KEWServiceLocator.getDocumentTypeService().findById(routeHeader.getDocumentTypeId());
if(docType == null){
errors.add(new WorkflowServiceErrorImpl("RouteHeader document type id invalid.", "routeheader.doctypeid.invalid"));
}
}
LOG.debug("Exit validateRouteHeader(..) ");
if (!errors.isEmpty()) {
throw new WorkflowServiceErrorException("RouteHeader Validation Error", errors);
}
}
示例7: canCancel
import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue; //导入方法依赖的package包/类
/**
* Implements {@link org.kuali.rice.kew.doctype.service.DocumentTypePermissionService#canCancel(String, org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue)}
*/
public boolean canCancel(String principalId, DocumentRouteHeaderValue document) {
validatePrincipalId(principalId);
validateDocument(document);
String documentId = document.getDocumentId();
DocumentType documentType = document.getDocumentType();
String documentStatus = document.getDocRouteStatus();
String initiatorPrincipalId = document.getInitiatorWorkflowId();
List<String> routeNodeNames = document.getCurrentNodeNames();
validateDocumentType(documentType);
validateRouteNodeNames(routeNodeNames);
validateDocumentStatus(documentStatus);
validatePrincipalId(initiatorPrincipalId);
if (!documentType.isPolicyDefined(org.kuali.rice.kew.api.doctype.DocumentTypePolicy.INITIATOR_MUST_CANCEL)) {
List<Map<String, String>> permissionDetailList = buildDocumentTypePermissionDetailsForNodes(documentType, routeNodeNames, documentStatus, null);
boolean foundAtLeastOnePermission = false;
// loop over permission details, only one of them needs to be authorized
for (Map<String, String> permissionDetails : permissionDetailList) {
Map<String, String> roleQualifiers = buildDocumentRoleQualifiers(document, permissionDetails.get(KewApiConstants.ROUTE_NODE_NAME_DETAIL));
if (useKimPermission(KewApiConstants.KEW_NAMESPACE, KewApiConstants.CANCEL_PERMISSION, permissionDetails, true)) {
foundAtLeastOnePermission = true;
if (getPermissionService().isAuthorizedByTemplate(principalId, KewApiConstants.KEW_NAMESPACE,
KewApiConstants.CANCEL_PERMISSION, permissionDetails, roleQualifiers)) {
return true;
}
}
}
// if we found defined KIM permissions, but not of them have authorized this user, return false
if (foundAtLeastOnePermission) {
return false;
}
}
if (documentType.getInitiatorMustCancelPolicy().getPolicyValue()) {
return executeInitiatorPolicyCheck(principalId, initiatorPrincipalId, documentStatus);
} else {
return true;
}
}
示例8: canRecall
import org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue; //导入方法依赖的package包/类
/**
* Implements {@link org.kuali.rice.kew.doctype.service.DocumentTypePermissionService#canRecall(String, org.kuali.rice.kew.routeheader.DocumentRouteHeaderValue)}
*/
public boolean canRecall(String principalId, DocumentRouteHeaderValue document) {
validatePrincipalId(principalId);
validateDocument(document);
String documentId = document.getDocumentId();
DocumentType documentType = document.getDocumentType();
String documentStatus = document.getDocRouteStatus();
String appDocStatus = document.getAppDocStatus();
String initiatorPrincipalId = document.getInitiatorWorkflowId();
List<String> routeNodeNames = document.getCurrentNodeNames();
validateDocumentType(documentType);
validateRouteNodeNames(routeNodeNames);
validateDocumentStatus(documentStatus);
// no need to validate appdocstatus, this is a free-form application defined value
// add appDocStatus to the details
List<Map<String, String>> permissionDetailList = buildDocumentTypePermissionDetailsForNodes(documentType, routeNodeNames, documentStatus, null);
if (!StringUtils.isBlank(appDocStatus)) {
for (Map<String, String> details: permissionDetailList) {
details.put(KewApiConstants.APP_DOC_STATUS_DETAIL, appDocStatus);
}
}
boolean foundAtLeastOnePermission = false;
boolean authorizedByPermission = false;
boolean principalIsInitiator = StringUtils.equals(initiatorPrincipalId, principalId);
// loop over permission details, only one of them needs to be authorized
for (Map<String, String> permissionDetails : permissionDetailList) {
Map<String, String> roleQualifiers = buildDocumentRoleQualifiers(document, permissionDetails.get(KewApiConstants.ROUTE_NODE_NAME_DETAIL));
if (useKimPermission(KewApiConstants.KEW_NAMESPACE, KewApiConstants.RECALL_PERMISSION, permissionDetails, false)) {
if (getPermissionService().isPermissionDefinedByTemplate(KewApiConstants.KEW_NAMESPACE, KewApiConstants.RECALL_PERMISSION, permissionDetails)) {
foundAtLeastOnePermission = true;
if (getPermissionService().isAuthorizedByTemplate(principalId, KewApiConstants.KEW_NAMESPACE,
KewApiConstants.RECALL_PERMISSION, permissionDetails, roleQualifiers)) {
return true;
}
}
}
}
if (foundAtLeastOnePermission) {
return false;
}
// alternative could be to only authorize initiator if the permission is omitted
// (i.e. exclude initiator if the initiator does not have the recall permission)
return authorizedByPermission;
}