-
Notifications
You must be signed in to change notification settings - Fork 33
/
TicketFilter.cs
105 lines (91 loc) 路 3.84 KB
/
TicketFilter.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
锘縰sing NSwag.Annotations;
using Tzkt.Api.Services;
namespace Tzkt.Api
{
public class TicketFilter : INormalizable
{
/// <summary>
/// Filter by internal TzKT id.
/// Click on the parameter to expand more details.
/// </summary>
public Int64Parameter id { get; set; }
/// <summary>
/// Filter by ticketer address.
/// Click on the parameter to expand more details.
/// </summary>
public AccountParameter ticketer { get; set; }
/// <summary>
/// Filter by ticket content type in Micheline format.
/// Click on the parameter to expand more details.
/// </summary>
public MichelineParameter rawType { get; set; }
/// <summary>
/// Filter by ticket content in Micheline format.
/// Click on the parameter to expand more details.
/// </summary>
public MichelineParameter rawContent { get; set; }
/// <summary>
/// Filter by ticket content in JSON format.
/// Note, this parameter supports the following format: `content{.path?}{.mode?}=...`,
/// so you can specify a path to a particular field to filter by (for example, `?content.color.in=red,green`).
/// Click on the parameter to expand more details.
/// </summary>
public JsonParameter content { get; set; }
/// <summary>
/// Filter by 32-bit hash of ticket content type.
/// Click on the parameter to expand more details.
/// </summary>
public Int32Parameter typeHash { get; set; }
/// <summary>
/// Filter by 32-bit hash of ticket content.
/// Click on the parameter to expand more details.
/// </summary>
public Int32Parameter contentHash { get; set; }
/// <summary>
/// Filter by address of the first minter.
/// Click on the parameter to expand more details.
/// </summary>
public AccountParameter firstMinter { get; set; }
/// <summary>
/// Filter by level of the block where the ticket was first seen.
/// Click on the parameter to expand more details.
/// </summary>
public Int32Parameter firstLevel { get; set; }
/// <summary>
/// Filter by timestamp (ISO 8601) of the block where the ticket was first seen.
/// Click on the parameter to expand more details.
/// </summary>
public TimestampParameter firstTime { get; set; }
/// <summary>
/// Filter by level of the block where the ticket was last seen.
/// Click on the parameter to expand more details.
/// </summary>
public Int32Parameter lastLevel { get; set; }
/// <summary>
/// Filter by timestamp (ISO 8601) of the block where the ticket was last seen.
/// Click on the parameter to expand more details.
/// </summary>
public TimestampParameter lastTime { get; set; }
[OpenApiIgnore]
public bool Empty =>
id == null &&
ticketer == null &&
rawType == null &&
rawContent == null &&
content == null &&
typeHash == null &&
contentHash == null &&
firstMinter == null &&
firstLevel == null &&
firstTime == null &&
lastLevel == null &&
lastTime == null;
public string Normalize(string name)
{
return ResponseCacheService.BuildKey("",
("id", id), ("ticketer", ticketer), ("rawType", rawType), ("rawContent", rawContent), ("content", content),
("typeHash", typeHash), ("contentHash", contentHash), ("firstMinter", firstMinter), ("firstLevel", firstLevel),
("firstTime", firstTime), ("lastLevel", lastLevel), ("lastTime", lastTime));
}
}
}