aboutsummaryrefslogtreecommitdiff
path: root/api/util/check_api_key.py
blob: 9c4c22e068fa9eb3e0c622352876702100891cd7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
from fastapi import Security, HTTPException, Depends, status
from fastapi.security import APIKeyHeader

from models import User
from api.util.db_dependency import get_db

"""
Make sure the provided API key is valid, then return the user's ID
"""
api_key_header = APIKeyHeader(name="X-API-Key")


def check_api_key(
    api_key_header: str = Security(api_key_header), db=Depends(get_db)
) -> str:
    response = db.query(User).filter(User.api_key == api_key_header).first()
    if not response:
        raise HTTPException(
            status_code=status.HTTP_401_UNAUTHORIZED, detail="Invalid API key"
        )
    return {"value": api_key_header, "owner": response.id}