Share via


Example: Distinguished Name for Lotus Notes Connected Data Sources

The distinguished name for Lotus Notes connected data sources must be in a specified format. If the distinguished name is in another format, the management agent will still return the distinguished name in the correct format. However, there is a loss in performance when relying upon the management agent to create the distinguished name because the management agent must create the new distinguished name before synchronizing the it with the metaverse.

To improve the performance of provisioning for Lotus Notes connected data sources, create the distinguished name in the following format: CN=firstnamemiddleinitiallastname/o=certifier,NAB=Notes Address Book

Note  The first name, middle initial, and last names of the user are separated by a space.

Name Description
firstname The first name of the user.
middleinitial The middle initial of the user.
lastname The last name of the user.
certifier The organizational unit (OU) name of the certifier.
Notes Address Book The file name of the Notes Address Book. If you are referencing a file that is located in a folder for the value, use a forward slash (/) to separate the folder from the file name. For example, folder/file name.CSEntry.DN

The following example is the distinguished name of Jeff Smith in the main organizational unit with a Notes Address Book file, Names.nsf.

"CN=Jeff Smith/o=main,NAB=names.nsf"

The following Visual Basic .NET example shows how to create a distinguished name for a user by using the identification file that is stored in the MADATA folder.

    Public Sub Provision(ByVal mventry As MVEntry) _
        Implements IMVSynchronization.Provision
    
        Dim ManagementAgent As ConnectedMA
        Dim Connectors As Integer
        Dim csentry As CSEntry
        Dim DNName As String
        Dim DNCertifier As String = "O=Main"
    
        If mventry("EmployeeStatus").IsPresent _
            AndAlso mventry("EmployeeStatus").Value.Equals("active") Then
    
            ManagementAgent = mventry.ConnectedMAs("Lotus Notes MA")
            Connectors = ManagementAgent.Connectors.Count
    
            If 0 = Connectors Then
    
                csentry = ManagementAgent.Connectors.StartNewConnector("person")
                DNName = mventry("sn").Value
    
                If mventry("middleName").IsPresent Then
                    DNName = mventry("middleName").Value + " " + DNName
                End If
    
                If mventry("givenName").IsPresent Then
                    DNName = mventry("givenName").Value + " " + DNName
                End If
    
                DNName = DNName + "/" + DNCertifier
    
                ' Set the property values to provision the object.
                csentry.DN = ManagementAgent.EscapeDNComponent("CN=" _
                                + DNName).Concat("NAB=names.nsf")
    
                csentry("LastName").Value = mventry("sn").Value
                csentry("_MMS_Certifier").Value = DNCertifier
                csentry("_MMS_IDRegType").IntegerValue = 1  ' US User
                csentry("_MMS_IDStoreType").IntegerValue = 2  ' ID File as a file
    
                ' The next two properties must have a value for a user with an
                ' identification file.
                csentry("_MMS_IDPath").Value = mventry("cn").Value
                csentry("_MMS_Password").Value = "FilePassword"
    
                ' The next two properties must have a value for a user to access
                ' e-mail through the Lotus Notes client or Web browser.
                csentry("MailServer").Value = "CN=DominoServer/O=DominoDomain"
                csentry("MailFile").Value = "mail\" & mventry("uid").Value
    
                '  Finish creating the new connector.
                csentry.CommitNewConnector()
    
            End If
    
        End If
    
    End Sub
    void IMVSynchronization.Provision (MVEntry mventry)
    {
        ConnectedMA ManagementAgent;
        int Connectors;
        CSEntry csentry;
        string DNName;
        string DNCertifier = "O=Main";
    
        if(mventry["EmployeeStatus"].IsPresent)
        {
            if(mventry["EmployeeStatus"].Value.Equals("active"))
            {
                ManagementAgent = mventry.ConnectedMAs["Lotus Notes MA"];            
                Connectors = ManagementAgent.Connectors.Count;
                
                
                // Create the new connector.
                if(0 == Connectors)
                {            
                    csentry = ManagementAgent.Connectors.StartNewConnector("person");
                    DNName = mventry["sn"].Value; 
    
                    if(mventry["middleName"].IsPresent)
                    {
                        DNName = mventry["middleName"].Value + " " + DNName;
                    }                
    
                    if(mventry["givenName"].IsPresent)
                    {
                        DNName = mventry["givenName"].Value + " " + DNName;
                    }                
    
                    DNName = DNName + "/" + DNCertifier;
                 
                    //  Set the property values to provision the object.
                    csentry.DN = ManagementAgent.EscapeDNComponent("CN="
                                    + DNName).Concat("NAB=names.nsf");
        
                    csentry["LastName"].Value = mventry["sn"].Value;
                    csentry["_MMS_Certifier"].Value = DNCertifier;        
                    csentry["_MMS_IDRegType"].IntegerValue = 1;  // US User        
                    csentry["_MMS_IDStoreType"].IntegerValue = 2;  // ID File as a File
    
                    //  The next two properties must have a value for a user with an
                    //  identification file.
                    csentry["_MMS_IDPath"].Value = mventry["cn"].Value;                
                    csentry["_MMS_Password"].Value = "FilePassword";  
        
                    //  The next two properties must have a value for a user to access
                    //  mail through the Lotus Notes client or Web browser.
                    csentry["MailServer"].Value = "CN=DominoServer/O=DominoDomain";         
                    csentry["MailFile"].Value = @"mail\" + mventry["uid"].Value;
            
                    // Finish creating the new connector.
                    csentry.CommitNewConnector();
                }
            }
        }
    }

Send comments about this topic to Microsoft

Build date: 2/16/2009