-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathStreamingClassOperatorResponse.cs
124 lines (110 loc) · 3.81 KB
/
StreamingClassOperatorResponse.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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
using System.Collections.Generic;
using System.Diagnostics.CodeAnalysis;
using Arcane.Operator.Models.Common;
using Arcane.Operator.Models.StreamClass.Base;
using Arcane.Operator.Models.StreamStatuses.StreamStatus.V1Beta1;
namespace Arcane.Operator.Models;
/// <summary>
/// Possible stream states.
/// </summary>
public enum StreamClassPhase
{
/// <summary>
/// An initial state of the StreamClass object.
/// </summary>
INITIALIZING,
/// <summary>
/// A ready streaming class is ready to be used and new Streams of this class can be created.
/// </summary>
READY,
/// <summary>
/// An error occured in stream class controller and new Streams of this class can not be created.
/// </summary>
FAILED,
/// <summary>
/// The stream class is stopped and new Streams of this class can not be created.
/// </summary>
STOPPED
}
/// <summary>
/// The StreamClassPhase extension methods.
/// </summary>
public static class StreamClassPhaseExtensions
{
/// <summary>
/// Returns True if the lifecycle phase is final.
/// </summary>
/// <param name="phase">Phase</param>
/// <returns></returns>
public static bool IsFinal(this StreamClassPhase phase)
{
return phase is StreamClassPhase.FAILED or StreamClassPhase.STOPPED;
}
}
/// <summary>
/// Contains response from stream operator that can be used by other services inside the application
/// </summary>
[ExcludeFromCodeCoverage(Justification = "Model")]
public record StreamClassOperatorResponse
{
/// <summary>
/// Affected StreamClass object
/// </summary>
public IStreamClass StreamClass { get; set; }
/// <summary>
/// Latest observed state of the StreamClass object
/// </summary>
public IEnumerable<V1Beta1StreamCondition> Conditions { get; private init; }
/// <summary>
/// StreamClass livecycle phase
/// </summary>
public StreamClassPhase Phase { get; private set; }
/// <summary>
/// Creates a StreamOperatorResponse object for stream with specified identifier, setting it state to RUNNING
/// </summary>
/// <param name="affectedObject">Affected stream class model</param>
public static StreamClassOperatorResponse Ready(IStreamClass affectedObject)
{
return new StreamClassOperatorResponse
{
StreamClass = affectedObject,
Conditions = new[]
{
new V1Beta1StreamCondition { Type = ResourceStatus.READY.ToString(), Status = "True" }
},
Phase = StreamClassPhase.READY
};
}
/// <summary>
/// Creates a StreamOperatorResponse object for stream with specified identifier, setting it state to RUNNING
/// </summary>
/// <param name="affectedObject">Affected stream class model</param>
public static StreamClassOperatorResponse Failed(IStreamClass affectedObject)
{
return new StreamClassOperatorResponse
{
StreamClass = affectedObject,
Conditions = new[]
{
new V1Beta1StreamCondition { Type = ResourceStatus.READY.ToString(), Status = "True" }
},
Phase = StreamClassPhase.FAILED
};
}
/// <summary>
/// Creates a StreamOperatorResponse object for stream with specified identifier, setting it state to RUNNING
/// </summary>
/// <param name="affectedObject">Affected stream class model</param>
public static StreamClassOperatorResponse Stopped(IStreamClass affectedObject)
{
return new StreamClassOperatorResponse
{
StreamClass = affectedObject,
Conditions = new[]
{
new V1Beta1StreamCondition { Type = ResourceStatus.READY.ToString(), Status = "True" }
},
Phase = StreamClassPhase.STOPPED
};
}
}