// Token: 0x060016CE RID: 5838 RVA: 0x00089784 File Offset: 0x00087984
        public static FirstTimeSyncWatermark Create(ExDateTime receivedDate, int changeNumber, bool read)
        {
            FirstTimeSyncWatermark firstTimeSyncWatermark = new FirstTimeSyncWatermark();

            firstTimeSyncWatermark.Update(changeNumber, read, receivedDate);
            return(firstTimeSyncWatermark);
        }
        // Token: 0x060016D0 RID: 5840 RVA: 0x000897A8 File Offset: 0x000879A8
        public object Clone()
        {
            FirstTimeSyncWatermark firstTimeSyncWatermark = (FirstTimeSyncWatermark)this.CustomClone();

            if (this.IcsState != null)
            {
                firstTimeSyncWatermark.IcsState = (byte[])this.IcsState.Clone();
            }
            return(firstTimeSyncWatermark);
        }
Пример #3
0
        protected override void UpdateWatermarkFromMinReceivedDate(ExDateTime minReceivedDate)
        {
            FirstTimeSyncWatermark firstTimeSyncWatermark = this.CurFTSMaxWatermark as FirstTimeSyncWatermark;

            if (firstTimeSyncWatermark == null)
            {
                this.CurFTSMaxWatermark = FirstTimeSyncWatermark.Create(minReceivedDate, 0);
                return;
            }
            if (firstTimeSyncWatermark.ReceivedDateUtc == ExDateTime.MinValue || firstTimeSyncWatermark.ReceivedDateUtc > minReceivedDate)
            {
                firstTimeSyncWatermark.Update(0, false, minReceivedDate);
            }
        }
Пример #4
0
        protected override void InitializeAllItemsInFilter(QueryBasedSyncFilter queryBasedSyncFilter)
        {
            FirstTimeSyncProvider firstTimeSyncProvider = this.syncProvider as FirstTimeSyncProvider;

            if (firstTimeSyncProvider != null)
            {
                ExTraceGlobals.SyncProcessTracer.Information((long)this.GetHashCode(), "FirstTimeFolderSync.InitializeAllItemsInFilter.  Using FTS Provider");
                queryBasedSyncFilter.EntriesInFilter.Clear();
                FirstTimeSyncWatermark minWatermark = firstTimeSyncProvider.GetNewFirstTimeSyncWatermark() as FirstTimeSyncWatermark;
                if (Command.CurrentCommand != null)
                {
                    Command.CurrentCommand.ProtocolLogger.SetProviderSyncType(this.CollectionId, ProviderSyncType.FCS);
                    Command.CurrentCommand.Context.SetDiagnosticValue(AirSyncConditionalHandlerSchema.FilterChangeSync, true);
                    if (base.IsFirstSyncScenario)
                    {
                        Command.CurrentCommand.Context.SetDiagnosticValue(AirSyncConditionalHandlerSchema.InitialSync, true);
                    }
                }
                firstTimeSyncProvider.FirstTimeSync(null, minWatermark, queryBasedSyncFilter.FilterQuery, -1, queryBasedSyncFilter.EntriesInFilter);
                return;
            }
            ExTraceGlobals.SyncProcessTracer.Information((long)this.GetHashCode(), "FirstTimeFolderSync.InitializeAllItemsInFilter.  Using Old Provider");
            base.InitializeAllItemsInFilter(queryBasedSyncFilter);
        }
 // Token: 0x060016CC RID: 5836 RVA: 0x00089751 File Offset: 0x00087951
 public static FirstTimeSyncWatermark CreateNew()
 {
     return(FirstTimeSyncWatermark.Create(ExDateTime.MinValue, -1));
 }
        // Token: 0x060016D4 RID: 5844 RVA: 0x0008988C File Offset: 0x00087A8C
        public override bool Equals(object thatObject)
        {
            FirstTimeSyncWatermark firstTimeSyncWatermark = thatObject as FirstTimeSyncWatermark;

            return(firstTimeSyncWatermark != null && this.ReceivedDateUtc == firstTimeSyncWatermark.ReceivedDateUtc);
        }
        // Token: 0x060016D2 RID: 5842 RVA: 0x0008980C File Offset: 0x00087A0C
        public int CompareTo(object thatObject)
        {
            FirstTimeSyncWatermark firstTimeSyncWatermark = thatObject as FirstTimeSyncWatermark;

            return(ExDateTime.Compare(this.ReceivedDateUtc, (firstTimeSyncWatermark == null) ? ExDateTime.MinValue : firstTimeSyncWatermark.ReceivedDateUtc));
        }
Пример #8
0
        internal static QueryResult GetPositionedQueryResult(Folder folderToQuery, StoreObjectId abqMailId, FirstTimeSyncWatermark minWatermark, ExDateTime?filterCutoffDate, ICollection <PropertyDefinition> propDefs, bool trackAssociatedMessageChanges, out int rowsToFetch)
        {
            AirSyncDiagnostics.TraceDebug <string, string, string>(ExTraceGlobals.SyncProcessTracer, null, "[FirstTimeSyncProvider.GetPositionedQueryResult] Folder: {0}, filterCutoffDate: {1}, minWatermark: {2}", folderToQuery.DisplayName, (filterCutoffDate != null) ? filterCutoffDate.Value.ToString() : "<NULL>", minWatermark.IsNew ? "<NEW>" : minWatermark.ReceivedDateUtc.ToString());
            ComparisonFilter comparisonFilter = null;

            rowsToFetch = -1;
            if (abqMailId != null)
            {
                AirSyncDiagnostics.TraceDebug <StoreObjectId>(ExTraceGlobals.SyncProcessTracer, null, "[FirstTimeSyncProvider.GetPositionedQueryResult] ABQMail Id is not null.  Limiting result set to item: {0}", abqMailId);
                comparisonFilter = new ComparisonFilter(ComparisonOperator.Equal, ItemSchema.Id, abqMailId);
                rowsToFetch      = 1;
            }
            else if (!minWatermark.IsNew)
            {
                AirSyncDiagnostics.TraceDebug <ExDateTime>(ExTraceGlobals.SyncProcessTracer, null, "[FirstTimeSyncProvider.GetPositionedQueryResult] Watermark is not new. Starting watermark received date: {0}", minWatermark.ReceivedDateUtc);
                comparisonFilter = new ComparisonFilter(ComparisonOperator.LessThanOrEqual, ItemSchema.ReceivedTime, minWatermark.ReceivedDateUtc);
            }
            else
            {
                AirSyncDiagnostics.TraceDebug(ExTraceGlobals.SyncProcessTracer, null, "[FirstTimeSyncProvider.GetPositionedQueryResult] Watermark is NEW.");
            }
            SortBy[]    sortColumns = FirstTimeSyncProvider.newestFirstSortOrder;
            QueryResult queryResult = null;
            bool        flag        = false;

            try
            {
                ItemQueryType itemQueryType = ItemQueryType.None;
                if (trackAssociatedMessageChanges)
                {
                    itemQueryType |= ItemQueryType.Associated;
                }
                queryResult = folderToQuery.ItemQuery(itemQueryType, null, sortColumns, propDefs);
                if (comparisonFilter != null)
                {
                    if (!queryResult.SeekToCondition(SeekReference.OriginBeginning, comparisonFilter))
                    {
                        AirSyncDiagnostics.TraceDebug(ExTraceGlobals.SyncProcessTracer, null, "[FirstTimeSyncProvider.GetPositionedQueryResult] Did not find any matching items for our initial seekToFilter.");
                        rowsToFetch = 0;
                        flag        = true;
                        return(queryResult);
                    }
                    AirSyncDiagnostics.TraceDebug <int, int>(ExTraceGlobals.SyncProcessTracer, null, "[FirstTimeSyncProvider.GetPositionedQueryResult] Done seeking to condition.  Current Row: {0}, Estimated Row Count: {1}", queryResult.CurrentRow, queryResult.EstimatedRowCount);
                }
                else
                {
                    AirSyncDiagnostics.TraceDebug(ExTraceGlobals.SyncProcessTracer, null, "[FirstTimeSyncProvider.GetPositionedQueryResult] No seekToFilter, positioning at beginning.");
                    queryResult.SeekToOffset(SeekReference.OriginBeginning, 0);
                }
                if (abqMailId == null)
                {
                    int currentRow = queryResult.CurrentRow;
                    if (filterCutoffDate != null && currentRow >= 0)
                    {
                        ComparisonFilter seekFilter = new ComparisonFilter(ComparisonOperator.LessThan, ItemSchema.ReceivedTime, filterCutoffDate.Value);
                        bool             flag2      = queryResult.SeekToCondition(SeekReference.OriginCurrent, seekFilter);
                        int num = queryResult.CurrentRow - (flag2 ? 1 : 0);
                        rowsToFetch = num - currentRow + 1;
                        if (rowsToFetch < 0)
                        {
                            rowsToFetch = 0;
                        }
                        AirSyncDiagnostics.TraceDebug <bool, int>(ExTraceGlobals.SyncProcessTracer, null, "[FirstTimeSyncProvider.GetPositionedQueryResult] Finding ending condition. Found? {0}.  Rows to fetch: {1}", flag2, rowsToFetch);
                        queryResult.SeekToOffset(SeekReference.OriginBeginning, currentRow);
                    }
                }
                flag = true;
            }
            finally
            {
                if (!flag && queryResult != null)
                {
                    queryResult.Dispose();
                }
            }
            return(queryResult);
        }
Пример #9
0
 private QueryResult GetPositionedQueryResult(FirstTimeSyncWatermark minWatermark, ExDateTime?filterCutoffDate, ICollection <PropertyDefinition> propDefs, out int rowsToFetch)
 {
     return(FirstTimeSyncProvider.GetPositionedQueryResult(this.folder, this.ABQMailId, minWatermark, filterCutoffDate, propDefs, this.trackAssociatedMessageChanges, out rowsToFetch));
 }
Пример #10
0
 public ISyncWatermark GetNewFirstTimeSyncWatermark()
 {
     return(FirstTimeSyncWatermark.CreateNew());
 }
Пример #11
0
        public bool FirstTimeSync(Dictionary <ISyncItemId, FolderSync.ClientStateInformation> clientManifest, FirstTimeSyncWatermark minWatermark, QueryFilter filter, int numOperations, Dictionary <ISyncItemId, ServerManifestEntry> newServerManifest)
        {
            ExDateTime receivedDateUtc = minWatermark.ReceivedDateUtc;

            if (numOperations < 0 && numOperations != -1)
            {
                throw new ArgumentException("numOperations is not valid, value = " + numOperations);
            }
            AirSyncDiagnostics.TraceInfo <int, QueryFilter>(ExTraceGlobals.SyncProcessTracer, this, "FirstTimeSyncProvider.FirstTimeSync. numOperations = {0} filter = {1}", numOperations, filter);
            ExDateTime?            filterTypeBoundary     = this.GetFilterTypeBoundary(filter);
            MailboxSyncPropertyBag mailboxSyncPropertyBag = new MailboxSyncPropertyBag(FirstTimeSyncProvider.newQueryProps);

            if (filter != null)
            {
                mailboxSyncPropertyBag.AddColumnsFromFilter(filter);
            }
            int num;

            using (QueryResult positionedQueryResult = this.GetPositionedQueryResult(minWatermark, filterTypeBoundary, mailboxSyncPropertyBag.Columns, out num))
            {
                bool flag = false;
                while (!flag)
                {
                    if (newServerManifest.Count >= numOperations && numOperations > 0)
                    {
                        return(!flag);
                    }
                    int num2;
                    if (numOperations == -1)
                    {
                        num2 = 10000;
                    }
                    else
                    {
                        int num3 = numOperations - newServerManifest.Count;
                        num2 = num3 + 1;
                    }
                    if (num2 < 0)
                    {
                        throw new InvalidOperationException(ServerStrings.ExNumberOfRowsToFetchInvalid(num2.ToString()));
                    }
                    bool flag2 = false;
                    if (num >= 0 && num < num2)
                    {
                        AirSyncDiagnostics.TraceDebug <int, int>(ExTraceGlobals.SyncProcessTracer, this, "[FirstTimeSyncProvier.FirstTimeSync] Limiting rows to fetch based on end filter. Original value: {0}, Filter Based Value: {1}", num2, num + 1);
                        num2  = num;
                        flag2 = true;
                    }
                    if (num2 <= 0)
                    {
                        AirSyncDiagnostics.TraceDebug(ExTraceGlobals.SyncProcessTracer, this, "[FirstTimeSyncProvider.FirstTimeSync] No more rows to fetch. Bailing out.");
                        flag = true;
                        return(false);
                    }
                    AirSyncDiagnostics.TraceInfo <int>(ExTraceGlobals.SyncProcessTracer, this, "FirstTimeSyncProvider.FirstTimeSync. Asking queryResult for {0} rows", num2);
                    IStorePropertyBag[] propertyBags = positionedQueryResult.GetPropertyBags(num2);
                    AirSyncDiagnostics.TraceInfo <int>(ExTraceGlobals.SyncProcessTracer, this, "FirstTimeSyncProvider.FirstTimeSync. Retrieved {0} rows", propertyBags.Length);
                    if (num > -1)
                    {
                        num -= propertyBags.Length;
                    }
                    flag = (propertyBags.Length == 0 || (flag2 && num == 0));
                    if (propertyBags.Length < num2)
                    {
                        flag |= (positionedQueryResult.CurrentRow == positionedQueryResult.EstimatedRowCount);
                    }
                    for (int i = 0; i < propertyBags.Length; i++)
                    {
                        VersionedId       versionedId      = null;
                        IStorePropertyBag storePropertyBag = propertyBags[i];
                        try
                        {
                            if (numOperations != -1 && newServerManifest.Count >= numOperations)
                            {
                                return(true);
                            }
                            if (!this.TryGetPropertyFromBag <VersionedId>(storePropertyBag, ItemSchema.Id, out versionedId))
                            {
                                AirSyncDiagnostics.TraceError(ExTraceGlobals.SyncProcessTracer, this, "[FirstTimeSyncProvider.FirstTimeSync] Could not get versioned Id from property bag.  Skipping item.");
                            }
                            else
                            {
                                ExDateTime exDateTime;
                                bool       flag3 = this.TryGetPropertyFromBag <ExDateTime>(storePropertyBag, ItemSchema.ReceivedTime, out exDateTime);
                                if (!flag3 && filterTypeBoundary != null)
                                {
                                    AirSyncDiagnostics.TraceDebug <string, string>(ExTraceGlobals.SyncProcessTracer, this, "FirstTimeSyncProvider.FirstTimeSync. Found item with missing/corrupt DateTimeReceived. Bailing out of FirstTimeSync mode. Mailbox: {0} ItemId: {1}", this.folder.Session.MailboxOwner.MailboxInfo.PrimarySmtpAddress.ToString(), versionedId.ObjectId.ToBase64String());
                                    flag = true;
                                    return(false);
                                }
                                ExDateTime value = exDateTime;
                                if (!flag3 && !this.TryGetPropertyFromBag <ExDateTime>(storePropertyBag, StoreObjectSchema.CreationTime, out value))
                                {
                                    AirSyncDiagnostics.TraceDebug <string, string>(ExTraceGlobals.SyncProcessTracer, this, "FirstTimeSyncProvider.FirstTimeSync. Found item with missing/corrupt CreationDate. Will use DateTime.MinValue instead.  Mailbox: {0}, ItemId: {1}", this.folder.Session.MailboxOwner.MailboxInfo.PrimarySmtpAddress.ToString(), versionedId.ObjectId.ToBase64String());
                                }
                                if (filterTypeBoundary != null && exDateTime < filterTypeBoundary)
                                {
                                    AirSyncDiagnostics.TraceDebug <ExDateTime>(ExTraceGlobals.SyncProcessTracer, this, "[FirstTimeSyncProvider.FirstTimeSync]  Passed our sync cutoff date of {0}. All rows fetched.", filterTypeBoundary.Value);
                                    flag = true;
                                    return(false);
                                }
                                int num4;
                                if (!this.TryGetPropertyFromBag <int>(storePropertyBag, ItemSchema.ArticleId, out num4))
                                {
                                    AirSyncDiagnostics.TraceDebug <VersionedId>(ExTraceGlobals.SyncProcessTracer, this, "[FirstTimeSyncProvider.FirstTimeSync] Unable to get articleId from property bag item. Id: {0}", versionedId);
                                }
                                else
                                {
                                    ISyncItemId syncItemId = MailboxSyncItemId.CreateForNewItem(versionedId.ObjectId);
                                    FolderSync.ClientStateInformation clientStateInformation;
                                    if (clientManifest != null && clientManifest.TryGetValue(syncItemId, out clientStateInformation) && clientStateInformation.ClientHasItem)
                                    {
                                        AirSyncDiagnostics.TraceDebug <string>(ExTraceGlobals.SyncProcessTracer, this, "[FirstTimeSyncProvider.FirstTimeSync] Skipping item {0} because it is already in client manifest.", syncItemId.NativeId.ToString());
                                        minWatermark.ChangeNumber    = num4;
                                        minWatermark.ReceivedDateUtc = exDateTime;
                                    }
                                    else if (filter != null && !EvaluatableFilter.Evaluate(filter, storePropertyBag))
                                    {
                                        AirSyncDiagnostics.TraceInfo <StoreObjectId, ExDateTime, int>(ExTraceGlobals.SyncTracer, this, "[FirstTimeSyncProvider.FirstTimeSync] Dropping item '{0}' because it failed to match our filter. ReceivedDateUtc: {1}, ChangeNumber: {2}", versionedId.ObjectId, exDateTime, num4);
                                        minWatermark.ChangeNumber    = num4;
                                        minWatermark.ReceivedDateUtc = exDateTime;
                                    }
                                    else
                                    {
                                        bool read;
                                        if (!this.TryGetPropertyFromBag <bool>(storePropertyBag, MessageItemSchema.IsRead, out read))
                                        {
                                            AirSyncDiagnostics.TraceDebug(ExTraceGlobals.SyncProcessTracer, this, "[FirstTimeSyncProvider.FirstTimeSync] Unabled to get read flag from property bag. Default to false.");
                                            read = false;
                                        }
                                        MailboxSyncWatermark mailboxSyncWatermark = MailboxSyncWatermark.Create();
                                        mailboxSyncWatermark.UpdateWithChangeNumber(num4, read);
                                        AirSyncDiagnostics.TraceInfo(ExTraceGlobals.SyncTracer, this, "FirstTimeSyncProvider.FirstTimeSync. Adding Sync'd item {0} to manifest", new object[]
                                        {
                                            syncItemId.NativeId
                                        });
                                        ServerManifestEntry serverManifestEntry = base.CreateItemChangeManifestEntry(syncItemId, mailboxSyncWatermark);
                                        ConversationId      conversationId      = null;
                                        if (this.TryGetPropertyFromBag <ConversationId>(storePropertyBag, ItemSchema.ConversationId, out conversationId))
                                        {
                                            serverManifestEntry.ConversationId = conversationId;
                                        }
                                        byte[]            bytes;
                                        ConversationIndex index;
                                        if (this.TryGetPropertyFromBag <byte[]>(storePropertyBag, ItemSchema.ConversationIndex, out bytes) && ConversationIndex.TryCreate(bytes, out index) && index != ConversationIndex.Empty && index.Components != null && index.Components.Count == 1)
                                        {
                                            AirSyncDiagnostics.TraceInfo(ExTraceGlobals.SyncTracer, this, "FirstTimeSyncProvider.FirstTimeSync. First message in conversation.", new object[]
                                            {
                                                syncItemId.NativeId
                                            });
                                            serverManifestEntry.FirstMessageInConversation = true;
                                        }
                                        serverManifestEntry.FilterDate = new ExDateTime?(value);
                                        string text;
                                        if (this.TryGetPropertyFromBag <string>(storePropertyBag, StoreObjectSchema.ItemClass, out text))
                                        {
                                            serverManifestEntry.MessageClass = (storePropertyBag[StoreObjectSchema.ItemClass] as string);
                                        }
                                        newServerManifest[serverManifestEntry.Id] = serverManifestEntry;
                                        minWatermark.ChangeNumber    = num4;
                                        minWatermark.ReceivedDateUtc = exDateTime;
                                    }
                                }
                            }
                        }
                        catch (Exception arg)
                        {
                            AirSyncDiagnostics.TraceError <string, Exception>(ExTraceGlobals.SyncTracer, this, "FirstTimeSyncProvider.FirstTimeSync. Caught exception processing item: {0}. Exception: {1}", (versionedId == null) ? "<NULL>" : versionedId.ToBase64String(), arg);
                            throw;
                        }
                    }
                }
            }
            return(false);
        }