Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/quantconnect/lean.brokerages.coinbase

Coinbase Pro brokerage template
https://github.com/quantconnect/lean.brokerages.coinbase

Last synced: about 1 month ago
JSON representation

Coinbase Pro brokerage template

Awesome Lists containing this project

README

        

![header-cheetah](https://user-images.githubusercontent.com/79997186/184224088-de4f3003-0c22-4a17-8cc7-b341b8e5b55d.png)

 
 
 

## Introduction

This repository hosts the CoinbasePro Brokerage Plugin Integration with the QuantConnect LEAN Algorithmic Trading Engine. LEAN is a brokerage agnostic operating system for quantitative finance. Thanks to open-source plugins such as this [LEAN](https://github.com/QuantConnect/Lean) can route strategies to almost any market.

[LEAN](https://github.com/QuantConnect/Lean) is maintained primarily by [QuantConnect](https://www.quantconnect.com), a US based technology company hosting a cloud algorithmic trading platform. QuantConnect has successfully hosted more than 200,000 live algorithms since 2015, and trades more than $1B volume per month.

### About Coinbase Pro


coinbase

[Coinbase](https://www.coinbase.com/) was founded by Brian Armstrong and Fred Ehrsam in 2012 with the goal to "increase economic freedom in the world". Coinbase Pro provides access to trading Crypto for clients in over [100 countries](https://www.coinbase.com/places) with no minimum deposit. Coinbase Pro also provides a self-hosted Crypto wallet, a Visa debit rewards card, and Bitcoin collateral-backed lines of credit.

For more information about the Coinbase Pro brokerage, see the [QuantConnect-Coinbase Pro Integration Page](https://www.quantconnect.com/docs/v2/our-platform/live-trading/brokerages/coinbase-pro).

## Using the Brokerage Plugin

### Deploying Coinbase Pro with VSCode User Interace

You can deploy using a visual interface in the QuantConnect Cloud. For more information see the [QuantConnect-CoinbasePro Integration Page](https://www.quantconnect.com/brokerages/coinbasepro).

![deploy-coinbase](https://user-images.githubusercontent.com/38889814/188244653-4feb1f60-d693-4dde-b47b-009dc3295a27.gif)

In the QuantConnect Cloud Platform you can harness the QuantConnect Live Data Feed. For most users this is substantially cheaper and easier than self-hosting.

### Deploying Coinbase Pro with LEAN CLI

Follow these steps to start local live trading with the Coinbase Pro brokerage:

1. Open a terminal in your [CLI root directory](https://www.quantconnect.com/docs/v2/lean-cli/initialization/directory-structure#02-lean-init).
2. Run `lean live "`" to start a live deployment wizard for the project in ./`` and then enter the brokerage number.

```
$ lean live 'My Project'

Select a brokerage:
1. Paper Trading
2. Interactive Brokers
3. Tradier
4. OANDA
5. Bitfinex
6. Coinbase Pro
7. Binance
8. Zerodha
9. Samco
10. Terminal Link
11. Atreyu
12. Trading Technologies
13. Kraken
14. FTX
Enter an option:
```

3. Enter the number of the organization that has a subscription for the Coinbase Pro module.

```
$ lean live "My Project"

Select the organization with the Coinbase Pro module subscription:
1. Organization 1
2. Organization 2
3. Organization 3
Enter an option: 1
```

4. Enter the environment to use.

```
$ lean live "My Project"

Use sandbox? (live, paper): live
```

5. Enter your API key, API secret.

```
$ lean live "My Project"

API key: 6d3ef5ca2d2fa52e4ee55624b0471261
API secret: ****************************************************************************************
```

To create new API credentials, see the [API settings page](https://pro.coinbase.com/profile/api) on the Coinbase Pro website.

6. Enter the number of the data feed to use and then follow the steps required for the data connection.

```
$ lean live 'My Project'

Select a data feed:
1. Interactive Brokers
2. Tradier
3. Oanda
4. Bitfinex
5. Coinbase Pro
6. Binance
7. Zerodha
8. Samco
9. Terminal Link
10. Trading Technologies
11. Kraken
12. FTX
13. IQFeed
14. Polygon Data Feed
15. Custom Data Only

To enter multiple options, separate them with comma:
```

If you select Polygon Data Feed, see [Polygon](https://www.quantconnect.com/docs/v2/lean-cli/live-trading/other-data-feeds/polygon) for set up instructions.

1. View the result in the `live` directory. Results are stored in real-time in JSON format. You can save results to a different directory by providing the `--output ` option in step 2.

If you already have a live environment configured in your [Lean configuration file](https://www.quantconnect.com/docs/v2/lean-cli/initialization/configuration#03-Lean-Configuration), you can skip the interactive wizard by providing the `--environment ` option in step 2. The value of this option must be the name of an environment which has `live-mode` set to true.

## Account Types

Coinbase Pro supports cash accounts.

## Order Types and Asset Classes

Coinbase Pro supports trading crypto and the following order types:

- Market Order
- Limit Order
- Stop-Limit Order

## Downloading Data

For local deployment, the algorithm needs to download the following dataset:

[Coinbase Pro Crypto Price Data](https://www.quantconnect.com/datasets/coinbase-pro-crypto-price-data)

## Brokerage Model

Lean models the brokerage behavior for backtesting purposes. The margin model is used in live trading to avoid placing orders that will be rejected due to insufficient buying power.

You can set the Brokerage Model with the following statements

SetBrokerageModel(BrokerageName.Coinbase, AccountType.Cash);

[Read Documentation](https://www.quantconnect.com/docs/v2/our-platform/live-trading/brokerages/coinbase-pro)

### Fees

We model the order fees of Coinbase Pro at the $50K-100K pricing tier for all Crypto pairs, which is a 0.60% maker and taker 0.80% fee for most pairs. The following table shows the Coinbase Pro Stable Pairs, which charge a 0% maker fee and a 0.001% taker fee:
|||||
|:----:|:----:|:----:|:----:|
|DAIUSDC|DAIUSD|GYENUSD|PAXUSD|
|PAXUSDT|MUSDUSD|USDCEUR|USDCGBP|
|USDTEUR|USDTGBP|USDTUSD|USDTUSDC|
|USTEUR|USTUSD|USTUSDT|WBTCBTC|

If you add liquidity to the order book by placing a limit order that doesn't cross the spread, you pay maker fees. If you remove liquidity from the order book by placing an order that crosses the spread, you pay taker fees. Coinbase Pro adjusts your fees based on your 30-day trading volume, but we don't currently model trading volume to adjust fees.

We model the adjustments Coinbase Pro has made to their fees over time. The following table shows the fees for each time period:
|Time Period (UTC)|Maker Fee (%)|Taker Fee (%)|
|----:|----:|----:|
|Time < 3/23/2019 1:30AM|0|0.3|
|3/23/2019 1:30AM <= Time < 10/8/2019 12:30AM|0.15|0.25|
|10/8/2019 12:30AM <= Time < 12/21/2023 1:00 AM|0.5|0.5|
|12/21/2023 1:00 AM <= Time|0.6|0.8|

To check the latest fees at all the fee levels, see the [What are the fees on Coinbase Pro?](https://help.coinbase.com/en/pro/trading-and-funding/trading-rules-and-fees/fees) page on the Coinbase Pro website.

### Margin

Coinbase Pro does not support margin trading.

### Slippage

Orders through Coinbase Pro do not experience slippage in backtests. In live trading, your orders may experience slippage.

### Fills

We fill market orders immediately and completely in backtests. In live trading, if the quantity of your market orders exceeds the quantity available at the top of the order book, your orders are filled according to what is available in the order book.

### Settlements

Trades settle immediately after the transaction.

### Deposits and Withdraws

You can deposit and withdraw cash from your brokerage account while you run an algorithm that's connected to the account. We sync the algorithm's cash holdings with the cash holdings in your brokerage account every day at 7:45 AM Eastern Time (ET).

 
 
 

![whats-lean](https://user-images.githubusercontent.com/79997186/184042682-2264a534-74f7-479e-9b88-72531661e35d.png)

 
 
 

LEAN Engine is an open-source algorithmic trading engine built for easy strategy research, backtesting, and live trading. We integrate with common data providers and brokerages, so you can quickly deploy algorithmic trading strategies.

The core of the LEAN Engine is written in C#, but it operates seamlessly on Linux, Mac and Windows operating systems. To use it, you can write algorithms in Python 3.8 or C#. QuantConnect maintains the LEAN project and uses it to drive the web-based algorithmic trading platform on the website.

## Contributions

Contributions are warmly very welcomed but we ask you to read the existing code to see how it is formatted, commented and ensure contributions match the existing style. All code submissions must include accompanying tests. Please see the [contributor guide lines](https://github.com/QuantConnect/Lean/blob/master/CONTRIBUTING.md).

## Code of Conduct

We ask that our users adhere to the community [code of conduct](https://www.quantconnect.com/codeofconduct) to ensure QuantConnect remains a safe, healthy environment for
high quality quantitative trading discussions.

## License Model

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

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.