/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at * trunk/opends/resource/legal-notices/OpenDS.LICENSE * or https://OpenDS.dev.java.net/OpenDS.LICENSE. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at * trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable, * add the following below this CDDL HEADER, with the fields enclosed * by brackets "[]" replaced with your own identifying information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Copyright 2008 Sun Microsystems, Inc. */ package org.opends.server.workflowelement; import static org.opends.messages.ConfigMessages.*; import java.util.List; import org.opends.server.admin.std.server.WorkflowElementCfg; import org.opends.server.types.Operation; import org.opends.server.types.CanceledOperationException; /** * This class defines the super class for all the workflow elements. A workflow * element is a task in a workflow. A workflow element can wrap a physical * repository such as a local backend, a remote LDAP server or a local ldif * file. A workflow element can also be used to route operations. This is the * case for load balancing and distribution. And workflow element can be used * in a virtual environment to transform data (DN and attribute renaming, * attribute value renaming...). * * @param The type of configuration handled by this workflow elelemnt. */ public abstract class WorkflowElement { // Indicates whether the workflow element encapsulates a private local // backend. private boolean isPrivate = false; // The workflow element identifier. private String workflowElementID = null; // The parent of the workflow element (null if the workflow element is // the root of the processing tree). private WorkflowElement parent = null; /** * Creates a new instance of the workflow element. */ public WorkflowElement() { // There is nothing to do in the constructor. } /** * Initializes the instance of the workflow element. * * @param workflowElementID the workflow element identifier as defined * in the configuration. */ public void initialize(String workflowElementID) { this.workflowElementID = workflowElementID; } /** * Set the parent of the current workflow element. * * @param parent the parent of the workflow element */ protected void setParent(WorkflowElement parent) { this.parent = parent; } /** * Indicates whether the provided configuration is acceptable for * this workflow elelement. * * @param configuration The workflow element configuration for * which to make the determination. * @param unacceptableReasons A list that may be used to hold the * reasons that the provided * configuration is not acceptable. * * @return {@code true} if the provided configuration is acceptable * for this workflow element, or {@code false} if not. */ public boolean isConfigurationAcceptable( T configuration, List unacceptableReasons) { // This default implementation does not perform any special // validation. It should be overridden by workflow element // implementations that wish to perform more detailed validation. return true; } /** * Performs any finalization that might be required when this * workflow element is unloaded. No action is taken in the default * implementation. */ public void finalizeWorkflowElement() { // No action is required by default. } /** * Executes the workflow element for an operation. * * @param operation the operation to execute * * @throws CanceledOperationException if this operation should be * cancelled */ public abstract void execute(Operation operation) throws CanceledOperationException; /** * Indicates whether the workflow element encapsulates a private * local backend. * * @return true if the workflow element encapsulates a private * local backend, false otherwise */ public boolean isPrivate() { return isPrivate; } /** * Specifies whether the workflow element encapsulates a private local * backend. * * @param isPrivate Indicates whether the workflow element encapsulates a * private local backend. */ protected void setPrivate(boolean isPrivate) { this.isPrivate = isPrivate; } /** * Provides the workflow element identifier. * * @return the worflow element identifier */ public String getWorkflowElementID() { return workflowElementID; } }