Example #1
0
        protected virtual StoreSession CreateStoreConnection(MailboxConnectFlags mailboxConnectFlags)
        {
            MrsTracer.Provider.Function("StorageMailbox.CreateStoreConnection", new object[0]);
            base.CheckDisposed();
            if (!base.IsRestore)
            {
                Guid guid = base.IsArchiveMailbox ? base.MbxArchiveMdbGuid : base.MbxHomeMdbGuid;
                if (mailboxConnectFlags.HasFlag(MailboxConnectFlags.NonMrsLogon) && base.TestIntegration.GetIntValueAndDecrement("InjectNFaultsTargetConnectivityVerification", 0, 0, 2147483647) > 0)
                {
                    guid = new Guid("F00DBABE-0000-0000-0000-000000000000");
                }
                if (base.MdbGuid != guid)
                {
                    MrsTracer.Provider.Warning("Source mailbox does not exist or is in the wrong database.", new object[0]);
                    throw new MailboxIsNotInExpectedMDBPermanentException(guid);
                }
            }
            MrsTracer.Provider.Debug("Opening StoreSession: mailbox=\"{0}\"", new object[]
            {
                base.TraceMailboxId
            });
            StoreSession result;

            try
            {
                using (base.RHTracker.Start())
                {
                    ADSessionSettings adsessionSettings = (base.PartitionHint != null) ? ADSessionSettings.FromTenantPartitionHint(base.PartitionHint) : ADSessionSettings.FromRootOrgScopeSet();
                    adsessionSettings.IncludeSoftDeletedObjects = true;
                    adsessionSettings.IncludeInactiveMailbox    = true;
                    ExchangePrincipal exchangePrincipal;
                    if (base.IsRestore)
                    {
                        exchangePrincipal = ExchangePrincipal.FromMailboxData(base.MailboxGuid, base.MdbGuid, StorageMailbox.CultureInfos);
                    }
                    else
                    {
                        exchangePrincipal = ExchangePrincipal.FromMailboxGuid(adsessionSettings, base.MailboxGuid, base.MdbGuid, RemotingOptions.LocalConnectionsOnly, base.EffectiveDomainControllerName, false);
                    }
                    string text = ((mailboxConnectFlags & MailboxConnectFlags.NonMrsLogon) != MailboxConnectFlags.None) ? "Client=Management" : "Client=MSExchangeMigration";
                    if ((mailboxConnectFlags & MailboxConnectFlags.PublicFolderHierarchyReplication) != MailboxConnectFlags.None)
                    {
                        text = "Client=PublicFolderSystem;Action=PublicFolderHierarchyReplication";
                    }
                    if (base.IsPublicFolderMailbox)
                    {
                        OpenMailboxSessionFlags openMailboxSessionFlags = OpenMailboxSessionFlags.None;
                        if (base.RestoreFlags.HasFlag(MailboxRestoreType.Recovery))
                        {
                            openMailboxSessionFlags |= OpenMailboxSessionFlags.UseRecoveryDatabase;
                        }
                        result = PublicFolderSession.OpenAsMRS(exchangePrincipal, text, openMailboxSessionFlags);
                    }
                    else
                    {
                        MailboxSession.InitializationFlags initializationFlags = MailboxSession.InitializationFlags.None;
                        if (base.IsRestore)
                        {
                            initializationFlags |= MailboxSession.InitializationFlags.OverrideHomeMdb;
                            if (base.RestoreFlags.HasFlag(MailboxRestoreType.Recovery))
                            {
                                initializationFlags |= MailboxSession.InitializationFlags.UseRecoveryDatabase;
                            }
                            if (base.RestoreFlags.HasFlag(MailboxRestoreType.SoftDeleted) || base.RestoreFlags.HasFlag(MailboxRestoreType.Disabled))
                            {
                                initializationFlags |= MailboxSession.InitializationFlags.DisconnectedMailbox;
                            }
                            base.VerifyRestoreSource(mailboxConnectFlags);
                        }
                        if (base.IsFolderMove && this is StorageDestinationMailbox)
                        {
                            initializationFlags |= MailboxSession.InitializationFlags.MoveUser;
                        }
                        if (base.IsOlcSync)
                        {
                            initializationFlags |= MailboxSession.InitializationFlags.OlcSync;
                        }
                        this.PerformPreLogonOperations(exchangePrincipal, mailboxConnectFlags, text);
                        result = MailboxSession.OpenAsMrs(exchangePrincipal, initializationFlags, text);
                    }
                }
            }
            catch (ObjectNotFoundException originalException)
            {
                base.VerifyMdbIsOnline(originalException);
                throw;
            }
            catch (MailboxInTransitException innerException)
            {
                throw this.GetMailboxInTransitException(innerException);
            }
            return(result);
        }