Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
47 changes: 37 additions & 10 deletions backend/api/user_data.py
Original file line number Diff line number Diff line change
@@ -1,29 +1,38 @@
"""User Data API endpoints for ALwrity."""

from fastapi import APIRouter, HTTPException, Depends
from typing import Dict, Any, Optional
from loguru import logger

from services.user_data_service import UserDataService
from services.database import get_db_session
from middleware.auth_middleware import get_current_user

router = APIRouter(prefix="/api/user-data", tags=["user-data"])

@router.get("/")
async def get_user_data():
async def get_user_data(current_user: dict = Depends(get_current_user)):
"""Get comprehensive user data from onboarding."""
db_session = None
try:
user_id = str(current_user.get("id"))
db_session = get_db_session()
if not db_session:
raise HTTPException(status_code=500, detail="Database connection failed")

user_data_service = UserDataService(db_session)
user_data = user_data_service.get_user_onboarding_data()
user_data = user_data_service.get_user_onboarding_data(user_id)

if not user_data:
return {"message": "No user data found"}
raise HTTPException(status_code=404, detail="No onboarding data found for user")

website_url = user_data_service.get_user_website_url(user_id)
if user_data.get("website_analysis"):
user_data["website_url"] = website_url

return user_data

except HTTPException:
raise

except Exception as e:
logger.error(f"Error getting user data: {str(e)}")
Expand All @@ -33,20 +42,29 @@ async def get_user_data():
db_session.close()

@router.get("/website-url")
async def get_website_url():
async def get_website_url(current_user: dict = Depends(get_current_user)):
"""Get the user's website URL from onboarding data."""
db_session = None
try:
user_id = str(current_user.get("id"))
db_session = get_db_session()
if not db_session:
raise HTTPException(status_code=500, detail="Database connection failed")

user_data_service = UserDataService(db_session)
website_url = user_data_service.get_user_website_url()
onboarding_data = user_data_service.get_user_onboarding_data(user_id)
if not onboarding_data:
raise HTTPException(status_code=404, detail="No onboarding data found for user")

website_url = user_data_service.get_user_website_url(user_id)

if not website_url:
return {"website_url": None, "message": "No website URL found"}

return {"website_url": website_url}

except HTTPException:
raise

except Exception as e:
logger.error(f"Error getting website URL: {str(e)}")
Expand All @@ -56,24 +74,33 @@ async def get_website_url():
db_session.close()

@router.get("/onboarding")
async def get_onboarding_data():
async def get_onboarding_data(current_user: dict = Depends(get_current_user)):
"""Get onboarding data for the user."""
db_session = None
try:
user_id = str(current_user.get("id"))
db_session = get_db_session()
if not db_session:
raise HTTPException(status_code=500, detail="Database connection failed")

user_data_service = UserDataService(db_session)
onboarding_data = user_data_service.get_user_onboarding_data()
onboarding_data = user_data_service.get_user_onboarding_data(user_id)

if not onboarding_data:
return {"message": "No onboarding data found"}
raise HTTPException(status_code=404, detail="No onboarding data found for user")

website_url = user_data_service.get_user_website_url(user_id)
if onboarding_data.get("website_analysis"):
onboarding_data["website_url"] = website_url

return onboarding_data

except HTTPException:
raise

except Exception as e:
logger.error(f"Error getting onboarding data: {str(e)}")
raise HTTPException(status_code=500, detail=f"Error getting onboarding data: {str(e)}")
finally:
if db_session:
db_session.close()
db_session.close()
10 changes: 5 additions & 5 deletions backend/services/user_data_service.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,19 +17,19 @@ def __init__(self, db_session: Session):
self.db = db_session
self.integration_service = OnboardingDataIntegrationService()

def get_user_website_url(self, user_id: int = 1) -> Optional[str]:
def get_user_website_url(self, user_id: str) -> Optional[str]:
"""
Get the website URL for a user from their onboarding data.

Args:
user_id: The user ID (defaults to 1 for single-user setup)
user_id: The user ID

Returns:
Website URL or None if not found
"""
try:
# Use SSOT integration service
integrated_data = self.integration_service.get_integrated_data_sync(str(user_id), self.db)
integrated_data = self.integration_service.get_integrated_data_sync(user_id, self.db)
website_analysis = integrated_data.get('website_analysis', {})

if not website_analysis:
Expand All @@ -52,7 +52,7 @@ def get_user_onboarding_data(self, user_id: str) -> Optional[Dict[str, Any]]:
Get comprehensive onboarding data for a user.

Args:
user_id: The user ID (defaults to 1 for single-user setup)
user_id: The user ID

Returns:
Dictionary with onboarding data or None if not found
Expand Down Expand Up @@ -81,7 +81,7 @@ def get_user_website_analysis(self, user_id: str) -> Optional[Dict[str, Any]]:
Get website analysis data for a user.

Args:
user_id: The user ID (defaults to 1 for single-user setup)
user_id: The user ID

Returns:
Website analysis data or None if not found
Expand Down