Lean  $LEAN_TAG$
OrderEventJsonConverter.cs
1 /*
2  * QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
3  * Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  *
15 */
16 
17 using QuantConnect.Util;
18 
20 {
21  /// <summary>
22  /// Defines how OrderEvents should be serialized to json
23  /// </summary>
24  public class OrderEventJsonConverter : TypeChangeJsonConverter<OrderEvent, SerializedOrderEvent>
25  {
26  private readonly string _algorithmId;
27 
28  /// <summary>
29  /// True will populate TResult object returned by <see cref="Convert(SerializedOrderEvent)"/> with json properties
30  /// </summary>
31  protected override bool PopulateProperties => false;
32 
33  /// <summary>
34  /// Creates a new instance
35  /// </summary>
36  /// <param name="algorithmId">The associated algorithm id, required when serializing</param>
37  public OrderEventJsonConverter(string algorithmId = null)
38  {
39  _algorithmId = algorithmId;
40  }
41 
42  /// <summary>
43  /// Convert the input value to a value to be serialzied
44  /// </summary>
45  /// <param name="value">The input value to be converted before serialziation</param>
46  /// <returns>A new instance of TResult that is to be serialzied</returns>
47  protected override SerializedOrderEvent Convert(OrderEvent value)
48  {
49  return new SerializedOrderEvent(value, _algorithmId);
50  }
51 
52  /// <summary>
53  /// Converts the input value to be deserialized
54  /// </summary>
55  /// <param name="value">The deserialized value that needs to be converted to <see cref="OrderEvent"/></param>
56  /// <returns>The converted value</returns>
57  protected override OrderEvent Convert(SerializedOrderEvent value)
58  {
59  return OrderEvent.FromSerialized(value);
60  }
61  }
62 }