mirror of
https://github.com/ryanamay/sparkle.git
synced 2024-09-20 05:30:34 +00:00
Compare commits
2 commits
6e3ba3701e
...
21b4ccdc5c
Author | SHA1 | Date | |
---|---|---|---|
21b4ccdc5c | |||
fd5dbc9f27 |
4 changed files with 37 additions and 19 deletions
19
app/api/v1/routes/market.py
Normal file
19
app/api/v1/routes/market.py
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
from fastapi import APIRouter, Depends
|
||||||
|
import requests
|
||||||
|
from app.core.config import settings
|
||||||
|
from app.core.websocket import start_finnhub_websocket
|
||||||
|
|
||||||
|
router = APIRouter()
|
||||||
|
|
||||||
|
@router.get("/marketnews")
|
||||||
|
async def market_news():
|
||||||
|
"""
|
||||||
|
API to get latest market news.
|
||||||
|
"""
|
||||||
|
params = {
|
||||||
|
"token": settings.FINNHUB_API_KEY,
|
||||||
|
"category": "general"
|
||||||
|
}
|
||||||
|
|
||||||
|
response = requests.get("https://finnhub.io/api/v1/news", params=params)
|
||||||
|
return response.json()
|
|
@ -5,31 +5,15 @@ from app.core.websocket import start_finnhub_websocket
|
||||||
|
|
||||||
router = APIRouter()
|
router = APIRouter()
|
||||||
|
|
||||||
@router.get("/search")
|
@router.get("/market-status")
|
||||||
async def lookup(query: str, exchange: str | None = None):
|
|
||||||
"""
|
|
||||||
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()
|
|
||||||
|
|
||||||
@router.get("/marketnews")
|
|
||||||
async def market_news():
|
async def market_news():
|
||||||
"""
|
"""
|
||||||
API to get latest market news.
|
API to get latest market news.
|
||||||
"""
|
"""
|
||||||
params = {
|
params = {
|
||||||
"token": settings.FINNHUB_API_KEY,
|
"token": settings.FINNHUB_API_KEY,
|
||||||
"category": "general"
|
"exchange": "US"
|
||||||
}
|
}
|
||||||
|
|
||||||
response = requests.get("https://finnhub.io/api/v1/news", params=params)
|
response = requests.get("https://finnhub.io/api/v1/market-status", params=params)
|
||||||
return response.json()
|
return response.json()
|
|
@ -33,3 +33,16 @@ async def quote(symbol: str):
|
||||||
|
|
||||||
response = requests.get("https://finnhub.io/api/v1/quote", params=params)
|
response = requests.get("https://finnhub.io/api/v1/quote", params=params)
|
||||||
return response.json()
|
return response.json()
|
||||||
|
|
||||||
|
@router.get("/profile")
|
||||||
|
async def profile(symbol: str):
|
||||||
|
"""
|
||||||
|
API to get company profile.
|
||||||
|
"""
|
||||||
|
params = {
|
||||||
|
"token": settings.FINNHUB_API_KEY,
|
||||||
|
"symbol": symbol
|
||||||
|
}
|
||||||
|
|
||||||
|
response = requests.get("https://finnhub.io/api/v1/stock/profile2", params=params)
|
||||||
|
return response.json()
|
||||||
|
|
|
@ -2,6 +2,7 @@ from fastapi import FastAPI
|
||||||
from app.core.config import settings
|
from app.core.config import settings
|
||||||
from app.api.v1.routes import stock
|
from app.api.v1.routes import stock
|
||||||
from app.api.v1.routes import news
|
from app.api.v1.routes import news
|
||||||
|
from app.api.v1.routes import market
|
||||||
from app.ws.routes import trades
|
from app.ws.routes import trades
|
||||||
app = FastAPI()
|
app = FastAPI()
|
||||||
|
|
||||||
|
@ -11,6 +12,7 @@ app = FastAPI()
|
||||||
async def startup_event():
|
async def startup_event():
|
||||||
app.include_router(stock.router, prefix="/api/v1")
|
app.include_router(stock.router, prefix="/api/v1")
|
||||||
app.include_router(news.router, prefix="/api/v1")
|
app.include_router(news.router, prefix="/api/v1")
|
||||||
|
app.include_router(market.router, prefix="/api/v1")
|
||||||
app.include_router(trades.router, prefix="/ws")
|
app.include_router(trades.router, prefix="/ws")
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue