Partager via


Example: Resource Mailbox with Limits

This example shows how to provision an Exchange 2000 or Exchange 2003 resource mailbox object with limits on the amount of disk space the user is allocated to store their messages.

Attribute Inclusion List

You must select the following attributes from the Select Attributes property page for your Active Directory management agent to provision an Exchange resource mailbox:

  • mailNickname
  • homeMDB
  • mDBStorageQuota
  • mDBOverQuotaLimit
  • mDBOverHardQuotaLimit
  • mDBUseDefaults
  • msExchMailboxSecurityDescriptor
  • msExchMasterAccountSid
  • nTSecurityDescriptor
  • userAccountControl

You can provision an Exchange mailbox with a mailbox store quota that limits the amount of disk space that the user is allowed to use to store their mail messages. Once the user exceeds their mailbox store quota, they receive an error message warning them about their excessive space usage, but they can still send and receive messages. You can also provision the mailbox with an overflow quota that adds an additional amount of disk space to store their mail messages. Once the user exceeds the overflow quota, the Exchange server refuses to allow the user to send mail. Finally, you can provision the mailbox with a hard limit on the amount of disk space to store their mail messages. If the user exceeds this hard limit, the Exchange server refuses to allow the user to send or receive mail.

The following example shows how to use a rules extension to provision an Exchange resource mailbox. The mailbox is given a quota of disk space based upon the values of the mDBStorageQuota, mDBOverQuotaLimit, and mDBOverHardQuotaLimit attributes. Be sure to add a reference to logging.dll to use the LogException method.

    Public Sub Provision(ByVal mventry As MVEntry) _
        Implements IMVSynchronization.Provision
    
        Dim adMA As ConnectedMA
        Dim csentry As CSEntry
        Dim nickName, mailboxMDB As String
        Dim dn as ReferenceValue
    
        ' Mailbox limits, in kilobytes
        Dim storeQuota     As Long  ' When reached, Exchange Server issues a warning about the mailbox size
        Dim overQuotaLimit As Long  ' When reached, Exchange Server prohibits sending e-mail from this mailbox
        Dim hardLimit      As Long  ' When reached, Exchange Server prohibits sending and receiving e-mail
    
        ' Security descriptor
        Dim sidString as String
        Dim sid as byte()
    
        try
            adMA = mventry.ConnectedMAs("Fabrikam AD MA")
    
            nickName   = mventry("mailNickname").Value
            mailboxMDB = mventry("homeMDB").Value
    
            storeQuota     = mventry("mDBStorageQuota").IntegerValue
            overQuotaLimit = mventry("mDBOverQuotaLimit").IntegerValue
            hardLimit      = mventry("mDBOverHardQuotaLimit").IntegerValue
    
            sidString  = mventry("msExchMailboxSecurityDescriptor").Value
            sid        = Utils.ConvertStringToSid(sidString)
    
            ' Construct the distinguished name
            dn = adMA.EscapeDNComponent("CN=" + mventry("cn").Value).Concat("ou=mailboxes,dc=fabrikam,dc=com")
    
            If 0 = adMA.Connectors.Count then
                csentry = ExchangeUtils.CreateMailbox(adMA, dn, nickName, mailboxMDB, storeQuota, overQuotaLimit, hardLimit, sid)
            End If
    
            ' Log and rethrow any exception
            Catch ex As Exception
                Logging.Logging.LogException(ex, "Provision", "Caught exception", False)
                Throw
        End Try
    End Sub
    void IMVSynchronization.Provision (MVEntry mventry)
    {
        ConnectedMA adMA;
        CSEntry csentry;
        String nickName, mailboxMDB;
        ReferenceValue dn;
    
        // Mailbox limits, in kilobytes
        long storeQuota;      // When reached, Exchange Server issues a warning about the mailbox size
        long overQuotaLimit;  // When reached, Exchange Server prohibits sending e-mail from this mailbox
        long hardLimit;       // When reached, Exchange Server prohibits sending and receiving e-mail
    
        // Security descriptor
        string sidString;
        byte[] sid;
    
        try
        {
            adMA = mventry.ConnectedMAs["Fabrikam AD MA"];
    
            nickName   = mventry["mailNickname"].Value;
            mailboxMDB = mventry["homeMDB"].Value;
    
            storeQuota     = mventry["mDBStorageQuota"].IntegerValue;
            overQuotaLimit = mventry["mDBOverQuotaLimit"].IntegerValue;
            hardLimit      = mventry["mDBOverHardQuotaLimit"].IntegerValue;
    
            sidString  = mventry["msExchMailboxSecurityDescriptor"].Value;
            sid        = Utils.ConvertStringToSid(sidString);
    
            // Construct the distinguished name
            dn = adMA.EscapeDNComponent("CN=" + mventry["cn"].Value).Concat("ou=mailboxes,dc=fabrikam,dc=com");
    
            if(0 == adMA.Connectors.Count)
            {
                csentry = ExchangeUtils.CreateMailbox(adMA, dn, nickName, mailboxMDB, storeQuota, overQuotaLimit, hardLimit, sid);
            }
        }
    
        // Log and rethrow any exception
        catch(Exception ex)
        {
            Logging.Logging.LogException(ex, "Provision", "Caught exception", false);
            throw;
        }
    }

See Also

CreateMailbox(ConnectedMA,ReferenceValue,String,String,long,long,long,Byte[])

Send comments about this topic to Microsoft

Build date: 2/16/2009