/* * 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"; } } }