Lean  $LEAN_TAG$
UpdateOrderCommand.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 
17 using QuantConnect.Orders;
18 
19 namespace QuantConnect.Commands
20 {
21  /// <summary>
22  /// Represents a command to update an order by id
23  /// </summary>
25  {
26  /// <summary>
27  /// Gets or sets the id of the order to update
28  /// </summary>
29  public int OrderId { get; set; }
30 
31  /// <summary>
32  /// Gets or sets the new quantity, specify null to not update the quantity
33  /// </summary>
34  public decimal? Quantity { get; set; }
35 
36  /// <summary>
37  /// Gets or sets the new limit price, specify null to not update the limit price.
38  /// This will only be used if the order has a limit price (Limit/StopLimit orders)
39  /// </summary>
40  public decimal? LimitPrice { get; set; }
41 
42  /// <summary>
43  /// Gets or sets the new stop price, specify null to not update the stop price.
44  /// This will onky be used if the order has a stop price (StopLimit/StopMarket orders)
45  /// </summary>
46  public decimal? StopPrice { get; set; }
47 
48  /// <summary>
49  /// Gets or sets the new tag for the order, specify null to not update the tag
50  /// </summary>
51  public string Tag { get; set; }
52 
53  /// <summary>
54  /// Runs this command against the specified algorithm instance
55  /// </summary>
56  /// <param name="algorithm">The algorithm to run this command against</param>
57  public override CommandResultPacket Run(IAlgorithm algorithm)
58  {
59  var ticket = algorithm.Transactions.UpdateOrder(new UpdateOrderRequest(algorithm.UtcTime, OrderId, new UpdateOrderFields
60  {
61  Quantity = Quantity,
62  LimitPrice = LimitPrice,
63  StopPrice = StopPrice,
64  Tag = Tag
65  }));
66 
67  var response = ticket.GetMostRecentOrderResponse();
68  return new CommandResultPacket(this, response.IsSuccess);
69  }
70  }
71 }