Add user router
This commit is contained in:
parent
b22bc4e164
commit
e33d74308a
|
@ -1,6 +1,6 @@
|
||||||
# Simple OCCP Central System
|
# Simple OCCP Central System
|
||||||
|
|
||||||
This is a simple implementation of a basic OCPP 2.0.1 compliant central system (backend) for EV charging stations.
|
This is a simple implementation of a basic [OCPP](https://openchargealliance.org/protocols/open-charge-point-protocol/) 2.0.1 compliant central system (backend) for EV charging stations.
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ import uvicorn
|
||||||
from app.database import engine, Base
|
from app.database import engine, Base
|
||||||
from app.models import *
|
from app.models import *
|
||||||
|
|
||||||
from app.routers import chargepoint_v1, ocpp_v1
|
from app.routers import chargepoint_v1, user_v1, ocpp_v1
|
||||||
from app.util.websocket_auth_backend import BasicAuthBackend
|
from app.util.websocket_auth_backend import BasicAuthBackend
|
||||||
|
|
||||||
Base.metadata.create_all(bind=engine)
|
Base.metadata.create_all(bind=engine)
|
||||||
|
@ -25,6 +25,7 @@ def create_app():
|
||||||
)
|
)
|
||||||
|
|
||||||
app.include_router(chargepoint_v1.router, prefix="/v1")
|
app.include_router(chargepoint_v1.router, prefix="/v1")
|
||||||
|
app.include_router(user_v1.router, prefix="/v1")
|
||||||
app.mount(path="/v1/ocpp", app=create_ocpp_app())
|
app.mount(path="/v1/ocpp", app=create_ocpp_app())
|
||||||
|
|
||||||
return app
|
return app
|
||||||
|
|
|
@ -8,7 +8,7 @@ from sqlalchemy.orm import Session
|
||||||
from app.database import get_db
|
from app.database import get_db
|
||||||
from app.ocpp_proto import chargepoint_manager
|
from app.ocpp_proto import chargepoint_manager
|
||||||
from app.schemas.chargepoint import ChargePoint, ChargePointCreate, ChargePointUpdate, ChargePointPassword, ChargePointConnectionInfo
|
from app.schemas.chargepoint import ChargePoint, ChargePointCreate, ChargePointUpdate, ChargePointPassword, ChargePointConnectionInfo
|
||||||
from app.models.chargepoint import ChargePoint as DBChargePoint
|
from app.models.chargepoint import ChargePoint as DbChargePoint
|
||||||
from app.security import get_api_key
|
from app.security import get_api_key
|
||||||
|
|
||||||
router = APIRouter(
|
router = APIRouter(
|
||||||
|
@ -23,7 +23,7 @@ async def get_chargepoints(
|
||||||
api_key: str = Security(get_api_key),
|
api_key: str = Security(get_api_key),
|
||||||
db: Session = Depends(get_db)
|
db: Session = Depends(get_db)
|
||||||
):
|
):
|
||||||
return db.query(DBChargePoint).offset(skip).limit(limit).all()
|
return db.query(DbChargePoint).offset(skip).limit(limit).all()
|
||||||
|
|
||||||
@router.get(path="/{chargepoint_id}", response_model=ChargePoint)
|
@router.get(path="/{chargepoint_id}", response_model=ChargePoint)
|
||||||
async def get_chargepoint(
|
async def get_chargepoint(
|
||||||
|
@ -31,7 +31,7 @@ async def get_chargepoint(
|
||||||
api_key: str = Security(get_api_key),
|
api_key: str = Security(get_api_key),
|
||||||
db: Session = Depends(get_db)
|
db: Session = Depends(get_db)
|
||||||
):
|
):
|
||||||
chargepoint = db.query(DBChargePoint).filter(DBChargePoint.id == chargepoint_id).first()
|
chargepoint = db.get(DbChargePoint, chargepoint_id)
|
||||||
if chargepoint is None:
|
if chargepoint is None:
|
||||||
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
||||||
return chargepoint
|
return chargepoint
|
||||||
|
@ -42,7 +42,7 @@ async def get_chargepoint_password(
|
||||||
api_key: str = Security(get_api_key),
|
api_key: str = Security(get_api_key),
|
||||||
db: Session = Depends(get_db)
|
db: Session = Depends(get_db)
|
||||||
):
|
):
|
||||||
chargepoint = db.query(DBChargePoint).filter(DBChargePoint.id == chargepoint_id).first()
|
chargepoint = db.get(DbChargePoint, chargepoint_id)
|
||||||
if chargepoint is None:
|
if chargepoint is None:
|
||||||
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
||||||
return ChargePointPassword(password=chargepoint.password)
|
return ChargePointPassword(password=chargepoint.password)
|
||||||
|
@ -53,7 +53,7 @@ async def reset_chargepoint_password(
|
||||||
api_key: str = Security(get_api_key),
|
api_key: str = Security(get_api_key),
|
||||||
db: Session = Depends(get_db)
|
db: Session = Depends(get_db)
|
||||||
):
|
):
|
||||||
chargepoint = db.query(DBChargePoint).filter(DBChargePoint.id == chargepoint_id).first()
|
chargepoint = db.get(DbChargePoint, chargepoint_id)
|
||||||
if chargepoint is None:
|
if chargepoint is None:
|
||||||
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
||||||
chargepoint.password = ''.join(random.choice(string.ascii_letters + string.digits) for i in range(24))
|
chargepoint.password = ''.join(random.choice(string.ascii_letters + string.digits) for i in range(24))
|
||||||
|
@ -66,7 +66,7 @@ async def create_chargepoint(
|
||||||
api_key: str = Security(get_api_key),
|
api_key: str = Security(get_api_key),
|
||||||
db: Session = Depends(get_db)
|
db: Session = Depends(get_db)
|
||||||
):
|
):
|
||||||
chargepoint_db = DBChargePoint(
|
chargepoint_db = DbChargePoint(
|
||||||
friendly_name=chargepoint.friendly_name,
|
friendly_name=chargepoint.friendly_name,
|
||||||
is_active=chargepoint.is_active,
|
is_active=chargepoint.is_active,
|
||||||
password=''.join(random.choice(string.ascii_letters + string.digits) for i in range(24))
|
password=''.join(random.choice(string.ascii_letters + string.digits) for i in range(24))
|
||||||
|
@ -83,7 +83,7 @@ async def update_chargepoint(
|
||||||
api_key: str = Security(get_api_key),
|
api_key: str = Security(get_api_key),
|
||||||
db: Session = Depends(get_db)
|
db: Session = Depends(get_db)
|
||||||
):
|
):
|
||||||
chargepoint = db.query(DBChargePoint).filter(DBChargePoint.id == chargepoint_id).first()
|
chargepoint = db.get(DbChargePoint, chargepoint_id)
|
||||||
if chargepoint is None:
|
if chargepoint is None:
|
||||||
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
||||||
for key, value in chargepoint_update.model_dump(exclude_unset=True).items():
|
for key, value in chargepoint_update.model_dump(exclude_unset=True).items():
|
||||||
|
@ -97,7 +97,7 @@ async def delete_chargepoint(
|
||||||
api_key: str = Security(get_api_key),
|
api_key: str = Security(get_api_key),
|
||||||
db: Session = Depends(get_db)
|
db: Session = Depends(get_db)
|
||||||
):
|
):
|
||||||
chargepoint = db.query(DBChargePoint).filter(DBChargePoint.id == chargepoint_id).first()
|
chargepoint = db.get(DbChargePoint, chargepoint_id)
|
||||||
if chargepoint is None:
|
if chargepoint is None:
|
||||||
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
raise HTTPException(status_code=404, detail="Chargepoint not found")
|
||||||
db.delete(chargepoint)
|
db.delete(chargepoint)
|
||||||
|
|
77
app/routers/user_v1.py
Normal file
77
app/routers/user_v1.py
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
from uuid import UUID
|
||||||
|
from fastapi import APIRouter, HTTPException, Security
|
||||||
|
from fastapi.params import Depends
|
||||||
|
from sqlalchemy.orm import Session
|
||||||
|
|
||||||
|
from app.database import get_db
|
||||||
|
from app.schemas.user import User, UserCreate, UserUpdate
|
||||||
|
from app.models.user import User as DbUser
|
||||||
|
from app.security import get_api_key
|
||||||
|
|
||||||
|
router = APIRouter(
|
||||||
|
prefix="/user",
|
||||||
|
tags=["user (v1)"],
|
||||||
|
)
|
||||||
|
|
||||||
|
@router.get(path="", response_model=list[User])
|
||||||
|
async def get_users(
|
||||||
|
skip: int = 0,
|
||||||
|
limit: int = 20,
|
||||||
|
api_key: str = Security(get_api_key),
|
||||||
|
db: Session = Depends(get_db)
|
||||||
|
):
|
||||||
|
return db.query(DbUser).offset(skip).limit(limit).all()
|
||||||
|
|
||||||
|
@router.get(path="/{user_id}", response_model=User)
|
||||||
|
async def get_user(
|
||||||
|
user_id: UUID,
|
||||||
|
api_key: str = Security(get_api_key),
|
||||||
|
db: Session = Depends(get_db)
|
||||||
|
):
|
||||||
|
user = db.get(DbUser, user_id)
|
||||||
|
if user == None:
|
||||||
|
raise HTTPException(status_code=404, detail="User not found")
|
||||||
|
return user
|
||||||
|
|
||||||
|
@router.post(path="", status_code=201, response_model=User)
|
||||||
|
async def create_user(
|
||||||
|
create_user: UserCreate,
|
||||||
|
api_key: str = Security(get_api_key),
|
||||||
|
db: Session = Depends(get_db)
|
||||||
|
):
|
||||||
|
db_user = DbUser(
|
||||||
|
friendly_name=create_user.friendly_name,
|
||||||
|
is_active=create_user.is_active
|
||||||
|
)
|
||||||
|
db.add(db_user)
|
||||||
|
db.commit()
|
||||||
|
db.refresh(db_user)
|
||||||
|
return db_user
|
||||||
|
|
||||||
|
@router.patch(path="/{user_id}", response_model=User)
|
||||||
|
async def update_user(
|
||||||
|
user_id: UUID,
|
||||||
|
user_update: UserUpdate,
|
||||||
|
api_key: str = Security(get_api_key),
|
||||||
|
db: Session = Depends(get_db)
|
||||||
|
):
|
||||||
|
user = db.get(DbUser, user_id)
|
||||||
|
if user is None:
|
||||||
|
raise HTTPException(status_code=404, detail="User not found")
|
||||||
|
for key, value in user_update.model_dump(exclude_unset=True).items():
|
||||||
|
setattr(user, key, value)
|
||||||
|
db.commit()
|
||||||
|
return user
|
||||||
|
|
||||||
|
@router.delete(path="/{user_id}", response_model=None)
|
||||||
|
async def delete_user(
|
||||||
|
user_id: UUID,
|
||||||
|
api_key: str = Security(get_api_key),
|
||||||
|
db: Session = Depends(get_db)
|
||||||
|
):
|
||||||
|
user = db.get(DbUser, user_id)
|
||||||
|
if user == None:
|
||||||
|
raise HTTPException(status_code=404, detail="User not found")
|
||||||
|
db.delete(user)
|
||||||
|
db.commit()
|
||||||
|
return []
|
|
@ -1,18 +1,20 @@
|
||||||
|
from typing import Optional
|
||||||
from uuid import UUID
|
from uuid import UUID
|
||||||
from pydantic import BaseModel
|
from pydantic import BaseModel
|
||||||
|
|
||||||
from app.schemas.id_token import IdToken
|
|
||||||
|
|
||||||
class UserBase(BaseModel):
|
class UserBase(BaseModel):
|
||||||
friendly_name: str
|
friendly_name: str
|
||||||
is_active: bool
|
is_active: bool
|
||||||
|
|
||||||
|
class UserUpdate(BaseModel):
|
||||||
|
friendly_name: Optional[str] = None
|
||||||
|
is_active: Optional[bool] = None
|
||||||
|
|
||||||
class UserCreate(UserBase):
|
class UserCreate(UserBase):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
class User(UserBase):
|
class User(UserBase):
|
||||||
id: UUID
|
id: UUID
|
||||||
id_tokens: list[IdToken] = []
|
|
||||||
|
|
||||||
class Config:
|
class Config:
|
||||||
from_attributes = True
|
from_attributes = True
|
Loading…
Reference in a new issue