-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathDeltaProcessorBase.cs
64 lines (56 loc) · 2.3 KB
/
DeltaProcessorBase.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
using System;
using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;
using BIT.Data.Sync.EventArgs;
namespace BIT.Data.Sync
{
/// <summary>
/// Base class for delta processors. This class implements the IDeltaProcessor interface and provides a basic implementation.
/// </summary>
public abstract class DeltaProcessorBase : IDeltaProcessor, IDeltaProcessorWithEvents
{
/// <summary>
/// The sequence service used by the delta processor.
/// </summary>
private readonly ISequenceService sequenceService;
public event EventHandler<ProcessingDeltaEventArgs> ProcessingDelta;
public event EventHandler<ProcessedDeltaEventArgs> ProcessedDelta;
/// <summary>
/// Raises the ProcessingDelta event.
/// </summary>
/// <param name="e"></param>
protected virtual void OnProcessingDelta(ProcessingDeltaEventArgs e)
{
ProcessingDelta?.Invoke(this, e);
}
/// <summary>
/// Raises the ProcessedDelta event.
/// </summary>
/// <param name="e"></param>
protected virtual void OnProcessedDelta(ProcessedDeltaEventArgs e)
{
ProcessedDelta?.Invoke(this, e);
}
/// <summary>
/// Gets the sequence service used by the delta processor.
/// </summary>
public ISequenceService SequenceService => sequenceService;
/// <summary>
/// Processes a collection of deltas asynchronously.
/// </summary>
/// <param name="Deltas">The deltas to process.</param>
/// <param name="cancellationToken">A cancellation token that can be used to cancel the operation.</param>
/// <returns>A task that represents the asynchronous operation.</returns>
public abstract Task ProcessDeltasAsync(IEnumerable<IDelta> Deltas, CancellationToken cancellationToken);
/// <summary>
/// Initializes a new instance of the DeltaProcessorBase class with the specified sequence service.
/// </summary>
/// <param name="sequenceService">The sequence service to use for processing deltas.</param>
public DeltaProcessorBase(ISequenceService sequenceService)
{
this.sequenceService = sequenceService;
}
}
}