From 428d828ca640d1348979f9982d1c0bc0a489a3b4 Mon Sep 17 00:00:00 2001 From: Andrew Branson Date: Thu, 12 Dec 2013 14:13:36 +0100 Subject: Properties preserve and respect the PropertyDescription 'isMutable' property. This setting prevents the WriteProperty predefined step from changing the property value when isMutable is false. WriteProperty also requires the selected property to already exist - they should be created either during Item instantiation or using AddC2KObject. LDAPPropertyManager prepends the Property name in its entries with ! if they are non mutable. Various places around the kernel that create properties now set the mutable field. Fixes #150 --- src/main/java/com/c2kernel/property/Property.java | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) (limited to 'src/main/java/com/c2kernel/property/Property.java') diff --git a/src/main/java/com/c2kernel/property/Property.java b/src/main/java/com/c2kernel/property/Property.java index 3022cc5..6b7c4ee 100644 --- a/src/main/java/com/c2kernel/property/Property.java +++ b/src/main/java/com/c2kernel/property/Property.java @@ -17,6 +17,7 @@ public class Property implements C2KLocalObject { private String mName; private String mValue; + private boolean mMutable = true; /************************************************************************** @@ -24,18 +25,17 @@ public class Property implements C2KLocalObject **************************************************************************/ public Property() { - setName( "" ); - setValue( "" ); } /************************************************************************** * **************************************************************************/ - public Property( String name, String value ) + public Property( String name, String value, boolean mutable ) { setName( name ); setValue( value ); + setMutable( mutable ); } /************************************************************************** @@ -48,7 +48,17 @@ public class Property implements C2KLocalObject } - /************************************************************************** + public boolean isMutable() { + return mMutable; + } + + + public void setMutable(boolean mMutable) { + this.mMutable = mMutable; + } + + +/************************************************************************** * **************************************************************************/ @Override -- cgit v1.2.3