feat: iam rbac system
Endpoints and db architecture to support a role based IAM system.
This commit is contained in:
parent
7b3ee9d5fa
commit
23f2ce98d7
31 changed files with 634 additions and 317 deletions
7
src/service/config.py
Normal file
7
src/service/config.py
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
"""
|
||||
Configurations for <this module>
|
||||
|
||||
Configurations:
|
||||
- List: Description
|
||||
- Configs: Description
|
||||
"""
|
||||
7
src/service/constants.py
Normal file
7
src/service/constants.py
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
"""
|
||||
Constants and error codes for <this module>
|
||||
|
||||
Constants:
|
||||
- List: Description
|
||||
- Consts: Description
|
||||
"""
|
||||
11
src/service/dependencies.py
Normal file
11
src/service/dependencies.py
Normal file
|
|
@ -0,0 +1,11 @@
|
|||
"""
|
||||
Router dependencies for <this module>
|
||||
|
||||
Classes:
|
||||
- List: Description
|
||||
- Classes: Description
|
||||
|
||||
Functions:
|
||||
- List: Description
|
||||
- Functions: Description
|
||||
"""
|
||||
7
src/service/exceptions.py
Normal file
7
src/service/exceptions.py
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
"""
|
||||
Module specific exceptions for <this module>
|
||||
|
||||
Exceptions:
|
||||
- List: Description
|
||||
- Exceptions: Description
|
||||
"""
|
||||
18
src/service/models.py
Normal file
18
src/service/models.py
Normal file
|
|
@ -0,0 +1,18 @@
|
|||
"""
|
||||
Database models for the services module
|
||||
|
||||
Models:
|
||||
- List: Description
|
||||
- Models: Description
|
||||
"""
|
||||
from sqlalchemy import Column, Integer, String
|
||||
|
||||
from src.database import Base
|
||||
|
||||
|
||||
class Service(Base):
|
||||
__tablename__ = "service"
|
||||
|
||||
id = Column(Integer, primary_key=True)
|
||||
name = Column(String, unique=True)
|
||||
api_key = Column(String, unique=True)
|
||||
63
src/service/router.py
Normal file
63
src/service/router.py
Normal file
|
|
@ -0,0 +1,63 @@
|
|||
"""
|
||||
Router endpoints for <this module>
|
||||
|
||||
Endpoints:
|
||||
- List: Description
|
||||
- Endpoints: Description
|
||||
"""
|
||||
from fastapi import APIRouter
|
||||
|
||||
from src.database import db_dependency
|
||||
|
||||
from src.service.models import Service
|
||||
from src.service.utils import generate_api_key
|
||||
|
||||
|
||||
router = APIRouter(
|
||||
tags=["Service"],
|
||||
prefix="/service",
|
||||
)
|
||||
|
||||
@router.get("/")
|
||||
async def get_all_services(db: db_dependency):
|
||||
# TODO: user_dependency
|
||||
# TODO: request model
|
||||
permission_models = db.query(Service).all()
|
||||
|
||||
# TODO: Response model
|
||||
return permission_models
|
||||
|
||||
@router.post("/")
|
||||
async def register_service(db: db_dependency, service_name: str):
|
||||
# TODO: super_admin_dependency
|
||||
# TODO: request model
|
||||
key = generate_api_key()
|
||||
service_model = Service(name=service_name, api_key=key)
|
||||
|
||||
db.add(service_model)
|
||||
db.commit()
|
||||
# TODO: response model
|
||||
|
||||
@router.patch("/{service_id}/key")
|
||||
async def regenerate_api_key(db: db_dependency, service_id: int):
|
||||
# TODO: super_admin_dependency
|
||||
# TODO: request model
|
||||
key = generate_api_key()
|
||||
service_model = db.query(Service).filter(Service.id==service_id).first()
|
||||
service_model.api_key = key
|
||||
|
||||
db.add(service_model)
|
||||
db.commit()
|
||||
# TODO: response model
|
||||
|
||||
@router.delete("/{service_id}")
|
||||
async def remove_service(db: db_dependency, service_id: int):
|
||||
# TODO: super_admin_dependency
|
||||
# TODO: request model
|
||||
service_model = db.query(Service).filter(Service.id==service_id).first()
|
||||
if service_model is None:
|
||||
return
|
||||
|
||||
db.delete(service_model)
|
||||
db.commit()
|
||||
# TODO: response model
|
||||
7
src/service/schemas.py
Normal file
7
src/service/schemas.py
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
"""
|
||||
Pydantic models for <this module>
|
||||
|
||||
Models:
|
||||
- List: Description
|
||||
- Models: Description
|
||||
"""
|
||||
11
src/service/service.py
Normal file
11
src/service/service.py
Normal file
|
|
@ -0,0 +1,11 @@
|
|||
"""
|
||||
Module specific business logic for <this module>
|
||||
|
||||
Classes:
|
||||
- List: Description
|
||||
- Classes: Description
|
||||
|
||||
Functions:
|
||||
- List: Description
|
||||
- Functions: Description
|
||||
"""
|
||||
16
src/service/utils.py
Normal file
16
src/service/utils.py
Normal file
|
|
@ -0,0 +1,16 @@
|
|||
"""
|
||||
Non-business logic reusable functions and classes for <this module>
|
||||
|
||||
Classes:
|
||||
- List: Description
|
||||
- Classes: Description
|
||||
|
||||
Functions:
|
||||
- List: Description
|
||||
- Functions: Description
|
||||
"""
|
||||
import uuid
|
||||
|
||||
|
||||
def generate_api_key() -> str:
|
||||
return str(uuid.uuid4())
|
||||
Loading…
Add table
Add a link
Reference in a new issue