Class AbstractConversationPermissionCommand
java.lang.Object
com.flowable.platform.service.permission.AbstractDmnBasedPermissionHelper<Conversation>
com.flowable.engage.engine.impl.permission.cmd.AbstractConversationPermissionCommand
- Direct Known Subclasses:
CheckArchiveConversationCommand
,CheckCreateConversationCommand
,CheckDropParticipantFromConversationCommand
,CheckEditMessageCommand
,CheckHasAccessToConversationCommand
,CheckJoinParticipantToExistingConversationCommand
,CheckPostDocumentCommand
,CheckPostImageCommand
,CheckPostMessageCommand
,CheckPostVideoCommand
,CheckPostVoiceCommand
,CheckReopenConversationCommand
,CheckUpdateConversationAvatarCommand
,CheckUpdateConversationDescriptionCommand
,CheckUpdateConversationNameCommand
public abstract class AbstractConversationPermissionCommand
extends AbstractDmnBasedPermissionHelper<Conversation>
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final EngageEngineConfiguration
protected Collection<String>
protected String
protected String
Fields inherited from class com.flowable.platform.service.permission.AbstractDmnBasedPermissionHelper
NONE_VALUE, OUTPUT_KEY_ERROR_MESSAGE, OUTPUT_KEY_ERROR_MESSAGE_CODE, OUTPUT_KEY_GROUP_NEEDED, OUTPUT_KEY_PERMISSION
-
Constructor Summary
ConstructorsConstructorDescriptionAbstractConversationPermissionCommand
(EngageEngineConfiguration engageEngineConfiguration, String userId, Collection<String> userGroupKeys, String userTenantId) -
Method Summary
Modifier and TypeMethodDescriptioncheckBasicConversationAccess
(CommandContext commandContext, String userId, Conversation conversation, ParticipantType participantType) Basic conversation access check if the participant type has already been resolved.createRuleInputForDefaultModel
(String userId, AuthorizedAction action, Conversation scopedObject, Map<String, Object> detailedRuleInput, CommandContext commandContext) IfAbstractDmnBasedPermissionHelper.getDecisionKeyDefaultPermissions()
returns a non-null value, this method must be implemented in order to create the rule input data for evaluating the default permission model.evaluateMainParticipantType
(ConversationEntity conversation) Evaluates the participant type of user within the specified conversation.evaluateMainParticipantType
(String userId, Collection<String> userGroupKeys, ConversationEntity conversation) Evaluates the participant type of the given user within the specified conversation.evaluatePermissionsAndProcessResult
(String tenantId, AuthorizedAction action, Conversation scopedObject, Map<String, Object> ruleInput, String decisionModelKey, String globalErrorMessageCode, CommandContext commandContext) protected String
If the permission helper is based on a default and detail DMN permission rule mechanism, this method must return the DMN key of the default permission rule model to execute.protected String
getTenantId
(Conversation conversation) Methods inherited from class com.flowable.platform.service.permission.AbstractDmnBasedPermissionHelper
evaluateDefaultPermissionOutput, evaluatePermissionRuleOutput, evaluatePermissionsAndProcessResult, executeAndLogPermissionModel, getEmptyListOnNullValue, getGroups, isGroupMember, isUserMemberOfGroup, isUserType, processErrorMessage, renderErrorMessage
-
Field Details
-
engageEngineConfiguration
-
userId
-
userGroupKeys
-
userTenantId
-
-
Constructor Details
-
AbstractConversationPermissionCommand
public AbstractConversationPermissionCommand(EngageEngineConfiguration engageEngineConfiguration, String userId, Collection<String> userGroupKeys, String userTenantId)
-
-
Method Details
-
checkBasicConversationAccess
protected Optional<String> checkBasicConversationAccess(CommandContext commandContext, String userId, Conversation conversation, ParticipantType participantType) Basic conversation access check if the participant type has already been resolved. It returns an optional error message, if the user represented through the participant type is not involved in the conversation.- Returns:
- an optional error message, if the user does not have access to the conversation
-
getTenantId
- Specified by:
getTenantId
in classAbstractDmnBasedPermissionHelper<Conversation>
-
evaluateMainParticipantType
Evaluates the participant type of user within the specified conversation. If the same user has different participant types (e.g. is both owner AND assignee), the main one is returned, which is according the following priorities: owner, assignee, assigned group, candidate user, candidate group- Parameters:
conversation
- the conversation for which the participant type is evaluated- Returns:
- the participant type (e.g. owner, assignee, etc)
-
evaluateMainParticipantType
public ParticipantType evaluateMainParticipantType(String userId, Collection<String> userGroupKeys, ConversationEntity conversation) Evaluates the participant type of the given user within the specified conversation. If the same user has different participant types (e.g. is both owner AND assignee), the main one is returned, which is according the following priorities: owner, assignee, assigned group, candidate user, candidate group- Parameters:
userId
- the id of the user to evaluate its participant typeuserGroupKeys
- the group keys for the user to evaluate its participant typeconversation
- the conversation for which the participant type is evaluated- Returns:
- the participant type (e.g. owner, assignee, etc)
-
evaluatePermissionsAndProcessResult
protected Optional<String> evaluatePermissionsAndProcessResult(String tenantId, AuthorizedAction action, Conversation scopedObject, Map<String, Object> ruleInput, String decisionModelKey, String globalErrorMessageCode, CommandContext commandContext) -
createRuleInputForDefaultModel
protected Map<String,Object> createRuleInputForDefaultModel(String userId, AuthorizedAction action, Conversation scopedObject, Map<String, Object> detailedRuleInput, CommandContext commandContext) Description copied from class:AbstractDmnBasedPermissionHelper
IfAbstractDmnBasedPermissionHelper.getDecisionKeyDefaultPermissions()
returns a non-null value, this method must be implemented in order to create the rule input data for evaluating the default permission model. The easiest way is by just returning the same rule input as being used for the detailed rule model, but in some cases, the rule input data is different for the default DMN model.- Specified by:
createRuleInputForDefaultModel
in classAbstractDmnBasedPermissionHelper<Conversation>
- Parameters:
userId
- the id of the user to test for action permissionsaction
- the action to test privilegesscopedObject
- the optional scoped object for which the action should be checkeddetailedRuleInput
- the rule input as provided and used for the detailed rule model executioncommandContext
- the command context used for execution or access to further services- Returns:
- the rule input data used for executing the default DMN permission model
-
getDecisionKeyDefaultPermissions
Description copied from class:AbstractDmnBasedPermissionHelper
If the permission helper is based on a default and detail DMN permission rule mechanism, this method must return the DMN key of the default permission rule model to execute.- Specified by:
getDecisionKeyDefaultPermissions
in classAbstractDmnBasedPermissionHelper<Conversation>
- Returns:
- the optional key of the default DMN permission model,
null
, if none needed
-