/* * 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.Securities; using System; using System.Collections.Generic; namespace QuantConnect.Brokerages { /// /// Provides Binance.US specific properties /// public class BinanceUSBrokerageModel : BinanceBrokerageModel { /// /// The base Binance Futures API endpoint URL. /// protected override string BaseApiEndpoint => "https://api.binance.us/api/v3"; /// /// Market name /// protected override string MarketName => Market.BinanceUS; /// /// Gets a map of the default markets to be used for each security type /// public override IReadOnlyDictionary DefaultMarkets { get; } = GetDefaultMarkets(Market.BinanceUS); /// /// Initializes a new instance of the class /// /// The type of account to be modeled, defaults to public BinanceUSBrokerageModel(AccountType accountType = AccountType.Cash) : base(accountType) { if (accountType == AccountType.Margin) { throw new ArgumentException(Messages.BinanceUSBrokerageModel.UnsupportedAccountType); } } /// /// Binance global leverage rule /// /// /// public override decimal GetLeverage(Security security) { // margin trading is not currently supported by Binance.US return 1m; } } }