/* * Copyright 2013 Red Hat, Inc. and/or its affiliates. * * 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.kie.internal.runtime.manager.context; import org.kie.api.runtime.manager.Context; /** * Process instance id aware implementation of the <code>Context</code> interface. * It's main responsibility is to be the data holder between caller and runtime manager * to obtain proper instances of <code>RuntimeEngine</code>.<br> * Used by strategy: * <ul> * <li>PerProcessInstance</li> * </ul> * To obtain instances of this context use one of the following static methods: * <ul> * <li><code>get()</code> to get empty context when starting process instances</li> * <li><code>get(Long)</code> to get context for specific process instance</li> * </ul> */ public class ProcessInstanceIdContext implements Context<Long> { private Long processInstanceId; public ProcessInstanceIdContext(Long processInstanceId) { this.processInstanceId = processInstanceId; } @Override public Long getContextId() { return processInstanceId; } public void setContextId(long id) { this.processInstanceId = id; } /** * Returns new instance of <code>ProcessInstanceIdContext</code> without process instance id. * Used for starting new instances of the process. * @return */ public static ProcessInstanceIdContext get() { return new ProcessInstanceIdContext(null); } /** * Returns new instance of <code>ProcessInstanceIdContext</code> with id of already existing process instance * @param processInstanceId actual identifier of process instance * @return */ public static ProcessInstanceIdContext get(Long processInstanceId) { return new ProcessInstanceIdContext(processInstanceId); } }