protected override PrimaryConsistencyCheckResult DetectInconsistencies() { PrimaryConsistencyCheckResult primaryConsistencyCheckResult = PrimaryConsistencyCheckResult.CreateInstance(base.Type, base.Description, true); UserObject userObject; if (base.Context.BaseRole == RoleType.Organizer) { userObject = base.Context.Attendee; if (!Participant.HasSameEmail(base.Context.Organizer.Participant, base.Context.OrganizerItem.Organizer, base.Context.LocalUser.ExchangePrincipal)) { this.FailCheck(primaryConsistencyCheckResult, base.Context.BaseRole, CalendarInconsistencyFlag.Organizer, string.Format("The calendar item is an organizer item, while the mailbox owner ({0}) is not the organizer of the item ({1}).", base.Context.Organizer, base.Context.OrganizerItem.Organizer)); } } else { userObject = base.Context.Organizer; } if (primaryConsistencyCheckResult.Status == CheckStatusType.Passed) { if (DistributionList.IsDL(userObject.RecipientType)) { this.FailCheck(primaryConsistencyCheckResult, base.Context.OppositeRole, CalendarInconsistencyFlag.LargeDL, "Distribution list too large to expand"); } else if (userObject.ExchangePrincipal == null) { this.FailCheck(primaryConsistencyCheckResult, base.Context.BaseRole, CalendarInconsistencyFlag.UserNotFound, "Could not get Exchange principal for " + base.Context.OppositeRole.ToString().ToLower()); } else if (userObject.ExchangePrincipal.MailboxInfo.Location.IsLegacyServer()) { this.FailCheck(primaryConsistencyCheckResult, base.Context.OppositeRole, CalendarInconsistencyFlag.LegacyUser, base.Context.OppositeRole.ToString() + " is on a legacy server."); } else if (base.Context.CalendarInstance != null) { if (!base.Context.CalendarInstance.ShouldProcessMailbox) { primaryConsistencyCheckResult.TerminateCheck("Skipping mailbox that should not be processed by CRA."); } } else { this.FailCheck(primaryConsistencyCheckResult, "Unable to initialize the target session."); } } return(primaryConsistencyCheckResult); }