namingContexts containing empty value throws exception on connect
-----------------------------------------------------------------

                 Key: DIRSTUDIO-753
                 URL: https://issues.apache.org/jira/browse/DIRSTUDIO-753
             Project: Directory Studio
          Issue Type: Bug
          Components: studio-connection, studio-ldapbrowser
    Affects Versions: 1.5.3
         Environment: Linux (RHEL 6 x86_64)
            Reporter: Tom Poage
            Priority: Minor


RFC 4512 (sec 5.1.2) suggests that an empty value in the rootDSE operational 
attribute namingContexts is normal, perhaps encouraged in some deployments.

Some LDAP servers, such as recent versions of Sun/Oracle DSEE, can display 
namingContexts containing an empty value.

I can't tell offhand if this is a bug with Directory Studio or JNDI. A sampling 
of other JNDI applications/code tested do not throw an exception on 
encountering the empty value.

E.g.

{code}
ldapsearch -x -LLL -H ldap://myhost.example.org -b '' -s base 'objectClass=*' 
namingContexts
{code}
{noformat)
dn:
namingContexts: dc=example,dc=org
namingContexts:
namingContexts: dc=people,dc=example,dc=org
{noformat}

If an Apache Directory Studio Connection is set to the default of "Get base DNs 
from Root DSE", an exception is thrown on the empty value.
{noformat}
Error while opening connection
 - [LDAP: error code 32 - No Such Object]
  javax.naming.NameNotFoundException: [LDAP: error code 32 - No Such Object]; 
remaining name ''
        at com.sun.jndi.ldap.LdapCtx.mapErrorCode(LdapCtx.java:3112)
        at com.sun.jndi.ldap.LdapCtx.processReturnCode(LdapCtx.java:3033)
        at com.sun.jndi.ldap.LdapCtx.processReturnCode(LdapCtx.java:2840)
        at com.sun.jndi.ldap.LdapCtx.searchAux(LdapCtx.java:1849)
        at com.sun.jndi.ldap.LdapCtx.c_search(LdapCtx.java:1772)
        at 
com.sun.jndi.toolkit.ctx.ComponentDirContext.p_search(ComponentDirContext.java:386)
        at 
com.sun.jndi.toolkit.ctx.PartialCompositeDirContext.search(PartialCompositeDirContext.java:356)
        at 
org.apache.directory.studio.connection.core.io.jndi.JNDIConnectionWrapper$1.run(JNDIConnectionWrapper.java:356)
        at 
org.apache.directory.studio.connection.core.io.jndi.JNDIConnectionWrapper.runAndMonitor(JNDIConnectionWrapper.java:1272)
        at 
org.apache.directory.studio.connection.core.io.jndi.JNDIConnectionWrapper.checkConnectionAndRunAndMonitor(JNDIConnectionWrapper.java:1203)
        at 
org.apache.directory.studio.connection.core.io.jndi.JNDIConnectionWrapper.search(JNDIConnectionWrapper.java:398)
        at 
org.apache.directory.studio.ldapbrowser.core.jobs.SearchRunnable.search(SearchRunnable.java:500)
        at 
org.apache.directory.studio.ldapbrowser.core.jobs.SearchRunnable.searchAndUpdateModel(SearchRunnable.java:320)
        at 
org.apache.directory.studio.ldapbrowser.core.jobs.InitializeRootDSERunnable.searchRootDseEntries(InitializeRootDSERunnable.java:377)
        at 
org.apache.directory.studio.ldapbrowser.core.jobs.InitializeRootDSERunnable.loadRootDSE(InitializeRootDSERunnable.java:250)
        at 
org.apache.directory.studio.ldapbrowser.core.jobs.InitializeAttributesRunnable.initializeAttributes(InitializeAttributesRunnable.java:217)
        at 
org.apache.directory.studio.ldapbrowser.core.jobs.InitializeAttributesRunnable.initializeAttributes(InitializeAttributesRunnable.java:195)
        at 
org.apache.directory.studio.ldapbrowser.core.BrowserConnectionListener.openBrowserConnection(BrowserConnectionListener.java:118)
        at 
org.apache.directory.studio.ldapbrowser.core.BrowserConnectionListener.connectionOpened(BrowserConnectionListener.java:65)
        at 
org.apache.directory.studio.connection.core.jobs.OpenConnectionsRunnable.runNotification(OpenConnectionsRunnable.java:132)
        at 
org.apache.directory.studio.connection.core.jobs.StudioConnectionJob.run(StudioConnectionJob.java:120)
        at org.eclipse.core.internal.jobs.Worker.run(Worker.java:55)

  [LDAP: error code 32 - No Such Object]
{noformat}

A partial workaround is relatively easy: specify a Base DN in the Connection 
Browser Options

Does it make sense for Directory Studio to ignore the empty value -- or at 
least not throw the exception -- since RootDSE is already a "standard" location?

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: 
https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

Reply via email to