-
Notifications
You must be signed in to change notification settings - Fork 328
Expand file tree
/
Copy pathExecutionStartedEvent.cs
More file actions
142 lines (125 loc) · 4.91 KB
/
Copy pathExecutionStartedEvent.cs
File metadata and controls
142 lines (125 loc) · 4.91 KB
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
// ----------------------------------------------------------------------------------
// Copyright Microsoft Corporation
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// http://www.apache.org/licenses/LICENSE-2.0
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// ----------------------------------------------------------------------------------
namespace DurableTask.Core.History
{
using DurableTask.Core.Tracing;
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Runtime.Serialization;
/// <summary>
/// A history event for orchestration execution starting
/// </summary>
[DataContract]
public class ExecutionStartedEvent : HistoryEvent, ISupportsDurableTraceContext
{
/// <summary>
/// The orchestration instance for this event
/// </summary>
[DataMember] public OrchestrationInstance OrchestrationInstance;
/// <summary>
/// Creates a new ExecutionStartedEvent with the supplied parameters
/// </summary>
/// <param name="eventId">The event id of the history event</param>
/// <param name="input">The serialized orchestration input </param>
public ExecutionStartedEvent(int eventId, string input)
: base(eventId)
{
Input = input;
}
/// <summary>
/// Creates a new ExecutionStartedEvent
/// </summary>
internal ExecutionStartedEvent()
{
}
/// <summary>
/// Creates a new ExecutionStartedEvent with the same fields as <paramref name="other"/>.
/// A deep copy is performed on all non-base class fields.
/// </summary>
internal ExecutionStartedEvent(ExecutionStartedEvent other)
{
// Copy base class fields
EventId = other.EventId;
Timestamp = other.Timestamp;
ExtensionData = other.ExtensionData;
IsPlayed = other.IsPlayed;
// Deep copy all other fields
OrchestrationInstance = other.OrchestrationInstance?.Clone();
ParentInstance = other.ParentInstance?.Clone();
ParentTraceContext = other.ParentTraceContext?.Clone();
Input = other.Input;
Name = other.Name;
Version = other.Version;
Tags = other.Tags != null ? new Dictionary<string, string>(other.Tags) : null;
Correlation = other.Correlation;
ScheduledStartTime = other.ScheduledStartTime;
Generation = other.Generation;
}
/// <summary>
/// Gets the event type
/// </summary>
public override EventType EventType => EventType.ExecutionStarted;
/// <summary>
/// Gets or sets the parent instance of the event
/// </summary>
[DataMember]
public ParentInstance ParentInstance { get; set; }
/// <summary>
/// Gets or sets the orchestration name
/// </summary>
[DataMember]
public string Name { get; set; }
/// <summary>
/// Gets or sets the orchestration version
/// </summary>
[DataMember]
public string Version { get; set; }
/// <summary>
/// Gets or sets the serialized input to the orchestration
/// </summary>
[DataMember]
public string Input { get; set; }
/// <summary>
/// Gets or sets a dictionary of tags of string, string
/// </summary>
[DataMember]
public IDictionary<string, string> Tags { get; set; }
// TODO: Make this property obsolete
/// <summary>
/// Gets or sets the serialized end-to-end correlation state.
/// </summary>
[DataMember]
public string Correlation { get; set; }
/// <summary>
/// The W3C trace context associated with this event.
/// </summary>
[DataMember]
public DistributedTraceContext ParentTraceContext { get; set; }
/// <summary>
/// Gets or sets date to start the orchestration
/// </summary>
[DataMember]
public DateTime? ScheduledStartTime { get; set; }
/// <summary>
/// Gets or sets the generation of the orchestration
/// </summary>
[DataMember]
public int? Generation { get; set; }
// Used for Continue-as-New scenarios
internal void SetParentTraceContext(ExecutionStartedEvent parent)
{
this.ParentTraceContext = parent.ParentTraceContext;
}
}
}