You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@directory.apache.org by se...@apache.org on 2007/04/01 22:35:23 UTC

svn commit: r524677 - in /directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor: ./ dialogs/ model/ widgets/

Author: seelmann
Date: Sun Apr  1 13:35:23 2007
New Revision: 524677

URL: http://svn.apache.org/viewvc?view=rev&rev=524677
Log:
Added two more value editors, integrated all into the ACIItemValueEditor

Added:
    directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/MaxValueCountValueEditor.java
    directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/RestrictedByValueEditor.java
Modified:
    directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/dialogs/MultiValuedDialog.java
    directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/model/ProtectedItemWrapperFactory.java
    directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemSourceEditorComposite.java
    directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemUserClassesComposite.java

Added: directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/MaxValueCountValueEditor.java
URL: http://svn.apache.org/viewvc/directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/MaxValueCountValueEditor.java?view=auto&rev=524677
==============================================================================
--- directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/MaxValueCountValueEditor.java (added)
+++ directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/MaxValueCountValueEditor.java Sun Apr  1 13:35:23 2007
@@ -0,0 +1,382 @@
+/*
+ *  Licensed to the Apache Software Foundation (ASF) under one
+ *  or more contributor license agreements.  See the NOTICE file
+ *  distributed with this work for additional information
+ *  regarding copyright ownership.  The ASF licenses this file
+ *  to you 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.apache.directory.ldapstudio.aciitemeditor;
+
+
+import java.util.Arrays;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+import org.apache.directory.ldapstudio.browser.core.model.AttributeHierarchy;
+import org.apache.directory.ldapstudio.browser.core.model.IConnection;
+import org.apache.directory.ldapstudio.browser.core.model.IValue;
+import org.apache.directory.ldapstudio.browser.core.model.schema.Schema;
+import org.apache.directory.ldapstudio.browser.ui.dialogs.TextDialog;
+import org.apache.directory.ldapstudio.browser.ui.valueeditors.AbstractDialogStringValueEditor;
+import org.apache.directory.ldapstudio.browser.ui.widgets.BaseWidgetUtils;
+import org.apache.directory.ldapstudio.browser.ui.widgets.ListContentProposalProvider;
+import org.eclipse.jface.dialogs.Dialog;
+import org.eclipse.jface.dialogs.IDialogConstants;
+import org.eclipse.jface.fieldassist.ComboContentAdapter;
+import org.eclipse.jface.fieldassist.ContentProposalAdapter;
+import org.eclipse.jface.fieldassist.DecoratedField;
+import org.eclipse.jface.fieldassist.FieldDecoration;
+import org.eclipse.jface.fieldassist.FieldDecorationRegistry;
+import org.eclipse.jface.fieldassist.IControlCreator;
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.layout.GridData;
+import org.eclipse.swt.layout.GridLayout;
+import org.eclipse.swt.widgets.Combo;
+import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.Control;
+import org.eclipse.swt.widgets.Shell;
+import org.eclipse.swt.widgets.Spinner;
+
+
+/**
+ * ACI item editor specific value editor to edit the MaxValueCount protected item.
+ *
+ * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
+ * @version $Rev$, $Date$
+ */
+public class MaxValueCountValueEditor extends AbstractDialogStringValueEditor
+{
+
+    /**
+     * {@inheritDoc}
+     * 
+     * This implementation opens the MaxValueCountDialog.
+     */
+    public boolean openDialog( Shell shell )
+    {
+        Object value = getValue();
+        if ( value != null && value instanceof MaxValueCountValueEditorRawValueWrapper )
+        {
+            MaxValueCountValueEditorRawValueWrapper wrapper = ( MaxValueCountValueEditorRawValueWrapper ) value;
+            MaxValueCountDialog dialog = new MaxValueCountDialog( shell, wrapper.schema, wrapper.type, wrapper.maxCount );
+            if ( dialog.open() == TextDialog.OK && !"".equals( dialog.getType() ) && dialog.getMaxCount() > -1 )
+            {
+                setValue( "{ type " + dialog.getType() + ", maxCount " + dialog.getMaxCount() + " }" );
+                return true;
+            }
+        }
+        return false;
+    }
+
+
+    /**
+     * {@inheritDoc}
+     * 
+     * Returns always the string value.
+     * 
+     * Reimplementation, because getRawValue() returns an 
+     * MaxValueCountValueEditorRawValueWrapper.
+     */
+    public String getDisplayValue( IValue value )
+    {
+        if ( value == null )
+        {
+            return "NULL";
+        }
+
+        String displayValue = value.getStringValue();
+        return displayValue;
+    }
+
+
+    /**
+     * {@inheritDoc}
+     * 
+     * Returns null.
+     * Modification in search result editor not supported.
+     */
+    public Object getRawValue( AttributeHierarchy attributeHierarchy )
+    {
+        return null;
+    }
+
+
+    /**
+     * {@inheritDoc}
+     * 
+     * Returns an MaxValueCountValueEditorRawValueWrapper.
+     */
+    public Object getRawValue( IValue value )
+    {
+        if ( value == null || !value.isString() )
+        {
+            return null;
+        }
+        else
+        {
+            return getRawValue( value.getAttribute().getEntry().getConnection(), value.getStringValue() );
+        }
+    }
+
+
+    /**
+     * {@inheritDoc}
+     * 
+     * Returns an MaxValueCountValueEditorRawValueWrapper.
+     */
+    public Object getRawValue( IConnection connection, Object value )
+    {
+        Schema schema = null;
+        if ( connection != null )
+        {
+            schema = connection.getSchema();
+        }
+        if ( schema == null || value == null || !( value instanceof String ) )
+        {
+            return null;
+        }
+        
+        String stringValue = ( String ) value;
+        String type = "";
+        int maxCount = 0;
+        try 
+        {
+            // for example: { type userPassword, maxCount 10 }
+            Pattern pattern = Pattern.compile("\\s*\\{\\s*type\\s*([^,]*),\\s*maxCount\\s*(\\d*)\\s*\\}\\s*");
+            Matcher matcher = pattern.matcher(stringValue);
+            type = matcher.matches() ? matcher.group(1) : "";
+            maxCount = matcher.matches() ? Integer.valueOf( matcher.group(2) ) : 0;
+        }
+        catch(Exception e)
+        {
+        }
+        
+        MaxValueCountValueEditorRawValueWrapper wrapper = new MaxValueCountValueEditorRawValueWrapper( schema, type, maxCount );
+        return wrapper;
+    }
+
+    /**
+     * The MaxValueCountValueEditorRawValueWrapper is used to pass contextual 
+     * information to the opened MaxValueCountDialog.
+     *
+     * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
+     * @version $Rev$, $Date$
+     */
+    private class MaxValueCountValueEditorRawValueWrapper
+    {
+        /** 
+         * The schema, used in MaxValueCountDialog to build the list
+         * with possible attribute types.
+         */
+        private Schema schema;
+
+        /** The attribute type, used as initial attribute type. */
+        private String type;
+        
+        /** The max count, used as initial value. */
+        private int maxCount;
+
+
+        /**
+         * Creates a new instance of AttributeTypeAndValueValueEditorRawValueWrapper.
+         * 
+         * @param schema the schema
+         * @param attributeType the attribute type
+         * @param value the value
+         */
+        private MaxValueCountValueEditorRawValueWrapper( Schema schema, String type, int maxCount )
+        {
+            this.schema = schema;
+            this.type = type;
+            this.maxCount = maxCount;
+        }
+    }
+    
+    
+    /**
+     * This class provides a dialog to enter the MaxValueCount values.
+     *
+     * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
+     * @version $Rev$, $Date$
+     */
+    private class MaxValueCountDialog extends Dialog
+    {
+
+        /** The dialog title */
+        public static final String DIALOG_TITLE = "Max Value Count Editor";
+
+        /** The schema. */
+        private Schema schema;
+
+        /** The initial attribute type. */
+        private String initialType;
+
+        /** The initial max count. */
+        private int initialMaxCount;
+
+        /** The attribute type combo field. */
+        private DecoratedField attributeTypeComboField;
+
+        /** The attribute type combo. */
+        private Combo attributeTypeCombo;
+
+        /** The attribute type content proposal adapter */
+        private ContentProposalAdapter attributeTypeCPA;
+
+        /** The max count spinner. */
+        private Spinner maxCountSpinner;
+
+        /** The return attribute type. */
+        private String returnType;
+
+        /** The return value. */
+        private int returnMaxCount;
+
+
+        /**
+         * Creates a new instance of AttributeTypeDialog.
+         * 
+         * @param parentShell the parent shell
+         * @param schema the schema
+         * @param initialType the initial attribute type
+         * @param initialMaxCount the initial max count
+         */
+        public MaxValueCountDialog( Shell parentShell, Schema schema, String initialType,
+            int initialMaxCount )
+        {
+            super( parentShell );
+            super.setShellStyle( super.getShellStyle() | SWT.RESIZE );
+            this.initialType = initialType;
+            this.initialMaxCount = initialMaxCount;
+            this.schema = schema;
+            this.returnType = null;
+            this.returnMaxCount = -1;
+        }
+
+
+        /**
+         * {@inheritDoc}
+         */
+        protected void configureShell( Shell shell )
+        {
+            super.configureShell( shell );
+            shell.setText( DIALOG_TITLE );
+        }
+
+
+        /**
+         * {@inheritDoc}
+         */
+        protected void createButtonsForButtonBar( Composite parent )
+        {
+            super.createButtonsForButtonBar( parent );
+        }
+
+
+        /**
+         * {@inheritDoc}
+         */
+        protected void okPressed()
+        {
+            returnType = attributeTypeCombo.getText();
+            returnMaxCount = maxCountSpinner.getSelection();
+            super.okPressed();
+        }
+
+
+        /**
+         * {@inheritDoc}
+         */
+        protected Control createDialogArea( Composite parent )
+        {
+            // create composite
+            Composite composite = ( Composite ) super.createDialogArea( parent );
+            GridData gd = new GridData( GridData.FILL_BOTH );
+            gd.widthHint = convertHorizontalDLUsToPixels( IDialogConstants.MINIMUM_MESSAGE_AREA_WIDTH );
+            composite.setLayoutData( gd );
+            composite.setLayout( new GridLayout( 5, false ) );
+
+            BaseWidgetUtils.createLabel( composite, "{ type ", 1 );
+            
+            // combo widget
+            String[] allAtNames = schema.getAttributeTypeDescriptionNames();
+            Arrays.sort( allAtNames );
+
+            final FieldDecoration fieldDecoration = FieldDecorationRegistry.getDefault().getFieldDecoration(
+                FieldDecorationRegistry.DEC_CONTENT_PROPOSAL );
+            attributeTypeComboField = new DecoratedField( composite, SWT.NONE, new IControlCreator()
+            {
+                public Control createControl( Composite parent, int style )
+                {
+                    Combo combo = BaseWidgetUtils.createCombo( parent, new String[0], -1, 1 );
+                    combo.setVisibleItemCount( 20 );
+                    return combo;
+                }
+            } );
+            attributeTypeComboField.addFieldDecoration( fieldDecoration, SWT.TOP | SWT.LEFT, true );
+            attributeTypeComboField.getLayoutControl().setLayoutData( new GridData( SWT.FILL, SWT.CENTER, true, false ) );
+            attributeTypeCombo = ( Combo ) attributeTypeComboField.getControl();
+            attributeTypeCombo.setItems( allAtNames );
+            attributeTypeCombo.setText( initialType );
+
+            // content proposal adapter
+            attributeTypeCPA = new ContentProposalAdapter( attributeTypeCombo, new ComboContentAdapter(),
+                new ListContentProposalProvider( attributeTypeCombo.getItems() ), null, null );
+            attributeTypeCPA.setFilterStyle( ContentProposalAdapter.FILTER_NONE );
+            attributeTypeCPA.setProposalAcceptanceStyle( ContentProposalAdapter.PROPOSAL_REPLACE );
+
+            BaseWidgetUtils.createLabel( composite, ", maxCount ", 1 );
+
+            maxCountSpinner = new Spinner( composite, SWT.BORDER );
+            maxCountSpinner.setMinimum( 0 );
+            maxCountSpinner.setMaximum( Integer.MAX_VALUE );
+            maxCountSpinner.setDigits( 0 );
+            maxCountSpinner.setIncrement( 1 );
+            maxCountSpinner.setPageIncrement( 100 );
+            maxCountSpinner.setSelection( initialMaxCount );
+            maxCountSpinner.setLayoutData( new GridData( GridData.FILL_HORIZONTAL ) );
+
+            BaseWidgetUtils.createLabel( composite, " }", 1 );
+            
+            applyDialogFont( composite );
+            return composite;
+        }
+
+
+        /**
+         * Gets the attribute type.
+         * 
+         * @return the attribute type, null if canceled
+         */
+        public String getType()
+        {
+            return returnType;
+        }
+
+
+        /**
+         * Gets the max count.
+         * 
+         * @return the max count, -1 if canceled
+         */
+        public int getMaxCount()
+        {
+            return returnMaxCount;
+        }
+
+    }
+
+}

Added: directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/RestrictedByValueEditor.java
URL: http://svn.apache.org/viewvc/directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/RestrictedByValueEditor.java?view=auto&rev=524677
==============================================================================
--- directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/RestrictedByValueEditor.java (added)
+++ directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/RestrictedByValueEditor.java Sun Apr  1 13:35:23 2007
@@ -0,0 +1,400 @@
+/*
+ *  Licensed to the Apache Software Foundation (ASF) under one
+ *  or more contributor license agreements.  See the NOTICE file
+ *  distributed with this work for additional information
+ *  regarding copyright ownership.  The ASF licenses this file
+ *  to you 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.apache.directory.ldapstudio.aciitemeditor;
+
+
+import java.util.Arrays;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+import org.apache.directory.ldapstudio.browser.core.model.AttributeHierarchy;
+import org.apache.directory.ldapstudio.browser.core.model.IConnection;
+import org.apache.directory.ldapstudio.browser.core.model.IValue;
+import org.apache.directory.ldapstudio.browser.core.model.schema.Schema;
+import org.apache.directory.ldapstudio.browser.ui.dialogs.TextDialog;
+import org.apache.directory.ldapstudio.browser.ui.valueeditors.AbstractDialogStringValueEditor;
+import org.apache.directory.ldapstudio.browser.ui.widgets.BaseWidgetUtils;
+import org.apache.directory.ldapstudio.browser.ui.widgets.ListContentProposalProvider;
+import org.eclipse.jface.dialogs.Dialog;
+import org.eclipse.jface.dialogs.IDialogConstants;
+import org.eclipse.jface.fieldassist.ComboContentAdapter;
+import org.eclipse.jface.fieldassist.ContentProposalAdapter;
+import org.eclipse.jface.fieldassist.DecoratedField;
+import org.eclipse.jface.fieldassist.FieldDecoration;
+import org.eclipse.jface.fieldassist.FieldDecorationRegistry;
+import org.eclipse.jface.fieldassist.IControlCreator;
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.layout.GridData;
+import org.eclipse.swt.layout.GridLayout;
+import org.eclipse.swt.widgets.Combo;
+import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.Control;
+import org.eclipse.swt.widgets.Shell;
+
+
+/**
+ * ACI item editor specific value editor to edit the RestrictedBy protected item.
+ *
+ * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
+ * @version $Rev$, $Date$
+ */
+public class RestrictedByValueEditor extends AbstractDialogStringValueEditor
+{
+
+    /**
+     * {@inheritDoc}
+     * 
+     * This implementation opens the RestrictedByDialog.
+     */
+    public boolean openDialog( Shell shell )
+    {
+        Object value = getValue();
+        if ( value != null && value instanceof RestrictedByValueEditorRawValueWrapper )
+        {
+            RestrictedByValueEditorRawValueWrapper wrapper = ( RestrictedByValueEditorRawValueWrapper ) value;
+            RestrictedByDialog dialog = new RestrictedByDialog( shell, wrapper.schema, wrapper.type, wrapper.valuesIn );
+            if ( dialog.open() == TextDialog.OK && !"".equals( dialog.getType() ) && !"".equals( dialog.getValuesIn() ) )
+            {
+                setValue( "{ type " + dialog.getType() + ", valuesIn " + dialog.getValuesIn() + " }" );
+                return true;
+            }
+        }
+        return false;
+    }
+
+
+    /**
+     * {@inheritDoc}
+     * 
+     * Returns always the string value.
+     * 
+     * Reimplementation, because getRawValue() returns an 
+     * RestrictedByValueEditorRawValueWrapper.
+     */
+    public String getDisplayValue( IValue value )
+    {
+        if ( value == null )
+        {
+            return "NULL";
+        }
+
+        String displayValue = value.getStringValue();
+        return displayValue;
+    }
+
+
+    /**
+     * {@inheritDoc}
+     * 
+     * Returns null.
+     * Modification in search result editor not supported.
+     */
+    public Object getRawValue( AttributeHierarchy attributeHierarchy )
+    {
+        return null;
+    }
+
+
+    /**
+     * {@inheritDoc}
+     * 
+     * Returns an RestrictedByValueEditorRawValueWrapper.
+     */
+    public Object getRawValue( IValue value )
+    {
+        if ( value == null || !value.isString() )
+        {
+            return null;
+        }
+        else
+        {
+            return getRawValue( value.getAttribute().getEntry().getConnection(), value.getStringValue() );
+        }
+    }
+
+
+    /**
+     * {@inheritDoc}
+     * 
+     * Returns an RestrictedByValueEditorRawValueWrapper.
+     */
+    public Object getRawValue( IConnection connection, Object value )
+    {
+        Schema schema = null;
+        if ( connection != null )
+        {
+            schema = connection.getSchema();
+        }
+        if ( schema == null || value == null || !( value instanceof String ) )
+        {
+            return null;
+        }
+
+        String stringValue = ( String ) value;
+        String type = "";
+        String valuesIn = "";
+        try
+        {
+            // for example: { type sn, valuesIn cn }
+            Pattern pattern = Pattern.compile( "\\s*\\{\\s*type\\s*([^,\\s]*)\\s*,\\s*valuesIn\\s*([^,\\s]*)\\s*\\}\\s*" );
+            Matcher matcher = pattern.matcher( stringValue );
+            type = matcher.matches() ? matcher.group( 1 ) : "";
+            valuesIn = matcher.matches() ? matcher.group( 2 ) : "";
+        }
+        catch ( Throwable e )
+        {
+            e.printStackTrace();
+        }
+
+        RestrictedByValueEditorRawValueWrapper wrapper = new RestrictedByValueEditorRawValueWrapper( schema, type,
+            valuesIn );
+        return wrapper;
+    }
+
+    /**
+     * The RestrictedByValueEditorRawValueWrapper is used to pass contextual 
+     * information to the opened RestrictedByDialog.
+     *
+     * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
+     * @version $Rev$, $Date$
+     */
+    private class RestrictedByValueEditorRawValueWrapper
+    {
+        /** 
+         * The schema, used in RestrictedByDialog to build the list
+         * with possible attribute types.
+         */
+        private Schema schema;
+
+        /** The type, used as initial type. */
+        private String type;
+
+        /** The values in, used as initial values in. */
+        private String valuesIn;
+
+
+        /**
+         * Creates a new instance of RestrictedByValueEditorRawValueWrapper.
+         * 
+         * @param schema the schema
+         * @param type the type
+         * @param valuesIn the values in
+         */
+        private RestrictedByValueEditorRawValueWrapper( Schema schema, String type, String valuesIn )
+        {
+            this.schema = schema;
+            this.type = type;
+            this.valuesIn = valuesIn;
+        }
+    }
+
+    /**
+     * This class provides a dialog to enter the RestrictedBy values.
+     *
+     * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
+     * @version $Rev$, $Date$
+     */
+    private class RestrictedByDialog extends Dialog
+    {
+
+        /** The dialog title */
+        public static final String DIALOG_TITLE = "Restricted By Editor";
+
+        /** The schema. */
+        private Schema schema;
+
+        /** The initial type. */
+        private String initialType;
+
+        /** The initial values in. */
+        private String initialValuesIn;
+
+        /** The type combo field. */
+        private DecoratedField typeComboField;
+
+        /** The type combo. */
+        private Combo typeCombo;
+
+        /** The type content proposal adapter */
+        private ContentProposalAdapter typeCPA;
+
+        /** The values in combo field. */
+        private DecoratedField valuesInComboField;
+
+        /** The values in combo. */
+        private Combo valuesInCombo;
+
+        /** The values in content proposal adapter */
+        private ContentProposalAdapter valuesInCPA;
+
+        /** The return type. */
+        private String returnType;
+
+        /** The return values in. */
+        private String returnValuesIn;
+
+
+        /**
+         * Creates a new instance of RestrictedByDialog.
+         * 
+         * @param parentShell the parent shell
+         * @param schema the schema
+         * @param initialType the initial type
+         * @param initialValuesIn the initial values in
+         */
+        public RestrictedByDialog( Shell parentShell, Schema schema, String initialType, String initialValuesIn )
+        {
+            super( parentShell );
+            super.setShellStyle( super.getShellStyle() | SWT.RESIZE );
+            this.initialType = initialType;
+            this.initialValuesIn = initialValuesIn;
+            this.schema = schema;
+            this.returnType = null;
+            this.returnValuesIn = null;
+        }
+
+
+        /**
+         * {@inheritDoc}
+         */
+        protected void configureShell( Shell shell )
+        {
+            super.configureShell( shell );
+            shell.setText( DIALOG_TITLE );
+        }
+
+
+        /**
+         * {@inheritDoc}
+         */
+        protected void createButtonsForButtonBar( Composite parent )
+        {
+            super.createButtonsForButtonBar( parent );
+        }
+
+
+        /**
+         * {@inheritDoc}
+         */
+        protected void okPressed()
+        {
+            returnType = typeCombo.getText();
+            returnValuesIn = valuesInCombo.getText();
+            super.okPressed();
+        }
+
+
+        /**
+         * {@inheritDoc}
+         */
+        protected Control createDialogArea( Composite parent )
+        {
+            // create composite
+            Composite composite = ( Composite ) super.createDialogArea( parent );
+            GridData gd = new GridData( GridData.FILL_BOTH );
+            gd.widthHint = convertHorizontalDLUsToPixels( IDialogConstants.MINIMUM_MESSAGE_AREA_WIDTH );
+            composite.setLayoutData( gd );
+            composite.setLayout( new GridLayout( 5, false ) );
+
+            BaseWidgetUtils.createLabel( composite, "{ type ", 1 );
+
+            // combo widget
+            String[] allAtNames = schema.getAttributeTypeDescriptionNames();
+            Arrays.sort( allAtNames );
+
+            final FieldDecoration fieldDecoration = FieldDecorationRegistry.getDefault().getFieldDecoration(
+                FieldDecorationRegistry.DEC_CONTENT_PROPOSAL );
+
+            typeComboField = new DecoratedField( composite, SWT.NONE, new IControlCreator()
+            {
+                public Control createControl( Composite parent, int style )
+                {
+                    Combo combo = BaseWidgetUtils.createCombo( parent, new String[0], -1, 1 );
+                    combo.setVisibleItemCount( 20 );
+                    return combo;
+                }
+            } );
+            typeComboField.addFieldDecoration( fieldDecoration, SWT.TOP | SWT.LEFT, true );
+            typeComboField.getLayoutControl().setLayoutData( new GridData( SWT.FILL, SWT.CENTER, true, false ) );
+            typeCombo = ( Combo ) typeComboField.getControl();
+            typeCombo.setItems( allAtNames );
+            typeCombo.setText( initialType );
+
+            // content proposal adapter
+            typeCPA = new ContentProposalAdapter( typeCombo, new ComboContentAdapter(),
+                new ListContentProposalProvider( typeCombo.getItems() ), null, null );
+            typeCPA.setFilterStyle( ContentProposalAdapter.FILTER_NONE );
+            typeCPA.setProposalAcceptanceStyle( ContentProposalAdapter.PROPOSAL_REPLACE );
+
+            BaseWidgetUtils.createLabel( composite, ", valuesIn ", 1 );
+
+            valuesInComboField = new DecoratedField( composite, SWT.NONE, new IControlCreator()
+            {
+                public Control createControl( Composite parent, int style )
+                {
+                    Combo combo = BaseWidgetUtils.createCombo( parent, new String[0], -1, 1 );
+                    combo.setVisibleItemCount( 20 );
+                    return combo;
+                }
+            } );
+            valuesInComboField.addFieldDecoration( fieldDecoration, SWT.TOP | SWT.LEFT, true );
+            valuesInComboField.getLayoutControl().setLayoutData( new GridData( SWT.FILL, SWT.CENTER, true, false ) );
+            valuesInCombo = ( Combo ) valuesInComboField.getControl();
+            valuesInCombo.setItems( allAtNames );
+            valuesInCombo.setText( initialValuesIn );
+
+            // content proposal adapter
+            valuesInCPA = new ContentProposalAdapter( valuesInCombo, new ComboContentAdapter(),
+                new ListContentProposalProvider( valuesInCombo.getItems() ), null, null );
+            valuesInCPA.setFilterStyle( ContentProposalAdapter.FILTER_NONE );
+            valuesInCPA.setProposalAcceptanceStyle( ContentProposalAdapter.PROPOSAL_REPLACE );
+
+            BaseWidgetUtils.createLabel( composite, " }", 1 );
+
+            applyDialogFont( composite );
+            return composite;
+        }
+
+
+        /**
+         * Gets the type.
+         * 
+         * @return the type, null if canceled
+         */
+        public String getType()
+        {
+            return returnType;
+        }
+
+
+        /**
+         * Gets the values in.
+         * 
+         * @return the values in, null if canceled
+         */
+        public String getValuesIn()
+        {
+            return returnValuesIn;
+        }
+
+    }
+
+}

Modified: directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/dialogs/MultiValuedDialog.java
URL: http://svn.apache.org/viewvc/directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/dialogs/MultiValuedDialog.java?view=diff&rev=524677&r1=524676&r2=524677
==============================================================================
--- directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/dialogs/MultiValuedDialog.java (original)
+++ directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/dialogs/MultiValuedDialog.java Sun Apr  1 13:35:23 2007
@@ -119,7 +119,7 @@
     protected void configureShell( Shell shell )
     {
         super.configureShell( shell );
-        shell.setText( "Edit " + displayName + " Values" );
+        shell.setText( "Edit " + displayName );
     }
 
     

Modified: directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/model/ProtectedItemWrapperFactory.java
URL: http://svn.apache.org/viewvc/directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/model/ProtectedItemWrapperFactory.java?view=diff&rev=524677&r1=524676&r2=524677
==============================================================================
--- directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/model/ProtectedItemWrapperFactory.java (original)
+++ directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/model/ProtectedItemWrapperFactory.java Sun Apr  1 13:35:23 2007
@@ -1,6 +1,12 @@
 
 package org.apache.directory.ldapstudio.aciitemeditor.model;
 
+import org.apache.directory.ldapstudio.aciitemeditor.MaxValueCountValueEditor;
+import org.apache.directory.ldapstudio.aciitemeditor.RestrictedByValueEditor;
+import org.apache.directory.ldapstudio.browser.ui.valueeditors.internal.AttributeTypeAndValueValueEditor;
+import org.apache.directory.ldapstudio.browser.ui.valueeditors.internal.AttributeTypeValueEditor;
+import org.apache.directory.ldapstudio.browser.ui.valueeditors.internal.FilterValueEditor;
+import org.apache.directory.ldapstudio.browser.ui.valueeditors.internal.IntegerValueEditor;
 import org.apache.directory.ldapstudio.browser.ui.valueeditors.internal.TextValueEditor;
 import org.apache.directory.shared.ldap.aci.ProtectedItem;
 
@@ -38,7 +44,7 @@
                     true,
                     "",  //$NON-NLS-1$
                     "", //$NON-NLS-1$
-                    new TextValueEditor() // TODO: AttributeTypeValueEditor
+                    new AttributeTypeValueEditor()
                 ),
                 
                 // allAttributeValues { 1.2.3, cn }
@@ -48,7 +54,7 @@
                     true,
                     "",  //$NON-NLS-1$
                     "", //$NON-NLS-1$
-                    new TextValueEditor() // TODO: AttributeTypeValueEditor
+                    new AttributeTypeValueEditor()
                 ),
                 
                 // attributeType
@@ -68,7 +74,7 @@
                     true,
                     "",  //$NON-NLS-1$
                     "", //$NON-NLS-1$
-                    new TextValueEditor() // TODO: AttributeTypeAndValueValueEditor
+                    new AttributeTypeAndValueValueEditor()
                 ),
                 
                 // selfValue { 1.2.3, cn }
@@ -78,7 +84,7 @@
                     true,
                     "",  //$NON-NLS-1$
                     "", //$NON-NLS-1$
-                    new TextValueEditor() // TODO: AttributeTypeValueEditor
+                    new AttributeTypeValueEditor()
                 ),
                 
                 // rangeOfValues (cn=E*)
@@ -88,7 +94,7 @@
                     false,
                     "",  //$NON-NLS-1$
                     "", //$NON-NLS-1$
-                    new TextValueEditor() 
+                    new FilterValueEditor() 
                 ),
                 
                 // maxValueCount { { type 10.11.12, maxCount 10 }, { maxCount 20, type 11.12.13  } }
@@ -98,7 +104,7 @@
                     true,
                     "",  //$NON-NLS-1$
                     "", //$NON-NLS-1$
-                    new TextValueEditor() // TODO: MaxValueCountValueEditor
+                    new MaxValueCountValueEditor()
                 ),
                 
                 // maxImmSub 3
@@ -108,7 +114,7 @@
                     false,
                     "",  //$NON-NLS-1$
                     "", //$NON-NLS-1$
-                    new TextValueEditor() // TODO: IntegerValueEditor
+                    new IntegerValueEditor()
                 ),
                 
                 // restrictedBy { { type 10.11.12, valuesIn ou }, { valuesIn cn, type 11.12.13  } }
@@ -118,7 +124,7 @@
                     true,
                     "",  //$NON-NLS-1$
                     "", //$NON-NLS-1$
-                    new TextValueEditor() // TODO: RestrictedByValueEditor
+                    new RestrictedByValueEditor()
                 ),
                 
                 // classes and : { item: xyz , or:{item:X,item:Y}   }

Modified: directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemSourceEditorComposite.java
URL: http://svn.apache.org/viewvc/directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemSourceEditorComposite.java?view=diff&rev=524677&r1=524676&r2=524677
==============================================================================
--- directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemSourceEditorComposite.java (original)
+++ directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemSourceEditorComposite.java Sun Apr  1 13:35:23 2007
@@ -26,7 +26,6 @@
 import org.apache.directory.ldapstudio.aciitemeditor.Activator;
 import org.apache.directory.shared.ldap.aci.ACIItem;
 import org.apache.directory.shared.ldap.aci.ACIItemParser;
-import org.eclipse.jface.dialogs.MessageDialog;
 import org.eclipse.jface.resource.JFaceResources;
 import org.eclipse.jface.text.Document;
 import org.eclipse.jface.text.IDocument;
@@ -35,13 +34,8 @@
 import org.eclipse.jface.text.source.SourceViewer;
 import org.eclipse.jface.text.source.SourceViewerConfiguration;
 import org.eclipse.swt.SWT;
-import org.eclipse.swt.events.SelectionAdapter;
-import org.eclipse.swt.events.SelectionEvent;
 import org.eclipse.swt.graphics.Font;
 import org.eclipse.swt.layout.FillLayout;
-import org.eclipse.swt.layout.GridData;
-import org.eclipse.swt.layout.GridLayout;
-import org.eclipse.swt.widgets.Button;
 import org.eclipse.swt.widgets.Composite;
 
 
@@ -143,6 +137,10 @@
     public String getInput() throws ParseException
     {
         String input = forceGetInput();
+        
+        // strip new lines
+        input = input.replaceAll( "\\n", " " );
+        input = input.replaceAll( "\\r", " " );
 
         ACIItemParser parser = Activator.getDefault().getACIItemParser();
         ACIItem aciItem = parser.parse( input );

Modified: directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemUserClassesComposite.java
URL: http://svn.apache.org/viewvc/directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemUserClassesComposite.java?view=diff&rev=524677&r1=524676&r2=524677
==============================================================================
--- directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemUserClassesComposite.java (original)
+++ directory/ldapstudio/trunk/ldapstudio-aciitemeditor/src/main/java/org/apache/directory/ldapstudio/aciitemeditor/widgets/ACIItemUserClassesComposite.java Sun Apr  1 13:35:23 2007
@@ -29,8 +29,8 @@
 import org.apache.directory.ldapstudio.aciitemeditor.ACIItemValueWithContext;
 import org.apache.directory.ldapstudio.aciitemeditor.Activator;
 import org.apache.directory.ldapstudio.aciitemeditor.dialogs.MultiValuedDialog;
-import org.apache.directory.ldapstudio.aciitemeditor.model.UserClassWrapperFactory;
 import org.apache.directory.ldapstudio.aciitemeditor.model.UserClassWrapper;
+import org.apache.directory.ldapstudio.aciitemeditor.model.UserClassWrapperFactory;
 import org.apache.directory.ldapstudio.browser.ui.valueeditors.AbstractDialogStringValueEditor;
 import org.apache.directory.shared.ldap.aci.ProtectedItem;
 import org.apache.directory.shared.ldap.aci.UserClass;