Lean
$LEAN_TAG$
IFeeModel.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
QuantConnect
.
Securities
;
17
18
namespace
QuantConnect.Orders.Fees
19
{
20
/// <summary>
21
/// Represents a model the simulates order fees
22
/// </summary>
23
/// <remarks>Please use <see cref="FeeModel"/> as the base class for
24
/// any implementations of <see cref="IFeeModel"/></remarks>
25
public
interface
IFeeModel
26
{
27
/// <summary>
28
/// Gets the order fee associated with the specified order.
29
/// </summary>
30
/// <param name="parameters">A <see cref="OrderFeeParameters"/> object
31
/// containing the security and order</param>
32
/// <returns>The cost of the order in a <see cref="CashAmount"/> instance</returns>
33
OrderFee
GetOrderFee
(
OrderFeeParameters
parameters);
34
}
35
36
/// <summary>
37
/// Provide extension method for <see cref="IFeeModel"/> to enable
38
/// backwards compatibility of invocations.
39
/// </summary>
40
public
static
class
FeeModelExtensions
41
{
42
/// <summary>
43
/// Gets the order fee associated with the specified order. This returns the cost
44
/// of the transaction in the account currency
45
/// </summary>
46
/// <param name="model">The fee model</param>
47
/// <param name="security">The security matching the order</param>
48
/// <param name="order">The order to compute fees for</param>
49
/// <returns>The cost of the order in units of the account currency</returns>
50
public
static
decimal
GetOrderFee
(
this
IFeeModel
model,
Security
security,
Order
order)
51
{
52
var parameters =
new
OrderFeeParameters
(security, order);
53
var fee = model.
GetOrderFee
(parameters);
54
55
return
fee.
Value
.
Amount
;
56
}
57
}
58
}
Common
Orders
Fees
IFeeModel.cs
Generated by
1.8.17