/*
* 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 QuantConnect.Orders.Fees;
using QuantConnect.Orders.Fills;
using QuantConnect.Orders.Slippage;
namespace QuantConnect.Securities.CryptoFuture
{
///
/// Crypto Future Security Object Implementation for Crypto Future Assets
///
public class CryptoFuture : Security, IBaseCurrencySymbol
{
///
/// Gets the currency acquired by going long this currency pair
///
///
/// For example, the EUR/USD has a base currency of the euro, and as a result
/// of going long the EUR/USD a trader is acquiring euros in exchange for US dollars
///
public Cash BaseCurrency { get; protected set; }
///
/// Constructor for the Crypto Future security
///
/// The symbol
/// Defines the hours this exchange is open
/// The cash object that represent the quote currency
/// The cash object that represent the base currency
/// The symbol properties for this security
/// Currency converter used to convert
/// instances into units of the account currency
/// Provides all data types registered in the algorithm
/// The security cache
public CryptoFuture(Symbol symbol,
SecurityExchangeHours exchangeHours,
Cash quoteCurrency,
Cash baseCurrency,
SymbolProperties symbolProperties,
ICurrencyConverter currencyConverter,
IRegisteredSecurityDataTypesProvider registeredTypes,
SecurityCache cache)
: base(symbol,
quoteCurrency,
symbolProperties,
new CryptoFutureExchange(exchangeHours),
cache,
new SecurityPortfolioModel(),
new ImmediateFillModel(),
IsCryptoCoinFuture(quoteCurrency.Symbol) ? new BinanceCoinFuturesFeeModel() : new BinanceFuturesFeeModel(),
NullSlippageModel.Instance,
new ImmediateSettlementModel(),
Securities.VolatilityModel.Null,
new CryptoFutureMarginModel(),
new SecurityDataFilter(),
new SecurityPriceVariationModel(),
currencyConverter,
registeredTypes,
// only applies for perpetual futures
symbol.ID.Date == SecurityIdentifier.DefaultDate ? new BinanceFutureMarginInterestRateModel() : Securities.MarginInterestRateModel.Null
)
{
BaseCurrency = baseCurrency;
Holdings = new CryptoFutureHolding(this, currencyConverter);
}
///
/// Checks whether the security is a crypto coin future
///
/// True if the security is a crypto coin future
public bool IsCryptoCoinFuture()
{
return IsCryptoCoinFuture(QuoteCurrency.Symbol);
}
///
/// Checks whether the security is a crypto coin future
///
/// The security quote currency
/// True if the security is a crypto coin future
private static bool IsCryptoCoinFuture(string quoteCurrency)
{
return quoteCurrency != "USDT" && quoteCurrency != "BUSD";
}
}
}