org.camunda.bpm.engine.repository.DeploymentBuilder Maven / Gradle / Ivy
/*
* Copyright Camunda Services GmbH and/or licensed to Camunda Services GmbH
* under one or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information regarding copyright
* ownership. Camunda licenses this file to you under the Apache License,
* Version 2.0; 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.engine.repository;
import java.io.InputStream;
import java.util.Collection;
import java.util.Date;
import java.util.List;
import java.util.zip.ZipInputStream;
import org.camunda.bpm.engine.AuthorizationException;
import org.camunda.bpm.engine.authorization.Permissions;
import org.camunda.bpm.engine.authorization.Resources;
import org.camunda.bpm.engine.exception.NotFoundException;
import org.camunda.bpm.engine.exception.NotValidException;
import org.camunda.bpm.model.bpmn.BpmnModelInstance;
import org.camunda.bpm.model.cmmn.CmmnModelInstance;
import org.camunda.bpm.model.dmn.DmnModelInstance;
/**
* Builder for creating new deployments.
*
* A builder instance can be obtained through {@link org.camunda.bpm.engine.RepositoryService#createDeployment()}.
*
* Multiple resources can be added to one deployment before calling the {@link #deploy()}
* operation.
*
* After deploying, no more changes can be made to the returned deployment
* and the builder instance can be disposed.
*
* In order the resources to be processed as definitions, their names must have one of allowed suffixes (file extensions in case of file reference).
*
*
* Resource name suffix Will be treated as
*
*
*
* .bpmn20.xml, .bpmn BPMN process definition
*
*
* .cmmn11.xml, .cmmn10.xml, .cmmn CMMN case definition
*
*
* .dmn11.xml, .dmn DMN decision table
*
*
*
*
* Additionally resources with resource name suffixes .png, .jpg, .gif and .svg can be treated as diagram images. The deployment resource is considered
* to represent the specific model diagram by file name, e.g. bpmnDiagram1.png will be considered to be a diagram image for bpmnDiagram1.bpmn20.xml.
*
* @author Tom Baeyens
* @author Joram Barrez
*/
public interface DeploymentBuilder {
DeploymentBuilder addInputStream(String resourceName, InputStream inputStream);
DeploymentBuilder addClasspathResource(String resource);
DeploymentBuilder addString(String resourceName, String text);
/**
* Adds a BPMN model to the deployment.
* @param resourceName resource name. See suffix requirements for resource names: {@see DeploymentBuilder}.
* @param modelInstance model instance
* @return
*/
DeploymentBuilder addModelInstance(String resourceName, BpmnModelInstance modelInstance);
/**
* Adds a DMN model to the deployment.
* @param resourceName resource name. See suffix requirements for resource names: {@see DeploymentBuilder}.
* @param modelInstance model instance
* @return
*/
DeploymentBuilder addModelInstance(String resourceName, DmnModelInstance modelInstance);
/**
* Adds a CMMN model to the deployment.
* @param resourceName resource name. See suffix requirements for resource names: {@see DeploymentBuilder}.
* @param modelInstance model instance
* @return
*/
DeploymentBuilder addModelInstance(String resourceName, CmmnModelInstance modelInstance);
DeploymentBuilder addZipInputStream(ZipInputStream zipInputStream);
/**
* All existing resources contained by the given deployment
* will be added to the new deployment to re-deploy them.
*
* @throws NotValidException if deployment id is null.
*/
DeploymentBuilder addDeploymentResources(String deploymentId);
/**
* A given resource specified by id and deployment id will be added
* to the new deployment to re-deploy the given resource.
*
* @throws NotValidException if either deployment id or resource id is null.
*/
DeploymentBuilder addDeploymentResourceById(String deploymentId, String resourceId);
/**
* All given resources specified by id and deployment id will be added
* to the new deployment to re-deploy the given resource.
*
* @throws NotValidException if either deployment id or the list of resource ids is null.
*/
DeploymentBuilder addDeploymentResourcesById(String deploymentId, List resourceIds);
/**
* A given resource specified by name and deployment id will be added
* to the new deployment to re-deploy the given resource.
*
* @throws NotValidException if either deployment id or resource name is null.
*/
DeploymentBuilder addDeploymentResourceByName(String deploymentId, String resourceName);
/**
* All given resources specified by name and deployment id will be added
* to the new deployment to re-deploy the given resource.
*
* @throws NotValidException if either deployment id or the list of resource names is null.
*/
DeploymentBuilder addDeploymentResourcesByName(String deploymentId, List resourceNames);
/**
* Gives the deployment the given name.
*
* @throws NotValidException
* if {@link #nameFromDeployment(String)} has been called before.
*/
DeploymentBuilder name(String name);
/**
* Sets the deployment id to retrieve the deployment name from it.
*
* @throws NotValidException
* if {@link #name(String)} has been called before.
*/
DeploymentBuilder nameFromDeployment(String deploymentId);
/**
* If set, this deployment will be compared to any previous deployment.
* This means that every (non-generated) resource will be compared with the
* provided resources of this deployment. If any resource of this deployment
* is different to the existing resources, all resources are re-deployed.
*
*
* Deprecated: use {@link #enableDuplicateFiltering(boolean)}
*/
@Deprecated
DeploymentBuilder enableDuplicateFiltering();
/**
* Check the resources for duplicates in the set of previous deployments with
* same deployment source. If no resources have changed in this deployment,
* its contained resources are not deployed at all. For further configuration,
* use the parameter deployChangedOnly
.
*
* @param deployChangedOnly determines whether only those resources should be
* deployed that have changed from the previous versions of the deployment.
* If false, all of the resources are re-deployed if any resource differs.
*/
DeploymentBuilder enableDuplicateFiltering(boolean deployChangedOnly);
/**
* Sets the date on which the process definitions contained in this deployment
* will be activated. This means that all process definitions will be deployed
* as usual, but they will be suspended from the start until the given activation date.
*/
DeploymentBuilder activateProcessDefinitionsOn(Date date);
/**
* Sets the source of a deployment.
*
*
* Furthermore if duplicate check of deployment resources is enabled (by calling
* {@link #enableDuplicateFiltering(boolean)}) then only previous deployments
* with the same given source are considered to perform the duplicate check.
*
*/
DeploymentBuilder source(String source);
/**
* Deploys all provided sources to the process engine and returns the created deployment.
*
*
* The returned {@link Deployment} instance has no information about the definitions, which are deployed
* with that deployment. To access this information you can use the {@link #deployWithResult()} method.
* This method will return an instance of {@link DeploymentWithDefinitions}, which contains the information
* about the successful deployed definitions.
*
*
* @throws NotFoundException thrown
*
* - if the deployment specified by {@link #nameFromDeployment(String)} does not exist or
* - if at least one of given deployments provided by {@link #addDeploymentResources(String)} does not exist.
*
*
* @throws NotValidException
* if there are duplicate resource names from different deployments to re-deploy.
*
* @throws AuthorizationException
* thrown if the current user does not possess the following permissions:
*
* - {@link Permissions#CREATE} on {@link Resources#DEPLOYMENT}
* - {@link Permissions#READ} on {@link Resources#DEPLOYMENT} (if resources from previous deployments are redeployed)
*
* @return the created deployment
*/
Deployment deploy();
/**
* Deploys all provided sources to the process engine and returns the created deployment with the deployed definitions.
*
* @throws NotFoundException thrown
*
* - if the deployment specified by {@link #nameFromDeployment(String)} does not exist or
* - if at least one of given deployments provided by {@link #addDeploymentResources(String)} does not exist.
*
*
* @throws NotValidException
* if there are duplicate resource names from different deployments to re-deploy.
*
* @throws AuthorizationException
* thrown if the current user does not possess the following permissions:
*
* - {@link Permissions#CREATE} on {@link Resources#DEPLOYMENT}
* - {@link Permissions#READ} on {@link Resources#DEPLOYMENT} (if resources from previous deployments are redeployed)
*
* @return the created deployment, contains the deployed definitions
*/
DeploymentWithDefinitions deployWithResult();
/**
* @return the names of the resources which were added to this builder.
*/
Collection getResourceNames();
/**
* Sets the tenant id of a deployment.
*/
DeploymentBuilder tenantId(String tenantId);
}