Refactorizacion de subir logo4.5
This commit is contained in:
@@ -1,47 +1,7 @@
|
||||
|
||||
# ============= LOGO CONFIGURABLE =============
|
||||
from fastapi import FastAPI, File, UploadFile, Form
|
||||
app = FastAPI()
|
||||
|
||||
@app.post("/api/config/logo", response_model=dict)
|
||||
async def upload_logo(
|
||||
file: UploadFile = File(...),
|
||||
db: Session = Depends(get_db),
|
||||
current_user: models.User = Depends(get_current_user)
|
||||
):
|
||||
"""Sube un logo y lo guarda en MinIO, actualiza la configuración."""
|
||||
if current_user.role != "admin":
|
||||
raise HTTPException(status_code=403, detail="Solo administradores pueden cambiar el logo")
|
||||
|
||||
# Subir imagen a MinIO
|
||||
file_extension = file.filename.split(".")[-1]
|
||||
now = datetime.now()
|
||||
folder = f"logo"
|
||||
file_name = f"logo_{now.strftime('%Y%m%d_%H%M%S')}.{file_extension}"
|
||||
s3_key = f"{folder}/{file_name}"
|
||||
s3_client.upload_fileobj(file.file, S3_IMAGE_BUCKET, s3_key, ExtraArgs={"ContentType": file.content_type})
|
||||
logo_url = f"{S3_ENDPOINT}/{S3_IMAGE_BUCKET}/{s3_key}"
|
||||
|
||||
# Guardar en configuración (puedes tener una tabla Config o usar AIConfiguration)
|
||||
config = db.query(models.AIConfiguration).filter(models.AIConfiguration.is_active == True).first()
|
||||
if config:
|
||||
config.logo_url = logo_url
|
||||
db.commit()
|
||||
db.refresh(config)
|
||||
# Si no hay config, solo retorna la url
|
||||
return {"logo_url": logo_url}
|
||||
|
||||
# Endpoint para obtener el logo
|
||||
@app.get("/api/config/logo", response_model=dict)
|
||||
def get_logo_url(
|
||||
db: Session = Depends(get_db)
|
||||
):
|
||||
config = db.query(models.AIConfiguration).filter(models.AIConfiguration.is_active == True).first()
|
||||
if config and getattr(config, "logo_url", None):
|
||||
return {"logo_url": config.logo_url}
|
||||
# Default logo (puedes poner una url por defecto)
|
||||
return {"logo_url": f"{S3_ENDPOINT}/{S3_IMAGE_BUCKET}/logo/default_logo.png"}
|
||||
from fastapi import FastAPI, Depends, HTTPException, status, UploadFile, File
|
||||
from fastapi import FastAPI, File, UploadFile, Form, Depends, HTTPException, status
|
||||
from fastapi.middleware.cors import CORSMiddleware
|
||||
from fastapi.security import HTTPBearer, HTTPAuthorizationCredentials
|
||||
from sqlalchemy.orm import Session, joinedload
|
||||
@@ -52,6 +12,16 @@ import boto3
|
||||
from botocore.client import Config
|
||||
import uuid
|
||||
from app.core import config as app_config
|
||||
from app.core.database import engine, get_db, Base
|
||||
from app.core.security import verify_password, get_password_hash, create_access_token, decode_access_token
|
||||
from app import models, schemas
|
||||
import shutil
|
||||
from datetime import datetime, timedelta
|
||||
import sys
|
||||
|
||||
BACKEND_VERSION = "1.0.25"
|
||||
app = FastAPI(title="Checklist Inteligente API", version=BACKEND_VERSION)
|
||||
|
||||
# S3/MinIO configuration
|
||||
S3_ENDPOINT = app_config.MINIO_ENDPOINT
|
||||
S3_ACCESS_KEY = app_config.MINIO_ACCESS_KEY
|
||||
@@ -67,22 +37,11 @@ s3_client = boto3.client(
|
||||
config=Config(signature_version='s3v4'),
|
||||
region_name='us-east-1'
|
||||
)
|
||||
import shutil
|
||||
from datetime import datetime, timedelta
|
||||
|
||||
from app.core.database import engine, get_db, Base
|
||||
from app.core.security import verify_password, get_password_hash, create_access_token, decode_access_token
|
||||
from app import models, schemas
|
||||
|
||||
# Crear tablas
|
||||
Base.metadata.create_all(bind=engine)
|
||||
|
||||
BACKEND_VERSION = "1.0.25"
|
||||
app = FastAPI(title="Checklist Inteligente API", version=BACKEND_VERSION)
|
||||
|
||||
# Información visual al iniciar el backend
|
||||
import sys
|
||||
from app.core import config as app_config
|
||||
print("\n================ BACKEND STARTUP INFO ================")
|
||||
print(f"Backend version: {BACKEND_VERSION}")
|
||||
print(f"Database URL: {app_config.settings.DATABASE_URL}")
|
||||
@@ -154,6 +113,45 @@ def get_current_user(
|
||||
return user
|
||||
|
||||
|
||||
@app.post("/api/config/logo", response_model=dict)
|
||||
async def upload_logo(
|
||||
file: UploadFile = File(...),
|
||||
db: Session = Depends(get_db),
|
||||
current_user: models.User = Depends(get_current_user)
|
||||
):
|
||||
"""Sube un logo y lo guarda en MinIO, actualiza la configuración."""
|
||||
if current_user.role != "admin":
|
||||
raise HTTPException(status_code=403, detail="Solo administradores pueden cambiar el logo")
|
||||
|
||||
# Subir imagen a MinIO
|
||||
file_extension = file.filename.split(".")[-1]
|
||||
now = datetime.now()
|
||||
folder = f"logo"
|
||||
file_name = f"logo_{now.strftime('%Y%m%d_%H%M%S')}.{file_extension}"
|
||||
s3_key = f"{folder}/{file_name}"
|
||||
s3_client.upload_fileobj(file.file, S3_IMAGE_BUCKET, s3_key, ExtraArgs={"ContentType": file.content_type})
|
||||
logo_url = f"{S3_ENDPOINT}/{S3_IMAGE_BUCKET}/{s3_key}"
|
||||
|
||||
# Guardar en configuración (puedes tener una tabla Config o usar AIConfiguration)
|
||||
config = db.query(models.AIConfiguration).filter(models.AIConfiguration.is_active == True).first()
|
||||
if config:
|
||||
config.logo_url = logo_url
|
||||
db.commit()
|
||||
db.refresh(config)
|
||||
# Si no hay config, solo retorna la url
|
||||
return {"logo_url": logo_url}
|
||||
|
||||
@app.get("/api/config/logo", response_model=dict)
|
||||
def get_logo_url(
|
||||
db: Session = Depends(get_db)
|
||||
):
|
||||
config = db.query(models.AIConfiguration).filter(models.AIConfiguration.is_active == True).first()
|
||||
if config and getattr(config, "logo_url", None):
|
||||
return {"logo_url": config.logo_url}
|
||||
# Default logo (puedes poner una url por defecto)
|
||||
return {"logo_url": f"{S3_ENDPOINT}/{S3_IMAGE_BUCKET}/logo/default_logo.png"}
|
||||
|
||||
|
||||
# ============= AUTH ENDPOINTS =============
|
||||
@app.post("/api/auth/register", response_model=schemas.User)
|
||||
def register(user: schemas.UserCreate, db: Session = Depends(get_db)):
|
||||
|
||||
Reference in New Issue
Block a user