-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathPageNextTokenResolver.cs
52 lines (45 loc) · 1.87 KB
/
PageNextTokenResolver.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
using System.Linq;
using System.Net.Http;
using Akka.Util;
using Arcane.Framework.Sources.RestApi.Services.PageResolvers.Base;
namespace Arcane.Framework.Sources.RestApi.Services.PageResolvers;
/// <summary>
/// Page offset resolver for pages with next link
/// </summary>
internal class PageNextTokenResolver : PageResolverBase<string>
{
private readonly string[] nextPageTokenPropertyKeyChain;
/// <summary>
/// Page offset resolver for pages with next link
/// </summary>
/// <param name="nextPageTokenPropertyKeyChain">Optional property key chain for resolver property value like total pages or token value.</param>
public PageNextTokenResolver(string[] nextPageTokenPropertyKeyChain)
{
this.nextPageTokenPropertyKeyChain = nextPageTokenPropertyKeyChain;
}
/// <inheritdoc cref="PageResolverBase{TPagePointer}.Next"/>
public override bool Next(Option<HttpResponseMessage> apiResponse)
{
if (!apiResponse.IsEmpty)
{
// exit immediately if next page token property is not present
if (!this.GetResponseContent(apiResponse, this.nextPageTokenPropertyKeyChain).Any())
{
this.pagePointer = null;
return false;
}
// read next page token from response
this.pagePointer = this.nextPageTokenPropertyKeyChain
.Aggregate(this.GetResponse(apiResponse), (je, property) => je.GetProperty(property)).GetString();
// check if we are starting to list pages, or are in the process already, or have finished
return this.pagePointer switch
{
null => false,
_ => true
};
}
// in case of empty response - reset page pointer to empty string and report ready for next
this.pagePointer = string.Empty;
return true;
}
}