| | | 1 | | using Elsa.Common.Models; |
| | | 2 | | using Elsa.Workflows.Runtime.Entities; |
| | | 3 | | using Elsa.Workflows.Runtime.Filters; |
| | | 4 | | using Elsa.Workflows.Runtime.OrderDefinitions; |
| | | 5 | | |
| | | 6 | | namespace Elsa.Workflows.Runtime; |
| | | 7 | | |
| | | 8 | | /// <summary> |
| | | 9 | | /// Provides access to bookmark queue dead-letter items. |
| | | 10 | | /// </summary> |
| | | 11 | | public interface IBookmarkQueueDeadLetterStore |
| | | 12 | | { |
| | | 13 | | /// <summary> |
| | | 14 | | /// Adds or updates the specified <see cref="BookmarkQueueDeadLetterItem"/> in the persistence store. |
| | | 15 | | /// </summary> |
| | | 16 | | Task SaveAsync(BookmarkQueueDeadLetterItem record, CancellationToken cancellationToken = default); |
| | | 17 | | |
| | | 18 | | /// <summary> |
| | | 19 | | /// Adds the specified <see cref="BookmarkQueueDeadLetterItem"/> to the persistence store. |
| | | 20 | | /// </summary> |
| | | 21 | | Task AddAsync(BookmarkQueueDeadLetterItem record, CancellationToken cancellationToken = default); |
| | | 22 | | |
| | | 23 | | /// <summary> |
| | | 24 | | /// Adds the specified <see cref="BookmarkQueueDeadLetterItem"/> to the persistence store or returns the existing it |
| | | 25 | | /// </summary> |
| | | 26 | | async Task<BookmarkQueueDeadLetterItem> AddOrGetExistingAsync(BookmarkQueueDeadLetterItem record, CancellationToken |
| | | 27 | | { |
| | 0 | 28 | | await AddAsync(record, cancellationToken); |
| | 0 | 29 | | return record; |
| | 0 | 30 | | } |
| | | 31 | | |
| | | 32 | | /// <summary> |
| | | 33 | | /// Adds the specified <see cref="BookmarkQueueDeadLetterItem"/> records to the persistence store or returns existin |
| | | 34 | | /// </summary> |
| | | 35 | | async Task<IReadOnlyCollection<BookmarkQueueDeadLetterItem>> AddOrGetExistingManyAsync(IEnumerable<BookmarkQueueDead |
| | | 36 | | { |
| | 2 | 37 | | var results = new List<BookmarkQueueDeadLetterItem>(); |
| | | 38 | | |
| | 7 | 39 | | foreach (var record in records) |
| | 2 | 40 | | results.Add(await AddOrGetExistingAsync(record, cancellationToken)); |
| | | 41 | | |
| | 1 | 42 | | return results; |
| | 1 | 43 | | } |
| | | 44 | | |
| | | 45 | | /// <summary> |
| | | 46 | | /// Atomically marks a replayable dead-letter item as replayed. |
| | | 47 | | /// </summary> |
| | | 48 | | Task<BookmarkQueueDeadLetterItem?> TryMarkReplayedAsync(string id, string queueItemId, DateTimeOffset replayedAt, Ca |
| | | 49 | | |
| | | 50 | | /// <summary> |
| | | 51 | | /// Returns the first bookmark queue dead-letter item matching the specified filter. |
| | | 52 | | /// </summary> |
| | | 53 | | Task<BookmarkQueueDeadLetterItem?> FindAsync(BookmarkQueueDeadLetterFilter filter, CancellationToken cancellationTok |
| | | 54 | | |
| | | 55 | | /// <summary> |
| | | 56 | | /// Returns a set of bookmark queue dead-letter items matching the specified filter. |
| | | 57 | | /// </summary> |
| | | 58 | | Task<IEnumerable<BookmarkQueueDeadLetterItem>> FindManyAsync(BookmarkQueueDeadLetterFilter filter, CancellationToken |
| | | 59 | | |
| | | 60 | | /// <summary> |
| | | 61 | | /// Returns a page of bookmark queue dead-letter items. |
| | | 62 | | /// </summary> |
| | | 63 | | Task<Page<BookmarkQueueDeadLetterItem>> PageAsync<TOrderBy>(PageArgs pageArgs, BookmarkQueueDeadLetterItemOrder<TOrd |
| | | 64 | | |
| | | 65 | | /// <summary> |
| | | 66 | | /// Returns a page of bookmark queue dead-letter items. |
| | | 67 | | /// </summary> |
| | | 68 | | Task<Page<BookmarkQueueDeadLetterItem>> PageAsync<TOrderBy>(PageArgs pageArgs, BookmarkQueueDeadLetterFilter filter, |
| | | 69 | | |
| | | 70 | | /// <summary> |
| | | 71 | | /// Deletes a set of bookmark queue dead-letter items matching the specified filter. |
| | | 72 | | /// </summary> |
| | | 73 | | Task<long> DeleteAsync(BookmarkQueueDeadLetterFilter filter, CancellationToken cancellationToken = default); |
| | | 74 | | } |