/*
* Copyright 2016 camunda services GmbH.
*
* 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.camunda.bpm.model.bpmn.builder;
import org.camunda.bpm.model.bpmn.BpmnModelInstance;
import org.camunda.bpm.model.bpmn.instance.Event;
import org.camunda.bpm.model.bpmn.instance.MessageEventDefinition;
/**
*
* @author Christopher Zell <christopher.zell@camunda.com>
*/
public abstract class AbstractMessageEventDefinitionBuilder<B extends AbstractMessageEventDefinitionBuilder<B>> extends AbstractRootElementBuilder<B, MessageEventDefinition>{
public AbstractMessageEventDefinitionBuilder(BpmnModelInstance modelInstance, MessageEventDefinition element, Class<?> selfType) {
super(modelInstance, element, selfType);
}
@Override
public B id(String identifier) {
return super.id(identifier);
}
/**
* Sets the message attribute.
*
* @param message the message for the message event definition
* @return the builder object
*/
public B message(String message) {
element.setMessage(findMessageForName(message));
return myself;
}
/**
* Sets the camunda topic attribute. This is only meaningful when
* the {@link #camundaType(String)} attribute has the value <code>external</code>.
*
* @param camundaTopic the topic to set
* @return the builder object
*/
public B camundaTopic(String camundaTopic) {
element.setCamundaTopic(camundaTopic);
return myself;
}
/**
* Sets the camunda type attribute.
*
* @param camundaType the type of the service task
* @return the builder object
*/
public B camundaType(String camundaType) {
element.setCamundaType(camundaType);
return myself;
}
/**
* Sets the camunda task priority attribute. This is only meaningful when
* the {@link #camundaType(String)} attribute has the value <code>external</code>.
*
*
* @param taskPriority the priority for the external task
* @return the builder object
*/
public B camundaTaskPriority(String taskPriority) {
element.setCamundaTaskPriority(taskPriority);
return myself;
}
/**
* Finishes the building of a message event definition.
*
* @param <T>
* @return the parent event builder
*/
@SuppressWarnings({ "rawtypes", "unchecked" })
public <T extends AbstractFlowNodeBuilder> T messageEventDefinitionDone() {
return (T) ((Event) element.getParentElement()).builder();
}
}