Compare commits

...

2 commits

Author SHA1 Message Date
8dd9bcadb9 add: basic stock search 2024-09-06 10:50:47 +08:00
bee6e96d53 fix: improper docker setup 2024-09-06 10:45:54 +08:00
5 changed files with 23 additions and 31 deletions

View file

@ -2,10 +2,10 @@
# base layer # base layer
FROM python:3.12-alpine as base FROM python:3.12-alpine as base
ARG DEV=false ENV VIRTUAL_ENV=/sparkle/.venv \
PATH="/sparkle/.venv/bin:$PATH"
ENV VIRTUAL_ENV=/app/.venv \ RUN python -m venv $VIRTUAL_ENV
PATH="/app/.venv/bin:$PATH"
RUN apk update && \ RUN apk update && \
apk add libpq apk add libpq
@ -26,7 +26,7 @@ RUN pip install poetry==1.8.3
# Install the app # Install the app
COPY pyproject.toml poetry.lock ./ COPY pyproject.toml poetry.lock ./
RUN poetry install dev --no-root && rm -rf $POETRY_CACHE_DIR; RUN poetry install --no-root && rm -rf $POETRY_CACHE_DIR;
FROM base as runtime FROM base as runtime
@ -34,7 +34,5 @@ COPY --from=builder ${VIRTUAL_ENV} ${VIRTUAL_ENV}
COPY app ./app COPY app ./app
WORKDIR /sparkle/app CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000"]
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8000"]

View file

@ -5,25 +5,18 @@ from app.core.websocket import start_finnhub_websocket
router = APIRouter() router = APIRouter()
@router.get("/price/{symbol}") @router.get("/search")
async def get_stock_price(symbol: str): async def lookup(query: str, exchange: str | None = None):
url = f"https://finnhub.io/api/v1/quote?symbol={symbol}&token={settings.FINNHUB_API_KEY}" """
response = requests.get(url) API to search for a stock symbol.
"""
params = {
"token": settings.FINNHUB_API_KEY,
"q": query
}
if exchange:
params["exchange"] = exchange
response = requests.get("https://finnhub.io/api/v1/search", params=params)
return response.json() return response.json()
@router.get("/start-websocket")
async def start_websocket():
"""
Endpoint to start the Finnhub WebSocket connection.
"""
start_finnhub_websocket()
return {"message": "WebSocket connection started"}
@router.get("/stop-websocket")
async def stop_websocket():
"""
Endpoint to stop the Finnhub WebSocket connection.
"""
# Code to stop the WebSocket connection
return {"message": "WebSocket connection stopped"}

View file

@ -1,4 +1,5 @@
import os import os
import finnhub
from dotenv import load_dotenv from dotenv import load_dotenv
load_dotenv() load_dotenv()
@ -6,5 +7,6 @@ load_dotenv()
class Settings: class Settings:
FINNHUB_API_KEY: str = os.getenv("FINNHUB_API_KEY") FINNHUB_API_KEY: str = os.getenv("FINNHUB_API_KEY")
FINNHUB_WEBSOCKET_URL: str = "wss://ws.finnhub.io?token=" + FINNHUB_API_KEY FINNHUB_WEBSOCKET_URL: str = "wss://ws.finnhub.io?token=" + FINNHUB_API_KEY
client: finnhub.Client = finnhub.Client(api_key=FINNHUB_API_KEY)
settings = Settings() settings = Settings()

View file

@ -4,12 +4,12 @@ from app.api.v1.routes import stock
from app.ws.routes import trades from app.ws.routes import trades
app = FastAPI() app = FastAPI()
app.include_router(stock.router, prefix="/api/v1")
app.include_router(trades.router, prefix="/ws")
@app.on_event("startup") @app.on_event("startup")
async def startup_event(): async def startup_event():
# Code to run on app startup, e.g., connect to WebSocket app.include_router(stock.router, prefix="/api/v1")
app.include_router(trades.router, prefix="/ws")
pass pass
@app.on_event("shutdown") @app.on_event("shutdown")

View file

@ -1,7 +1,6 @@
services: services:
sparkle: sparkle:
container_name: sparkle container_name: sparkle
image: sparkle:lastest
build: build:
context: . context: .
dockerfile: Dockerfile dockerfile: Dockerfile