Skip to content

Latest commit

 

History

History
228 lines (168 loc) · 6.6 KB

README.md

File metadata and controls

228 lines (168 loc) · 6.6 KB

Crypto Dashboard

Project Overview

The Crypto Dashboard is a full-stack application designed to provide real-time updates and visualizations of cryptocurrency market data. It includes features such as line graphs for historical data and aggregated trade visualizations for buy/sell activity. The project is structured into three key components: the frontend (crypto-dashboard), data acquisition (data_acquisition), and data serving (data_serving).

crypto-dashboard


Features

Frontend

  • Responsive Dashboard: Displays cryptocurrency data in a dynamic layout, adjusting to screen size (e.g., 2x2 grid for large screens, vertical stack for smaller screens).
  • Visualizations:
    • Line charts for price trends.
    • Aggregated trade charts (buy/sell activity for 1m, 5m, 10m, and 60m intervals).
  • Real-Time Updates: Periodically fetches and updates data for a seamless user experience.

Backend

  • Data Serving (data_serving):
    • Serves cryptocurrency data through RESTful API endpoints.
    • Handles data aggregation for efficient rendering on the frontend.
    • Configuration management with config.py.
  • Data Acquisition (data_acquisition):
    • Collects and processes cryptocurrency trade data.
    • Integrates with a database for persistent storage.

Deployment

  • Uses docker-compose for containerized deployment, ensuring ease of setup and scalability.

Project Structure

├── crypto-dashboard       # Frontend React application
│   ├── package.json
│   ├── package-lock.json
│   ├── README.md
│   └── src
│       ├── App.css        # Styling for the main application
│       ├── App.js         # Main React component
│       ├── App.test.js    # Unit tests for App.js
│       ├── axios.js       # Axios instance with configuration
│       ├── components     # React components
│       │   ├── AggregatedTrades.css  # Styling for aggregated trades
│       │   ├── AggregatedTrades.js   # Aggregated trades component
│       │   ├── GraphComponent.js     # Line graph component
│       │   └── TradeListComponent.js # (Deprecated) Trade list component
│       ├── index.css      # Global styling
│       ├── index.js       # Application entry point
│       └── setupTests.js  # Test setup configuration
├── data_acquisition       # Data ingestion scripts
│   ├── db.py              # Database integration
│   └── main.py            # Main entry point for data ingestion
├── data_serving           # Backend services
│   ├── api.py             # API endpoints for data serving
│   ├── config.py          # Configuration for backend services
│   └── db_utils.py        # Utility functions for database operations
├── docker-compose.yml     # Docker Compose configuration
└── private                # Private keys and environment variables
    ├── cdp_api_key.json   # API key for coin base api
    └── private.env        # Environment variables for database

Getting Started

Prerequisites

Installation

Create Project Structure

  1. Create private directory
mkdir private
  1. Create your .env as referenced bo docker-compose.yml. see example_private.env. Put this in private directory.

  2. Get your API key from Coin Base. You should be able to download json file like example_cdp_api_key.json. Put this in private directory.

Dockerized Deployment

  1. Ensure docker-compose is installed.

  2. Run:

docker-compose up --build
  1. Check that everything is as expected.
docker logs async_postgres
  1. Check that your environment variables are applied in the docker instance:
docker exec -it async_postgres bash
env | grep POSTGRES # this should show you the values in your private.env.

Run App

1. Populate your data

Websocket to Coin base api using data_acquisition/main.py.
If you have issues check your keys and the white listed IPs on the key ( including Ipv6 ). curl -4 ifconfig.io and curl -6 ipconfig.io to get external Ip addresses. Change the SUBS in data_acquisition/main.py to your desired subscriptions.

NOTE: The data acquisition can use a lot of data over the network. One option would be to remove the trades and just get the tickers.

  1. start the db container:
docker start async_postgres
  1. in /data_acquisitions
python main.py
  1. let this run for a few minutes.

  2. Check that the database is being populated

docker exec -it async_postgres bash
psql -U crypto -d crypto
\l # show available databases
\c crypto #: connect to database
\dt # list tables
select count(td.id) from ticker_data as td; ## this should not be 0.
exit
exit

2. Backend

  1. Navigate to the data_serving directory:
cd data_serving
  1. Start the API server:
python api.py
  1. Check with curl
curl -X GET "http://localhost:5000/api/last_trade?product_id=BTC-USD" # substitute the appropriate product_id

3. Frontend

  1. Navigate to the crypto-dashboard directory:
cd crypto-dashboard
  1. Install dependencies:
npm install
  1. Start the development server:
npm start

API Endpoints

/api/ticker_data

  • Method: GET
  • Description: Fetches historical ticker data for a cryptocurrency.
  • Parameters:
    • product_id (e.g., BTC-USD)
    • start_time (ISO timestamp)

/api/aggregated_trades

  • Method: GET
  • Description: Fetches aggregated trade data.
  • Parameters:
    • product_id (e.g., BTC-USD)
    • since (ISO timestamp)

/api/last_trade

  • Method: GET
  • Description: Fetches last trade for a product.
  • Parameters:
    • product_id (e.g., BTC-USD)

/api/recent_trades

  • Method: GET
  • Description: Fetches last n trades for a product.
  • Parameters:
    • product_id (e.g., BTC-USD)
    • limit (int - number of recent to return)


Development Notes

  • Frontend: Built with React, styled with CSS. Designed to be responsive and lightweight.
  • Backend: Python Flask app serving APIs. Focus on efficiency with well-optimized queries.
  • Data Flow: Data acquisition and serving are decoupled for scalability and clarity.