Lean
$LEAN_TAG$
TimeInForce.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
using
System;
17
using
Newtonsoft.Json;
18
using
QuantConnect
.
Interfaces
;
19
using
QuantConnect
.
Orders
.
TimeInForces
;
20
using
QuantConnect
.
Securities
;
21
22
namespace
QuantConnect.Orders
23
{
24
/// <summary>
25
/// Time In Force - defines the length of time over which an order will continue working before it is canceled
26
/// </summary>
27
[JsonConverter(typeof(TimeInForceJsonConverter))]
28
public
abstract
class
TimeInForce
:
ITimeInForceHandler
29
{
30
/// <summary>
31
/// Gets a <see cref="GoodTilCanceledTimeInForce"/> instance
32
/// </summary>
33
public
static
readonly
TimeInForce
GoodTilCanceled
=
new
GoodTilCanceledTimeInForce
();
34
35
/// <summary>
36
/// Gets a <see cref="DayTimeInForce"/> instance
37
/// </summary>
38
public
static
readonly
TimeInForce
Day
=
new
DayTimeInForce
();
39
40
/// <summary>
41
/// Gets a <see cref="GoodTilDateTimeInForce"/> instance
42
/// </summary>
43
public
static
Func<DateTime, TimeInForce>
GoodTilDate
=> (DateTime expiry) =>
new
GoodTilDateTimeInForce
(expiry);
44
45
/// <summary>
46
/// Checks if an order is expired
47
/// </summary>
48
/// <param name="security">The security matching the order</param>
49
/// <param name="order">The order to be checked</param>
50
/// <returns>Returns true if the order has expired, false otherwise</returns>
51
public
abstract
bool
IsOrderExpired
(
Security
security,
Order
order);
52
53
/// <summary>
54
/// Checks if an order fill is valid
55
/// </summary>
56
/// <param name="security">The security matching the order</param>
57
/// <param name="order">The order to be checked</param>
58
/// <param name="fill">The order fill to be checked</param>
59
/// <returns>Returns true if the order fill can be emitted, false otherwise</returns>
60
public
abstract
bool
IsFillValid
(
Security
security,
Order
order,
OrderEvent
fill);
61
}
62
}
Common
Orders
TimeInForce.cs
Generated by
1.8.17