X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;ds=sidebyside;f=org.argeo.util%2Fsrc%2Forg%2Fargeo%2Futil%2Fdirectory%2FDirectory.java;h=9e564ced9d339ba1255f23ce3bf389782831454d;hb=285c23f26c4d634cd139d393ebcb708187d5e960;hp=351a608bc53c9c3dbfdb81910c858a54b1a3e56e;hpb=3066d79e3ced9339679672242bdf2340a03e1f29;p=lgpl%2Fargeo-commons.git diff --git a/org.argeo.util/src/org/argeo/util/directory/Directory.java b/org.argeo.util/src/org/argeo/util/directory/Directory.java index 351a608bc..9e564ced9 100644 --- a/org.argeo.util/src/org/argeo/util/directory/Directory.java +++ b/org.argeo.util/src/org/argeo/util/directory/Directory.java @@ -5,34 +5,37 @@ import java.util.Optional; import org.argeo.util.transaction.WorkControl; +/** An information directory (typicylly LDAP). */ public interface Directory extends HierarchyUnit { - /** - * The base of the hierarchy defined by this directory. This could typically be - * an LDAP base DN. - */ - String getContext(); - String getName(); + /** Whether this directory is read only. */ boolean isReadOnly(); + /** Whether this directory is disabled. */ boolean isDisabled(); + /** The realm (typically Kerberos) of this directory. */ Optional getRealm(); + /** Sets the transaction control used by this directory when editing. */ void setTransactionControl(WorkControl transactionControl); /* * METADATA */ + /** Metadata of this directory. */ public Dictionary getProperties(); /* * HIERARCHY */ - + /** The first level of hierarchy units. */ Iterable getDirectHierarchyUnits(boolean functionalOnly); + /** The hierarchy unit at this path. */ HierarchyUnit getHierarchyUnit(String path); + /** Create a new hierarchy unit. */ + HierarchyUnit createHierarchyUnit(String path); }