# -*- coding:utf-8 -*- import json import logging from fastapi import Depends, FastAPI, HTTPException, Request, status from fastapi.middleware.cors import CORSMiddleware import schemas from deps import get_token, reset_account_status from utils import generate_lyrics, generate_music, get_feed, get_lyrics, get_credits from cookie import suno_auths app = FastAPI() app.add_middleware( CORSMiddleware, allow_origins=["*"], allow_credentials=True, allow_methods=["*"], allow_headers=["*"], ) # 配置日志 logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s') @app.on_event("startup") async def startup_event(): # 在应用启动时重置所有账号状态 reset_account_status() logging.info("所有账号状态已重置") @app.get("/") async def get_root(): return schemas.Response() @app.post("/generate") async def generate( data: schemas.CustomModeGenerateParam, token: str = Depends(get_token) ): try: resp = await generate_music(data.dict(), token) return resp except Exception as e: logging.error(f"生成音乐失败: {str(e)}") raise HTTPException( detail=str(e), status_code=status.HTTP_500_INTERNAL_SERVER_ERROR ) @app.post("/generate/description-mode") async def generate_with_song_description( data: schemas.DescriptionModeGenerateParam, token: str = Depends(get_token) ): try: resp = await generate_music(data.dict(), token) return resp except Exception as e: logging.error(f"根据描述生成音乐失败: {str(e)}") raise HTTPException( detail=str(e), status_code=status.HTTP_500_INTERNAL_SERVER_ERROR ) @app.get("/feed/{aid}") async def fetch_feed(aid: str, token: str = Depends(get_token)): try: resp = await get_feed(aid, token) return resp except Exception as e: logging.error(f"获取feed失败: {str(e)}") raise HTTPException( detail=str(e), status_code=status.HTTP_500_INTERNAL_SERVER_ERROR ) @app.post("/generate/lyrics/") async def generate_lyrics_post(request: Request, token: str = Depends(get_token)): req = await request.json() prompt = req.get("prompt") if prompt is None: raise HTTPException( detail="prompt is required", status_code=status.HTTP_400_BAD_REQUEST ) try: resp = await generate_lyrics(prompt, token) return resp except Exception as e: logging.error(f"生成歌词失败: {str(e)}") raise HTTPException( detail=str(e), status_code=status.HTTP_500_INTERNAL_SERVER_ERROR ) @app.get("/lyrics/{lid}") async def fetch_lyrics(lid: str, token: str = Depends(get_token)): try: resp = await get_lyrics(lid, token) return resp except Exception as e: logging.error(f"获取歌词失败: {str(e)}") raise HTTPException( detail=str(e), status_code=status.HTTP_500_INTERNAL_SERVER_ERROR ) @app.get("/get_credits") async def fetch_credits(token: str = Depends(get_token)): try: resp = await get_credits(token) return resp except Exception as e: logging.error(f"获取积分失败: {str(e)}") raise HTTPException( detail=str(e), status_code=status.HTTP_500_INTERNAL_SERVER_ERROR ) @app.get("/account_status") async def get_account_status(): status = {} for i, suno_auth in suno_auths.items(): status[i] = { "session_id": suno_auth.get_session_id(), "is_disabled": suno_auth.is_disabled } return status if __name__ == "__main__": import uvicorn uvicorn.run(app, host="0.0.0.0", port=8000)