forked from QuantConnect/Lean
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathISecurityPrice.cs
97 lines (84 loc) · 3.22 KB
/
ISecurityPrice.cs
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
/*
* 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;
using System.Collections.Generic;
using QuantConnect.Data;
using QuantConnect.Securities;
namespace QuantConnect.Interfaces
{
/// <summary>
/// Reduced interface which allows setting and accessing
/// price properties for a <see cref="Security"/>
/// </summary>
public interface ISecurityPrice
{
/// <summary>
/// Get the current value of the security.
/// </summary>
decimal Price { get; }
/// <summary>
/// If this uses trade bar data, return the most recent close.
/// </summary>
decimal Close { get; }
/// <summary>
/// Access to the volume of the equity today
/// </summary>
decimal Volume { get; }
/// <summary>
/// Gets the most recent bid price if available
/// </summary>
decimal BidPrice { get; }
/// <summary>
/// Gets the most recent bid size if available
/// </summary>
decimal BidSize { get; }
/// <summary>
/// Gets the most recent ask price if available
/// </summary>
decimal AskPrice { get; }
/// <summary>
/// Gets the most recent ask size if available
/// </summary>
decimal AskSize { get; }
/// <summary>
/// Access to the open interest of the security today
/// </summary>
long OpenInterest { get; }
/// <summary>
/// <see cref="Symbol"/> for the asset.
/// </summary>
Symbol Symbol { get; }
/// <summary>
/// Update any security properties based on the latest market data and time
/// </summary>
/// <param name="data">New data packet from LEAN</param>
void SetMarketPrice(BaseData data);
/// <summary>
/// Updates all of the security properties, such as price/OHLCV/bid/ask based
/// on the data provided. Data is also stored into the security's data cache
/// </summary>
/// <param name="data">The security update data</param>
/// <param name="dataType">The data type</param>
/// <param name="containsFillForwardData">Flag indicating whether
/// <paramref name="data"/> contains any fill forward bar or not</param>
void Update(IReadOnlyList<BaseData> data, Type dataType, bool? containsFillForwardData);
/// <summary>
/// Get the last price update set to the security.
/// </summary>
/// <returns>BaseData object for this security</returns>
BaseData GetLastData();
}
}