/* * QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals. * Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect 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. */ using System; namespace QuantConnect.Orders { /// /// Represents a request to submit, update, or cancel an order /// public abstract class OrderRequest { /// /// Gets the type of this order request /// public abstract OrderRequestType OrderRequestType { get; } /// /// Gets the status of this request /// public OrderRequestStatus Status { get; private set; } /// /// Gets the UTC time the request was created /// public DateTime Time { get; private set; } /// /// Gets the order id the request acts on /// public int OrderId { get; protected set; } /// /// Gets a tag for this request /// public string Tag { get; private set; } /// /// Gets the response for this request. If this request was never processed then this /// will equal . This value is never equal to null. /// public OrderResponse Response { get; private set; } /// /// Initializes a new instance of the class /// /// The time this request was created /// The order id this request acts on, specify zero for /// A custom tag for the request protected OrderRequest(DateTime time, int orderId, string tag) { Time = time; OrderId = orderId; Tag = tag; Response = OrderResponse.Unprocessed; Status = OrderRequestStatus.Unprocessed; } /// /// Sets the for this request /// /// The response to this request /// The current status of this request public void SetResponse(OrderResponse response, OrderRequestStatus status = OrderRequestStatus.Error) { if (response == null) { throw new ArgumentNullException(nameof(response), "Response can not be null"); } // if the response is an error, ignore the input status Status = response.IsError ? OrderRequestStatus.Error : status; Response = response; } /// /// Returns a string that represents the current object. /// /// /// A string that represents the current object. /// /// 2 public override string ToString() { return Messages.OrderRequest.ToString(this); } } }