mirror of https://github.com/OpenIdentityPlatform/OpenDJ.git

Nicolas Capponi
30.14.2016 40c232bb1ea09338ddbc93f2be3db6b340575fba
OPENDJ-3038 Remove CommonSchemaElements class and transform ServerSchemaElement to an utility class

- Replace by ServerSchemaElement class calls
- ServerSchemaElement is now an utility class
1 files deleted
15 files modified
510 ■■■■■ changed files
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/datamodel/ServerDescriptor.java 6 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/task/DeleteSchemaElementsTask.java 25 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/task/ModifyAttributeTask.java 4 ●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/task/NewSchemaElementsTask.java 82 ●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/AbstractVLVIndexPanel.java 6 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/BrowseSchemaPanel.java 21 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/CustomAttributePanel.java 7 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/CustomObjectClassPanel.java 5 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/NewIndexPanel.java 6 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/StandardAttributePanel.java 3 ●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/StandardObjectClassPanel.java 10 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/util/Utilities.java 74 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/server/backends/NullBackend.java 4 ●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/server/backends/SchemaBackend.java 2 ●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/server/schema/ServerSchemaElement.java 93 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/server/types/CommonSchemaElements.java 162 ●●●●● patch | view | raw | blame | history
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/datamodel/ServerDescriptor.java
@@ -32,14 +32,13 @@
import org.forgerock.opendj.ldap.schema.ObjectClass;
import org.opends.guitools.controlpanel.util.ConfigFromDirContext;
import org.opends.quicksetup.UserData;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.tools.tasks.TaskEntry;
import org.opends.server.types.Schema;
import com.forgerock.opendj.util.OperatingSystem;
import static org.opends.guitools.controlpanel.datamodel.BasicMonitoringAttributes.*;
import static org.opends.server.types.CommonSchemaElements.*;
import static org.opends.server.schema.ServerSchemaElement.*;
/**
 * This is just a class used to provide a data model describing what the
@@ -608,8 +607,7 @@
        && attr1.isOperational() == attr2.isOperational()
        && attr1.isSingleValue() == attr2.isSingleValue()
        && areEqual(attr1.getApproximateMatchingRule(), attr2.getApproximateMatchingRule())
        && areEqual(new ServerSchemaElement(attr1).getDefinitionWithFileName(),
            new ServerSchemaElement(attr2).getDefinitionWithFileName())
        && areEqual(getDefinitionWithFileName(attr1), getDefinitionWithFileName(attr2))
        && areEqual(attr1.getDescription(), attr2.getDescription())
        && areEqual(attr1.getEqualityMatchingRule(), attr2.getEqualityMatchingRule())
        && areEqual(attr1.getOrderingMatchingRule(), attr2.getOrderingMatchingRule())
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/task/DeleteSchemaElementsTask.java
@@ -222,15 +222,13 @@
    int numberDeleted = 0;
    for (ObjectClass objectClass : ocsToDelete)
    {
      final ServerSchemaElement element = new ServerSchemaElement(objectClass);
      deleteSchemaElement(element, numberDeleted, totalNumber, INFO_CTRL_PANEL_DELETING_OBJECTCLASS);
      deleteSchemaElement(objectClass, numberDeleted, totalNumber, INFO_CTRL_PANEL_DELETING_OBJECTCLASS);
      numberDeleted++;
    }
    for (AttributeType attribute : attrsToDelete)
    {
      final ServerSchemaElement element = new ServerSchemaElement(attribute);
      deleteSchemaElement(element, numberDeleted, totalNumber, INFO_CTRL_PANEL_DELETING_ATTRIBUTE);
      deleteSchemaElement(attribute, numberDeleted, totalNumber, INFO_CTRL_PANEL_DELETING_ATTRIBUTE);
      numberDeleted++;
    }
@@ -256,7 +254,7 @@
    }
  }
  private void deleteSchemaElement(final ServerSchemaElement element, final int numberDeleted, final int totalNumber,
  private void deleteSchemaElement(final SchemaElement element, final int numberDeleted, final int totalNumber,
      final Arg1<Object> deletingElementMsg) throws OnlineUpdateException, OpenDsException
  {
    SwingUtilities.invokeLater(new Runnable()
@@ -317,7 +315,7 @@
   * @param schemaElement the schema element to be deleted.
   * @throws OpenDsException if an error occurs.
   */
  private void updateSchemaFile(ServerSchemaElement schemaElement) throws OpenDsException
  private void updateSchemaFile(SchemaElement schemaElement) throws OpenDsException
  {
    String schemaFile = getSchemaFile(schemaElement);
@@ -348,9 +346,9 @@
   * @param element the schema element.
   * @return the schema file for a given schema element.
   */
  private String getSchemaFile(ServerSchemaElement element)
  private String getSchemaFile(SchemaElement element)
  {
    String schemaFile = element.getSchemaFile();
    String schemaFile = ServerSchemaElement.getSchemaFile(element);
    if (schemaFile == null)
    {
      schemaFile = ConfigConstants.FILE_USER_SCHEMA_ELEMENTS;
@@ -370,7 +368,7 @@
   * @param element the schema element.
   * @return the value in the schema file for the provided element.
   */
  private String getSchemaFileAttributeValue(ServerSchemaElement element)
  private String getSchemaFileAttributeValue(SchemaElement element)
  {
    return element.toString();
  }
@@ -380,7 +378,7 @@
   * progress dialog.
   * @param element the schema element to be deleted.
   */
  private void printEquivalentCommandToDelete(ServerSchemaElement element)
  private void printEquivalentCommandToDelete(SchemaElement element)
  {
    String schemaFile = getSchemaFile(element);
    String attrName = getAttributeConfigName(element);
@@ -413,7 +411,7 @@
    getProgressDialog().appendProgressHtml(Utilities.applyFont(msg, ColorAndFontConstants.progressFont));
  }
  private LocalizableMessage getEquivalentCommandOfflineMsg(ServerSchemaElement element, String schemaFile)
  private LocalizableMessage getEquivalentCommandOfflineMsg(SchemaElement element, String schemaFile)
  {
    String nameOrOID = getElementNameOrOID(element);
    if (isAttributeType(element))
@@ -423,7 +421,7 @@
    return INFO_CTRL_PANEL_EQUIVALENT_CMD_TO_DELETE_OBJECTCLASS_OFFLINE.get(nameOrOID, schemaFile);
  }
  private LocalizableMessage getEquivalentCommandOnlineMsg(ServerSchemaElement element)
  private LocalizableMessage getEquivalentCommandOnlineMsg(SchemaElement element)
  {
    String nameOrOID = getElementNameOrOID(element);
    if (isAttributeType(element))
@@ -446,8 +444,7 @@
    }
    if (isSuperior)
    {
       // get a new attribute without the superior type
       return updateAttributeTypeWithNewSuperiorType(attrToDelete, null);
       return getNewAttributeTypeWithNewSuperiorType(attrToDelete, null);
    }
    else
    {
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/task/ModifyAttributeTask.java
@@ -16,6 +16,8 @@
 */
package org.opends.guitools.controlpanel.task;
import static org.opends.guitools.controlpanel.util.Utilities.getNewAttributeTypeWithNewSuperiorType;
import static org.opends.messages.AdminToolMessages.*;
import static org.opends.server.util.CollectionUtils.*;
import static org.opends.server.util.SchemaUtils.*;
@@ -148,7 +150,7 @@
    else if (oldAttribute.equals(attrToDelete.getSuperiorType()))
    {
      // get a new attribute with the new superior type
      return Utilities.updateAttributeTypeWithNewSuperiorType(attrToDelete, newAttribute);
      return getNewAttributeTypeWithNewSuperiorType(attrToDelete, newAttribute);
    }
    else
    {
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/task/NewSchemaElementsTask.java
@@ -16,11 +16,11 @@
 */
package org.opends.guitools.controlpanel.task;
import static org.forgerock.opendj.ldap.ModificationType.*;
import static org.forgerock.util.Utils.*;
import static org.opends.messages.AdminToolMessages.*;
import static org.opends.guitools.controlpanel.util.Utilities.*;
import static org.opends.server.schema.ServerSchemaElement.getSchemaFile;
import java.io.File;
import java.util.ArrayList;
@@ -43,13 +43,13 @@
import org.forgerock.i18n.LocalizableMessage;
import org.forgerock.opendj.ldap.schema.AttributeType;
import org.forgerock.opendj.ldap.schema.ObjectClass;
import org.forgerock.opendj.ldap.schema.SchemaElement;
import org.opends.guitools.controlpanel.datamodel.ControlPanelInfo;
import org.opends.guitools.controlpanel.ui.ColorAndFontConstants;
import org.opends.guitools.controlpanel.ui.ProgressDialog;
import org.opends.guitools.controlpanel.util.Utilities;
import org.opends.server.config.ConfigConstants;
import org.opends.server.core.DirectoryServer;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.types.Attribute;
import org.opends.server.types.Attributes;
import org.opends.server.types.DirectoryException;
@@ -169,10 +169,10 @@
    }
  }
  private List<String> getElementsNameOrOID(final Collection<ServerSchemaElement> schemaElements)
  private List<String> getElementsNameOrOID(final Collection<SchemaElement> schemaElements)
  {
    final List<String> nameOrOIDs = new ArrayList<>();
    for (ServerSchemaElement schemaElement : schemaElements)
    for (SchemaElement schemaElement : schemaElements)
    {
      nameOrOIDs.add(getElementNameOrOID(schemaElement));
    }
@@ -245,8 +245,8 @@
  private void updateSchemaOffline() throws OpenDsException
  {
    // Group the changes in the same schema file.
    final Map<String, List<ServerSchemaElement>> mapAttrs = copy(attributeTypesToSchemaElements(attrsToAdd));
    final Map<String, List<ServerSchemaElement>> mapClasses = copy(objectClassesToSchemaElements(ocsToAdd));
    final Map<String, List<SchemaElement>> mapAttrs = copy(attributeTypesToSchemaElements(attrsToAdd));
    final Map<String, List<SchemaElement>> mapClasses = copy(objectClassesToSchemaElements(ocsToAdd));
    final Set<String> allFileNames = new LinkedHashSet<>(mapAttrs.keySet());
    allFileNames.addAll(mapClasses.keySet());
@@ -264,23 +264,23 @@
    }
  }
  private List<ServerSchemaElement> get(Map<String, List<ServerSchemaElement>> hmElems, String fileName)
  private List<SchemaElement> get(Map<String, List<SchemaElement>> hmElems, String fileName)
  {
    List<ServerSchemaElement> elems = hmElems.get(fileName);
    return elems != null ? elems : Collections.<ServerSchemaElement> emptyList();
    List<SchemaElement> elems = hmElems.get(fileName);
    return elems != null ? elems : Collections.<SchemaElement> emptyList();
  }
  private Map<String, List<ServerSchemaElement>> copy(Set<ServerSchemaElement> elemsToAdd)
  private Map<String, List<SchemaElement>> copy(Set<SchemaElement> elemsToAdd)
  {
    Map<String, List<ServerSchemaElement>> hmElems = new LinkedHashMap<>();
    for (ServerSchemaElement elem : elemsToAdd)
    Map<String, List<SchemaElement>> hmElems = new LinkedHashMap<>();
    for (SchemaElement elem : elemsToAdd)
    {
      String fileName = elem.getSchemaFile();
      String fileName = getSchemaFile(elem);
      if (fileName == null)
      {
        fileName = "";
      }
      List<ServerSchemaElement> elems = hmElems.get(fileName);
      List<SchemaElement> elems = hmElems.get(fileName);
      if (elems == null)
      {
        elems = new ArrayList<>();
@@ -293,17 +293,17 @@
  private void addAttributeOnline(final AttributeType attribute) throws OpenDsException
  {
    addSchemaElementOnline(new ServerSchemaElement(attribute),
    addSchemaElementOnline(attribute,
        INFO_CTRL_PANEL_CREATING_ATTRIBUTE_PROGRESS.get(attribute.getNameOrOID()));
  }
  private void addObjectClassOnline(final ObjectClass objectClass) throws OpenDsException
  {
    addSchemaElementOnline(new ServerSchemaElement(objectClass),
    addSchemaElementOnline(objectClass,
        INFO_CTRL_PANEL_CREATING_OBJECTCLASS_PROGRESS.get(objectClass.getNameOrOID()));
  }
  private void addSchemaElementOnline(final ServerSchemaElement schemaElement, final LocalizableMessage progressMsg)
  private void addSchemaElementOnline(final SchemaElement schemaElement, final LocalizableMessage progressMsg)
      throws OpenDsException
  {
    SwingUtilities.invokeLater(new Runnable()
@@ -340,48 +340,48 @@
  }
  /** Returns the definition for provided element without the file name. */
  private String getValueOffline(ServerSchemaElement element)
  private String getValueOffline(SchemaElement element)
  {
    return updateSchemaElementExtraPropertySingleValue(null, element, ServerConstants.SCHEMA_PROPERTY_FILENAME, null)
        .toString();
  }
  private Set<ServerSchemaElement> objectClassesToSchemaElements(final Collection<ObjectClass> classes)
  private Set<SchemaElement> objectClassesToSchemaElements(final Collection<ObjectClass> classes)
  {
    Set<ServerSchemaElement> elements = new HashSet<>();
    Set<SchemaElement> elements = new HashSet<>();
    for (ObjectClass objectClass : classes)
    {
      elements.add(new ServerSchemaElement(objectClass));
      elements.add(objectClass);
    }
    return elements;
  }
  private Set<ServerSchemaElement> attributeTypesToSchemaElements(final Collection<AttributeType> types)
  private Set<SchemaElement> attributeTypesToSchemaElements(final Collection<AttributeType> types)
  {
    Set<ServerSchemaElement> elements = new HashSet<>();
    Set<SchemaElement> elements = new HashSet<>();
    for (AttributeType type : types)
    {
      elements.add(new ServerSchemaElement(type));
      elements.add(type);
    }
    return elements;
  }
  private List<AttributeType> schemaElementsToAttributeTypes(final Collection<ServerSchemaElement> elements)
  private List<AttributeType> schemaElementsToAttributeTypes(final Collection<SchemaElement> elements)
  {
    List<AttributeType> types = new ArrayList<>();
    for (ServerSchemaElement element : elements)
    for (SchemaElement element : elements)
    {
      types.add((AttributeType) element.asSchemaElement());
      types.add((AttributeType) element);
    }
    return types;
  }
  private List<ObjectClass> schemaElementsToObjectClasses(final Collection<ServerSchemaElement> elements)
  private List<ObjectClass> schemaElementsToObjectClasses(final Collection<SchemaElement> elements)
  {
    List<ObjectClass> classes = new ArrayList<>();
    for (ServerSchemaElement element : elements)
    for (SchemaElement element : elements)
    {
      classes.add((ObjectClass) element.asSchemaElement());
      classes.add((ObjectClass) element);
    }
    return classes;
  }
@@ -411,7 +411,7 @@
    }
  }
  private void printEquivalentCommandLineToAddOnline(ServerSchemaElement element)
  private void printEquivalentCommandLineToAddOnline(SchemaElement element)
  {
    List<String> args = new ArrayList<>();
    args.add("-a");
@@ -437,8 +437,8 @@
  private void updateSchemaOffline(
      String file, final List<AttributeType> attributes, final List<ObjectClass> objectClasses) throws OpenDsException
  {
    final List<ServerSchemaElement> schemaElements =
        new ArrayList<ServerSchemaElement>(attributeTypesToSchemaElements(attributes));
    final List<SchemaElement> schemaElements =
        new ArrayList<SchemaElement>(attributeTypesToSchemaElements(attributes));
    schemaElements.addAll(objectClassesToSchemaElements(objectClasses));
    if (file == null)
    {
@@ -489,7 +489,7 @@
      updateSchemaUndefinedFile(fileName, schemaElements);
    }
    for (ServerSchemaElement schemaElement : schemaElements)
    for (SchemaElement schemaElement : schemaElements)
    {
      notifyConfigurationElementCreated(schemaElement);
    }
@@ -504,7 +504,7 @@
  }
  private String equivalentCommandToAddOffline(
      String schemaFile, boolean isSchemaFileDefined, List<ServerSchemaElement> schemaElements)
      String schemaFile, boolean isSchemaFileDefined, List<SchemaElement> schemaElements)
  {
    List<String> names = getElementsNameOrOID(schemaElements);
@@ -526,7 +526,7 @@
      }
    }
    for (ServerSchemaElement element : schemaElements)
    for (SchemaElement element : schemaElements)
    {
      sb.append(getAttributeConfigName(element)).append(": ").append(getValueOffline(element)).append("<br>");
    }
@@ -586,7 +586,7 @@
   * @throws OpenDsException
   *           if an error occurs updating the schema file.
   */
  private void updateSchemaFile(String schemaFile, List<ServerSchemaElement> schemaElements)
  private void updateSchemaFile(String schemaFile, List<SchemaElement> schemaElements)
      throws OpenDsException
  {
    try (final LDIFExportConfig exportConfig = new LDIFExportConfig(schemaFile, ExistingFileBehavior.OVERWRITE))
@@ -608,23 +608,23 @@
    }
  }
  private void addElementsToEntry(List<ServerSchemaElement> schemaElements, Entry schemaEntry)
  private void addElementsToEntry(List<SchemaElement> schemaElements, Entry schemaEntry)
      throws DirectoryException
  {
    for (ServerSchemaElement element : schemaElements)
    for (SchemaElement element : schemaElements)
    {
      Attribute attr = Attributes.create(getAttributeConfigName(element), getValueOffline(element));
      schemaEntry.applyModification(new Modification(ADD, attr));
    }
  }
  private void updateSchemaUndefinedFile(String schemaFile, List<ServerSchemaElement> schemaElements)
  private void updateSchemaUndefinedFile(String schemaFile, List<SchemaElement> schemaElements)
      throws OfflineUpdateException
  {
    try (LDIFExportConfig exportConfig = new LDIFExportConfig(schemaFile, ExistingFileBehavior.FAIL))
    {
      List<String> lines = getSchemaEntryLines();
      for (final ServerSchemaElement element : schemaElements)
      for (final SchemaElement element : schemaElements)
      {
        lines.add(getAttributeConfigName(element) + ": " + getValueOffline(element));
      }
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/AbstractVLVIndexPanel.java
@@ -80,7 +80,6 @@
import org.opends.quicksetup.Installation;
import org.opends.server.config.ConfigException;
import org.opends.server.protocols.ldap.LDAPFilter;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.types.FilterType;
import org.opends.server.types.LDAPException;
import org.opends.server.types.OpenDsException;
@@ -320,15 +319,14 @@
        for (AttributeType attr : schema.getAttributeTypes())
        {
          ServerSchemaElement element = new ServerSchemaElement(attr);
          String name = attr.getNameOrOID();
          if (!isDefined(name))
          {
            if (Utilities.isStandard(element))
            if (Utilities.isStandard(attr))
            {
              standardAttrNames.add(name);
            }
            else if (Utilities.isConfiguration(element))
            else if (Utilities.isConfiguration(attr))
            {
              configurationAttrNames.add(name);
            }
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/BrowseSchemaPanel.java
@@ -16,8 +16,6 @@
 */
package org.opends.guitools.controlpanel.ui;
import static org.opends.guitools.controlpanel.util.Utilities.getElementNameOrOID;
import static org.opends.messages.AdminToolMessages.*;
import static org.opends.server.util.StaticUtils.*;
@@ -71,6 +69,7 @@
import org.forgerock.opendj.ldap.schema.AttributeType;
import org.forgerock.opendj.ldap.schema.MatchingRule;
import org.forgerock.opendj.ldap.schema.ObjectClass;
import org.forgerock.opendj.ldap.schema.SchemaElement;
import org.forgerock.opendj.ldap.schema.Syntax;
import org.opends.guitools.controlpanel.browser.IconPool;
import org.opends.guitools.controlpanel.datamodel.ControlPanelInfo;
@@ -141,7 +140,7 @@
  private JPopupMenu popup;
  private ServerSchemaElement lastCreatedElement;
  private SchemaElement lastCreatedElement;
  private final CategoryTreeNode attributes = new CategoryTreeNode(INFO_CTRL_PANEL_ATTRIBUTES_CATEGORY_NODE.get());
  private final CategoryTreeNode objectClasses =
@@ -671,14 +670,13 @@
    {
      if (mustAdd(oc))
      {
        ServerSchemaElement element = new ServerSchemaElement(oc);
        String name = oc.getNameOrOID();
        if (Utilities.isStandard(element))
        if (Utilities.isStandard(oc))
        {
          standardOcNames.add(name);
          hmStandardOcs.put(name, new StandardObjectClassTreeNode(name, oc));
        }
        else if (Utilities.isConfiguration(element))
        else if (Utilities.isConfiguration(oc))
        {
          configurationOcNames.add(name);
          hmConfigurationOcs.put(name, new ConfigurationObjectClassTreeNode(name, oc));
@@ -699,16 +697,15 @@
    Map<String, CustomAttributeTreeNode> hmCustomAttrs = new HashMap<>();
    for (AttributeType attr : lastSchema.getAttributeTypes())
    {
      ServerSchemaElement element = new ServerSchemaElement(attr);
      if (mustAdd(attr))
      {
        String name = attr.getNameOrOID();
        if (Utilities.isStandard(element))
        if (Utilities.isStandard(attr))
        {
          standardAttrNames.add(name);
          hmStandardAttrs.put(name, new StandardAttributeTreeNode(name, attr));
        }
        else if (Utilities.isConfiguration(element))
        else if (Utilities.isConfiguration(attr))
        {
          configurationAttrNames.add(name);
          hmConfigurationAttrs.put(name, new ConfigurationAttributeTreeNode(name, attr));
@@ -872,7 +869,7 @@
            if (lastCreatedElement != null)
            {
              if (node instanceof CustomObjectClassTreeNode
                  && name.equals(getElementNameOrOID(lastCreatedElement)))
                  && name.equals(Utilities.getElementNameOrOID(lastCreatedElement)))
              {
                newSelectionPath = new TreePath(node.getPath());
                lastCreatedElement = null;
@@ -1464,9 +1461,9 @@
  private void configurationElementCreated(ConfigurationElementCreatedEvent ev)
  {
    Object o = ev.getConfigurationObject();
    if (o instanceof ServerSchemaElement)
    if (o instanceof SchemaElement)
    {
      lastCreatedElement = (ServerSchemaElement) o;
      lastCreatedElement = (SchemaElement) o;
    }
  }
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/CustomAttributePanel.java
@@ -18,6 +18,7 @@
import static org.opends.guitools.controlpanel.util.Utilities.*;
import static org.opends.messages.AdminToolMessages.*;
import static org.opends.server.schema.ServerSchemaElement.*;
import static org.opends.server.util.CollectionUtils.*;
import java.awt.Component;
@@ -83,7 +84,6 @@
import org.opends.guitools.controlpanel.ui.renderer.SchemaElementComboBoxCellRenderer;
import org.opends.guitools.controlpanel.util.LowerCaseComparator;
import org.opends.guitools.controlpanel.util.Utilities;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.types.Schema;
import org.opends.server.util.ServerConstants;
import org.opends.server.util.StaticUtils;
@@ -526,15 +526,14 @@
    lastAliases.addAll(someAliases);
    this.aliases.setText(Utilities.getStringFromCollection(someAliases, ", "));
    ServerSchemaElement element = new ServerSchemaElement(attr);
    String sOrigin = element.getOrigin();
    String sOrigin = getOrigin(attr);
    if (sOrigin == null)
    {
      sOrigin = "";
    }
    origin.setText(sOrigin);
    String sFile = element.getSchemaFile();
    String sFile = getSchemaFile(attr);
    if (sFile == null)
    {
      sFile = "";
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/CustomObjectClassPanel.java
@@ -17,7 +17,7 @@
package org.opends.guitools.controlpanel.ui;
import static org.opends.messages.AdminToolMessages.*;
import static org.opends.server.types.CommonSchemaElements.*;
import static org.opends.server.schema.ServerSchemaElement.*;
import static org.opends.server.util.CollectionUtils.*;
import static org.opends.server.util.SchemaUtils.*;
@@ -80,7 +80,6 @@
import org.opends.guitools.controlpanel.ui.components.TitlePanel;
import org.opends.guitools.controlpanel.ui.renderer.SchemaElementComboBoxCellRenderer;
import org.opends.guitools.controlpanel.util.Utilities;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.types.Schema;
import org.opends.server.util.ServerConstants;
import org.opends.server.util.StaticUtils;
@@ -500,7 +499,7 @@
    lastAliases.addAll(aliases);
    this.aliases.setText(Utilities.getStringFromCollection(aliases, ", "));
    String sOrigin = new ServerSchemaElement(oc).getOrigin();
    String sOrigin = getOrigin(oc);
    if (sOrigin == null)
    {
      sOrigin = "";
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/NewIndexPanel.java
@@ -52,7 +52,6 @@
import org.opends.guitools.controlpanel.event.ConfigurationChangeEvent;
import org.opends.guitools.controlpanel.task.Task;
import org.opends.guitools.controlpanel.util.Utilities;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.types.Schema;
/** Panel that appears when the user defines a new index. */
@@ -125,15 +124,14 @@
      TreeSet<String> customAttrNames = new TreeSet<>();
      for (AttributeType attr : schema.getAttributeTypes())
      {
        ServerSchemaElement element = new ServerSchemaElement(attr);
        String name = attr.getNameOrOID();
        if (!indexExists(backend, name))
        {
          if (Utilities.isStandard(element))
          if (Utilities.isStandard(attr))
          {
            standardAttrNames.add(name);
          }
          else if (Utilities.isConfiguration(element))
          else if (Utilities.isConfiguration(attr))
          {
            configurationAttrNames.add(name);
          }
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/StandardAttributePanel.java
@@ -44,7 +44,6 @@
import org.opends.guitools.controlpanel.ui.components.TitlePanel;
import org.opends.guitools.controlpanel.util.LowerCaseComparator;
import org.opends.guitools.controlpanel.util.Utilities;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.types.Schema;
/** The panel that displays a standard attribute definition. */
@@ -237,7 +236,7 @@
    n = superior != null ? superior.getNameOrOID() : null;
    parent.setText(n);
    oid.setText(attr.getOID());
    origin.setText(StandardObjectClassPanel.getOrigin(new ServerSchemaElement(attr)).toString());
    origin.setText(StandardObjectClassPanel.getOrigin(attr).toString());
    n = attr.getDescription();
    if (n == null)
    {
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/ui/StandardObjectClassPanel.java
@@ -18,6 +18,7 @@
package org.opends.guitools.controlpanel.ui;
import static org.opends.messages.AdminToolMessages.*;
import static org.opends.server.schema.ServerSchemaElement.*;
import static org.opends.server.util.StaticUtils.*;
import java.awt.Component;
@@ -44,6 +45,7 @@
import org.forgerock.i18n.LocalizableMessageBuilder;
import org.forgerock.opendj.ldap.schema.AttributeType;
import org.forgerock.opendj.ldap.schema.ObjectClass;
import org.forgerock.opendj.ldap.schema.SchemaElement;
import org.opends.guitools.controlpanel.event.ConfigurationChangeEvent;
import org.opends.guitools.controlpanel.ui.components.TitlePanel;
import org.opends.guitools.controlpanel.util.LowerCaseComparator;
@@ -239,11 +241,11 @@
   * @param element the schema element.
   * @return the message describing the schema element origin (file, RFC, etc.).
   */
  static LocalizableMessage getOrigin(ServerSchemaElement element)
  static LocalizableMessage getOrigin(SchemaElement element)
  {
    LocalizableMessageBuilder returnValue = new LocalizableMessageBuilder();
    String fileName = element.getSchemaFile();
    String xOrigin = element.getOrigin();
    String fileName = getSchemaFile(element);
    String xOrigin = ServerSchemaElement.getOrigin(element);
    if (xOrigin != null)
    {
      returnValue.append(xOrigin);
@@ -287,7 +289,7 @@
    name.setText(n);
    parent.setText(getSuperiorText(oc));
    oid.setText(oc.getOID());
    origin.setText(getOrigin(new ServerSchemaElement(oc)).toString());
    origin.setText(getOrigin(oc).toString());
    n = oc.getDescription();
    if (n == null)
    {
opendj-server-legacy/src/main/java/org/opends/guitools/controlpanel/util/Utilities.java
@@ -25,6 +25,7 @@
import static org.opends.admin.ads.util.PreferredConnection.Type.*;
import static org.opends.messages.AdminToolMessages.*;
import static org.opends.quicksetup.Installation.*;
import static org.opends.server.schema.ServerSchemaElement.*;
import java.awt.Color;
import java.awt.Component;
@@ -133,7 +134,6 @@
import org.opends.server.core.LockFileManager;
import org.opends.server.core.ServerContext;
import org.opends.server.schema.SchemaConstants;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.types.OpenDsException;
import org.opends.server.types.Schema;
import org.opends.server.util.SchemaUtils;
@@ -1995,14 +1995,14 @@
   * @return {@code true} if the provided schema element is part of the standard,
   *         {@code false} otherwise.
   */
  public static boolean isStandard(ServerSchemaElement fileElement)
  public static boolean isStandard(SchemaElement fileElement)
  {
    final String fileName = fileElement.getSchemaFile();
    final String fileName = getSchemaFile(fileElement);
    if (fileName != null)
    {
      return standardSchemaFileNames.contains(fileName) || fileName.toLowerCase().contains("-rfc");
    }
    String xOrigin = fileElement.getOrigin();
    String xOrigin = getOrigin(fileElement);
    if (xOrigin != null)
    {
      return standardSchemaOrigins.contains(xOrigin) || xOrigin.startsWith("RFC ") || xOrigin.startsWith("draft-");
@@ -2017,14 +2017,14 @@
   * @return {@code true} if the provided schema element is part of the configuration,
   *         {@code false} otherwise.
   */
  public static boolean isConfiguration(ServerSchemaElement fileElement)
  public static boolean isConfiguration(SchemaElement fileElement)
  {
    String fileName = fileElement.getSchemaFile();
    String fileName = getSchemaFile(fileElement);
    if (fileName != null)
    {
      return configurationSchemaFileNames.contains(fileName);
    }
    String xOrigin = fileElement.getOrigin();
    String xOrigin = getOrigin(fileElement);
    if (xOrigin != null)
    {
      return configurationSchemaOrigins.contains(xOrigin);
@@ -2816,9 +2816,9 @@
   *            Element to check.
   * @return {@code true} iff element is an attribute type.
   */
  public static boolean isAttributeType(ServerSchemaElement element)
  public static boolean isAttributeType(SchemaElement element)
  {
    return element.asSchemaElement() instanceof AttributeType;
    return element instanceof AttributeType;
  }
  /**
@@ -2829,7 +2829,7 @@
   *            Using any other schema element will return invalid result.
   * @return Either "attributeTypes" or "objectClasses"
   */
  public static String getAttributeConfigName(ServerSchemaElement element)
  public static String getAttributeConfigName(SchemaElement element)
  {
    return isAttributeType(element) ? ConfigConstants.ATTR_ATTRIBUTE_TYPES : ConfigConstants.ATTR_OBJECTCLASSES;
  }
@@ -2842,14 +2842,17 @@
   *            Using any other schema element will yield an exception.
   * @return Either "attributeTypes" or "objectClasses"
   */
  public static String getElementNameOrOID(ServerSchemaElement element)
  public static String getElementNameOrOID(SchemaElement element)
  {
    SchemaElement elem = element.asSchemaElement();
    if (elem instanceof AttributeType)
    if (element instanceof AttributeType)
    {
      return ((AttributeType) elem).getNameOrOID();
      return ((AttributeType) element).getNameOrOID();
    }
    return ((ObjectClass) elem).getNameOrOID();
    else if (element instanceof ObjectClass)
    {
      return ((ObjectClass) element).getNameOrOID();
    }
    throw new RuntimeException("getElementNameOrOID() not implemented for element of type " + element.getClass());
  }
  /**
@@ -2860,14 +2863,17 @@
   *            Using any other schema element will yield an exception.
   * @return Either "attributeTypes" or "objectClasses"
   */
  public static String getElementOID(ServerSchemaElement element)
  public static String getElementOID(SchemaElement element)
  {
    SchemaElement elem = element.asSchemaElement();
    if (elem instanceof AttributeType)
    if (element instanceof AttributeType)
    {
      return ((AttributeType) elem).getOID();
      return ((AttributeType) element).getOID();
    }
    return ((ObjectClass) elem).getOID();
    else if (element instanceof ObjectClass)
    {
      return ((ObjectClass) element).getOID();
    }
    throw new RuntimeException("getElementOID() not implemented for element of type " + element.getClass());
  }
  /**
@@ -2879,7 +2885,7 @@
   *            new superior type to use.
   * @return the new attribute type
   */
  public static AttributeType updateAttributeTypeWithNewSuperiorType(AttributeType attributeType,
  public static AttributeType getNewAttributeTypeWithNewSuperiorType(AttributeType attributeType,
      AttributeType newSuperiorType)
  {
    String superiorTypeOID = newSuperiorType != null ? newSuperiorType.getNameOrOID() : null;
@@ -2905,8 +2911,8 @@
   *          the value to set
   * @return the updated schema element
   */
  public static ServerSchemaElement updateSchemaElementExtraPropertySingleValue(ServerContext serverContext,
      ServerSchemaElement element, String property, String value)
  public static SchemaElement updateSchemaElementExtraPropertySingleValue(ServerContext serverContext,
      SchemaElement element, String property, String value)
  {
    List<String> values = value != null ? Arrays.asList(value) : null;
    return updateSchemaElementExtraPropertyMultiplesValues(serverContext, element, property, values);
@@ -2926,32 +2932,34 @@
   *          the list of values to set
   * @return the updated schema element
   */
  public static ServerSchemaElement updateSchemaElementExtraPropertyMultiplesValues(ServerContext serverContext,
      ServerSchemaElement element, String property, List<String> values)
  public static SchemaElement updateSchemaElementExtraPropertyMultiplesValues(ServerContext serverContext,
      SchemaElement element, String property, List<String> values)
  {
    org.forgerock.opendj.ldap.schema.Schema schemaNG = serverContext != null ?
        serverContext.getSchemaNG() : org.forgerock.opendj.ldap.schema.Schema.getDefaultSchema();
    SchemaBuilder schemaBuilder = new SchemaBuilder(schemaNG);
    SchemaElement elem = element.asSchemaElement();
    if (elem instanceof AttributeType)
    if (element instanceof AttributeType)
    {
       AttributeType attr = (AttributeType) elem;
      AttributeType attr = (AttributeType) element;
      AttributeType.Builder builder =
          schemaBuilder.buildAttributeType(attr).removeExtraProperty(property, (String) null);
      if (values != null  && !values.isEmpty())
      {
        builder.extraProperties(property, values);
      }
      return new ServerSchemaElement(builder.addToSchemaOverwrite().toSchema().getAttributeType(attr.getNameOrOID()));
      return builder.addToSchemaOverwrite().toSchema().getAttributeType(attr.getNameOrOID());
    }
    // It is an object class
    ObjectClass oc = (ObjectClass) elem;
    else if (element instanceof ObjectClass)
    {
      ObjectClass oc = (ObjectClass) element;
    ObjectClass.Builder builder = schemaBuilder.buildObjectClass(oc).removeExtraProperty(property, (String) null);
    if (values != null && !values.isEmpty())
    {
      builder.extraProperties(property, values);
    }
    return new ServerSchemaElement(builder.addToSchemaOverwrite().toSchema().getObjectClass(oc.getNameOrOID()));
      return builder.addToSchemaOverwrite().toSchema().getObjectClass(oc.getNameOrOID());
  }
    throw new RuntimeException("updateSchemaElementExtraPropertyMultiplesValues() not implemented for element of type "
        + element.getClass());
  }
}
opendj-server-legacy/src/main/java/org/opends/server/backends/NullBackend.java
@@ -18,6 +18,7 @@
import static org.forgerock.opendj.ldap.schema.CoreSchema.*;
import static org.opends.messages.BackendMessages.*;
import static org.opends.server.schema.ServerSchemaElement.*;
import static org.opends.server.util.ServerConstants.*;
import static org.opends.server.util.StaticUtils.*;
@@ -45,7 +46,6 @@
import org.opends.server.core.ModifyOperation;
import org.opends.server.core.SearchOperation;
import org.opends.server.core.ServerContext;
import org.opends.server.schema.ServerSchemaElement;
import org.opends.server.types.BackupConfig;
import org.opends.server.types.BackupDirectory;
import org.opends.server.types.DirectoryException;
@@ -150,7 +150,7 @@
    String nulOCName = "nullbackendobject";
    ObjectClass nulOC = DirectoryServer.getSchema().getObjectClass(nulOCName);
    try {
      DirectoryServer.getSchema().registerObjectClass(nulOC, new ServerSchemaElement(nulOC).getSchemaFile(), false);
      DirectoryServer.getSchema().registerObjectClass(nulOC, getSchemaFile(nulOC), false);
    } catch (DirectoryException de) {
      logger.traceException(de);
      throw new InitializationException(de.getMessageObject());
opendj-server-legacy/src/main/java/org/opends/server/backends/SchemaBackend.java
@@ -24,7 +24,7 @@
import static org.opends.server.config.ConfigConstants.*;
import static org.opends.server.core.DirectoryServer.*;
import static org.opends.server.schema.GeneralizedTimeSyntax.*;
import static org.opends.server.types.CommonSchemaElements.*;
import static org.opends.server.schema.ServerSchemaElement.*;
import static org.opends.server.util.CollectionUtils.*;
import static org.opends.server.util.ServerConstants.*;
import static org.opends.server.util.StaticUtils.*;
opendj-server-legacy/src/main/java/org/opends/server/schema/ServerSchemaElement.java
@@ -15,89 +15,58 @@
 */
package org.opends.server.schema;
import static org.opends.server.types.Schema.*;
import static org.opends.server.types.Schema.addSchemaFileToElementDefinitionIfAbsent;
import static org.opends.messages.SchemaMessages.ERR_ATTR_SYNTAX_ILLEGAL_X_SCHEMA_FILE;
import static org.opends.server.util.ServerConstants.SCHEMA_PROPERTY_FILENAME;
import java.util.List;
import java.util.Map;
import org.forgerock.i18n.LocalizableMessage;
import org.forgerock.opendj.ldap.ResultCode;
import org.forgerock.opendj.ldap.schema.AttributeType;
import org.forgerock.opendj.ldap.schema.Schema;
import org.forgerock.opendj.ldap.schema.SchemaBuilder;
import org.forgerock.opendj.ldap.schema.SchemaElement;
import org.opends.server.core.ServerContext;
import org.opends.server.types.DirectoryException;
import org.opends.server.util.ServerConstants;
/**
 * Provides common operations for server schema elements.
 * Utility class that provides common operations over schema elements in a server context.
 */
public class ServerSchemaElement
{
  /** The underlying schema element. */
  private final SchemaElement element;
  private ServerSchemaElement()
  {
    // prevent instantiation
  }
  /**
   * Creates an element.
   * Retrieves the definition string used to create the provided schema element and including the
   * X-SCHEMA-FILE extension.
   *
   * @param element
   *            The schema element to wrap.
   *            The schema element.
   * @return The definition string used to create the schema element including the X-SCHEMA-FILE
   *         extension.
   */
  public ServerSchemaElement(SchemaElement element)
  {
    this.element = element;
  }
  /**
   * Returns this schema element.
   *
   * @return this schema element
   */
  public SchemaElement asSchemaElement()
  {
    return this.element;
  }
  /**
   * Retrieves the definition string used to create this schema element
   * and including the X-SCHEMA-FILE extension.
   *
   * @return The definition string used to create this attribute
   *         type including the X-SCHEMA-FILE extension.
   */
  public String getDefinitionWithFileName()
  public static String getDefinitionWithFileName(SchemaElement element)
  {
    final String definition = element.toString();
    return addSchemaFileToElementDefinitionIfAbsent(definition, getSchemaFile());
    return addSchemaFileToElementDefinitionIfAbsent(definition, getSchemaFile(element));
  }
  /**
   * Returns the description of this schema element.
   * Returns the single value of the provided extra property for the provided schema element.
   *
   * @return The description of this schema element, or the empty string if it does not have a description.
   */
  public String getDescription()
  {
    return element.getDescription();
  }
  /**
   * Returns a map of extra properties of this schema element.
   *
   * @return An unmodifiable map containing all of the extra properties associated with this schema element.
   */
  public Map<String, List<String>> getExtraProperties()
  {
    return element.getExtraProperties();
  }
  /**
   * Returns the single value of the provided extra property.
   *
   * @param element
   *            The schema element.
   * @param property
   *            The name of property to retrieve.
   * @return the single value of the property
   * @return the single value of the extra property
   */
  public String getExtraPropertyAsSingleValue(String property)
  public static String getExtraPropertyAsSingleValue(SchemaElement element, String property)
  {
    List<String> values = element.getExtraProperties().get(property);
    return values != null && !values.isEmpty() ? values.get(0) : null;
@@ -106,21 +75,25 @@
  /**
   * Returns the origin of the provided schema element.
   *
   * @return the origin of the provided schema element.
   * @param element
   *            The schema element.
   * @return the origin of the schema element as defined in the extra properties.
   */
  public String getOrigin()
  public static String getOrigin(SchemaElement element)
  {
    return getExtraPropertyAsSingleValue(ServerConstants.SCHEMA_PROPERTY_ORIGIN);
    return getExtraPropertyAsSingleValue(element, ServerConstants.SCHEMA_PROPERTY_ORIGIN);
  }
  /**
   * Returns the schema file of the provided schema element.
   *
   * @return the schema file of the provided schema element.
   * @param element
   *            The schema element.
   * @return the schema file of schema element.
   */
  public String getSchemaFile()
  public static String getSchemaFile(SchemaElement element)
  {
    return getExtraPropertyAsSingleValue(ServerConstants.SCHEMA_PROPERTY_FILENAME);
    return getExtraPropertyAsSingleValue(element, ServerConstants.SCHEMA_PROPERTY_FILENAME);
  }
  /**
opendj-server-legacy/src/main/java/org/opends/server/types/CommonSchemaElements.java
File was deleted