-
Notifications
You must be signed in to change notification settings - Fork 55
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
#636 - JetStream Batch Get Client support
* Added batch get contract
- Loading branch information
1 parent
a86b4a8
commit ae90e37
Showing
2 changed files
with
90 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
80 changes: 80 additions & 0 deletions
80
src/NATS.Client.JetStream/Models/StreamMsgBatchGetRequest.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
using System.ComponentModel.DataAnnotations; | ||
using System.Text.Json.Serialization; | ||
|
||
namespace NATS.Client.JetStream.Models; | ||
|
||
/// <summary> | ||
/// A request to the JetStream $JS.API.STREAM.MSG.GET API | ||
/// </summary> | ||
public record StreamMsgBatchGetRequest | ||
{ | ||
/// <summary> | ||
/// The maximum amount of messages to be returned for this request | ||
/// </summary> | ||
[JsonPropertyName("batch")] | ||
[JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingDefault)] | ||
[Range(-1, int.MaxValue)] | ||
public int Batch { get; set; } | ||
|
||
/// <summary> | ||
/// The maximum amount of returned bytes for this request. | ||
/// </summary> | ||
[JsonPropertyName("max_bytes")] | ||
[JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingDefault)] | ||
[Range(-1, int.MaxValue)] | ||
public int MaxBytes { get; set; } | ||
|
||
/// <summary> | ||
/// The minimum sequence for returned message | ||
/// </summary> | ||
[JsonPropertyName("seq")] | ||
[JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingDefault)] | ||
[Range(ulong.MinValue, ulong.MaxValue)] | ||
public ulong MinSequence { get; set; } | ||
|
||
/// <summary> | ||
/// The minimum start time for returned message | ||
/// </summary> | ||
[JsonPropertyName("start_time")] | ||
[JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingDefault)] | ||
[Range(ulong.MinValue, ulong.MaxValue)] | ||
public DateTime StartTime { get; set; } | ||
|
||
/// <summary> | ||
/// The subject used filter messages that should be returned | ||
/// </summary> | ||
[JsonPropertyName("next_by_subj")] | ||
[JsonIgnore(Condition = JsonIgnoreCondition.Never)] | ||
[Required] | ||
#if NET6_0 | ||
public string Subject { get; set; } = default!; | ||
#else | ||
#pragma warning disable SA1206 | ||
public required string Subject { get; set; } | ||
|
||
#pragma warning restore SA1206 | ||
#endif | ||
|
||
/// <summary> | ||
/// Return last messages mathing the subjects | ||
/// </summary> | ||
[JsonPropertyName("multi_last")] | ||
[JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingDefault)] | ||
[Range(ulong.MinValue, ulong.MaxValue)] | ||
public string[] LastBySubjects { get; set; } = []; | ||
|
||
/// <summary> | ||
/// Return message after sequence | ||
/// </summary> | ||
[JsonPropertyName("up_to_seq")] | ||
[JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingDefault)] | ||
[Range(ulong.MinValue, ulong.MaxValue)] | ||
public ulong UpToSequence { get; set; } | ||
|
||
/// <summary> | ||
/// Return message after time | ||
/// </summary> | ||
[JsonPropertyName("up_to_time")] | ||
[JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingDefault)] | ||
public DateTimeOffset UpToTime { get; set; } | ||
} |