from fastapi import APIRouter, Depends, Query from fastapi.responses import PlainTextResponse, RedirectResponse from middleware.auth import SignRequired from models.response import ResponseModel import service.oauth callback_router = APIRouter( prefix='/callback', tags=["callback"], ) oauth_router = APIRouter( prefix='/callback/oauth', tags=["callback", "oauth"], ) pay_router = APIRouter( prefix='/callback/pay', tags=["callback", "pay"], ) upload_router = APIRouter( prefix='/callback/upload', tags=["callback", "upload"], ) callback_router.include_router(oauth_router) callback_router.include_router(pay_router) callback_router.include_router(upload_router) @oauth_router.post( path='/qq', summary='QQ互联回调', description='Handle QQ OAuth callback and return user information.', ) def router_callback_qq() -> ResponseModel: """ Handle QQ OAuth callback and return user information. Returns: ResponseModel: A model containing the response data for the QQ OAuth callback. """ pass @oauth_router.get( path='/github', summary='GitHub OAuth 回调', description='Handle GitHub OAuth callback and return user information.', ) async def router_callback_github( code: str = Query(description="The token received from GitHub for authentication.")) -> PlainTextResponse: """ GitHub OAuth 回调处理 - Github 成功响应: - JWT: {"access_token": "gho_xxxxxxxx", "token_type": "bearer", "scope": ""} - User Info:{ "code": "grfessg1312432313421fdgs", "user_data": { "login": "Yuerchu", "id": 114514, "node_id": "xxxxx", "avatar_url": "https://avatars.githubusercontent.com/u/114514?v=4", "gravatar_id": "", "url": "https://api.github.com/users/Yuerchu", "html_url": "https://github.com/Yuerchu", "followers_url": "https://api.github.com/users/Yuerchu/followers", "following_url": "https://api.github.com/users/Yuerchu/following{/other_user}", "gists_url": "https://api.github.com/users/Yuerchu/gists{/gist_id}", "starred_url": "https://api.github.com/users/Yuerchu/starred{/owner}{/repo}", "subscriptions_url": "https://api.github.com/users/Yuerchu/subscriptions", "organizations_url": "https://api.github.com/users/Yuerchu/orgs", "repos_url": "https://api.github.com/users/Yuerchu/repos", "events_url": "https://api.github.com/users/Yuerchu/events{/privacy}", "received_events_url": "https://api.github.com/users/Yuerchu/received_events", "type": "User", "user_view_type": "public", "site_admin": false, "name": "于小丘", "company": null, "blog": "https://www.yxqi.cn", "location": "ChangSha, HuNan, China", "email": "admin@yuxiaoqiu.cn", "hireable": null, "bio": null, "twitter_username": null, "notification_email": "admin@yuxiaoqiu.cn", "public_repos": 17, "public_gists": 0, "followers": 8, "following": 8, "created_at": "2019-04-13T11:17:33Z", "updated_at": "2025-08-20T03:03:16Z" } } - 错误响应示例: - { 'error': 'bad_verification_code', 'error_description': 'The code passed is incorrect or expired.', 'error_uri': 'https://docs.github.com/apps/managing-oauth-apps/troubleshooting-oauth-app-access-token-request-errors/#bad-verification-code' } Returns: PlainTextResponse: A response containing the user information from GitHub. """ try: access_token = await service.oauth.github.get_access_token(code) # [TODO] 把access_token写数据库里 if not access_token: return PlainTextResponse("Failed to retrieve access token from GitHub.", status_code=400) user_data = await service.oauth.github.get_user_info(access_token.access_token) # [TODO] 把user_data写数据库里 return PlainTextResponse(f"User information processed successfully, code: {code}, user_data: {user_data.json_dump()}", status_code=200) except Exception as e: return PlainTextResponse(f"An error occurred: {str(e)}", status_code=500) @pay_router.post( path='/alipay', summary='支付宝支付回调', description='Handle Alipay payment callback and return payment status.', ) def router_callback_alipay() -> ResponseModel: """ Handle Alipay payment callback and return payment status. Returns: ResponseModel: A model containing the response data for the Alipay payment callback. """ pass @pay_router.post( path='/wechat', summary='微信支付回调', description='Handle WeChat Pay payment callback and return payment status.', ) def router_callback_wechat() -> ResponseModel: """ Handle WeChat Pay payment callback and return payment status. Returns: ResponseModel: A model containing the response data for the WeChat Pay payment callback. """ pass @pay_router.post( path='/stripe', summary='Stripe支付回调', description='Handle Stripe payment callback and return payment status.', ) def router_callback_stripe() -> ResponseModel: """ Handle Stripe payment callback and return payment status. Returns: ResponseModel: A model containing the response data for the Stripe payment callback. """ pass @pay_router.get( path='/easypay', summary='易支付回调', description='Handle EasyPay payment callback and return payment status.', ) def router_callback_easypay() -> PlainTextResponse: """ Handle EasyPay payment callback and return payment status. Returns: PlainTextResponse: A response containing the payment status for the EasyPay payment callback. """ pass # return PlainTextResponse("success", status_code=200) @pay_router.get( path='/custom/{order_no}/{id}', summary='自定义支付回调', description='Handle custom payment callback and return payment status.', ) def router_callback_custom(order_no: str, id: str) -> ResponseModel: """ Handle custom payment callback and return payment status. Args: order_no (str): The order number for the payment. id (str): The ID associated with the payment. Returns: ResponseModel: A model containing the response data for the custom payment callback. """ pass @upload_router.post( path='/remote/{session_id}/{key}', summary='远程上传回调', description='Handle remote upload callback and return upload status.', ) def router_callback_remote(session_id: str, key: str) -> ResponseModel: """ Handle remote upload callback and return upload status. Args: session_id (str): The session ID for the upload. key (str): The key for the uploaded file. Returns: ResponseModel: A model containing the response data for the remote upload callback. """ pass @upload_router.post( path='/qiniu/{session_id}', summary='七牛云上传回调', description='Handle Qiniu Cloud upload callback and return upload status.', ) def router_callback_qiniu(session_id: str) -> ResponseModel: """ Handle Qiniu Cloud upload callback and return upload status. Args: session_id (str): The session ID for the upload. Returns: ResponseModel: A model containing the response data for the Qiniu Cloud upload callback. """ pass @upload_router.post( path='/tencent/{session_id}', summary='腾讯云上传回调', description='Handle Tencent Cloud upload callback and return upload status.', ) def router_callback_tencent(session_id: str) -> ResponseModel: """ Handle Tencent Cloud upload callback and return upload status. Args: session_id (str): The session ID for the upload. Returns: ResponseModel: A model containing the response data for the Tencent Cloud upload callback. """ pass @upload_router.post( path='/aliyun/{session_id}', summary='阿里云上传回调', description='Handle Aliyun upload callback and return upload status.', ) def router_callback_aliyun(session_id: str) -> ResponseModel: """ Handle Aliyun upload callback and return upload status. Args: session_id (str): The session ID for the upload. Returns: ResponseModel: A model containing the response data for the Aliyun upload callback. """ pass @upload_router.post( path='/upyun/{session_id}', summary='又拍云上传回调', description='Handle Upyun upload callback and return upload status.', ) def router_callback_upyun(session_id: str) -> ResponseModel: """ Handle Upyun upload callback and return upload status. Args: session_id (str): The session ID for the upload. Returns: ResponseModel: A model containing the response data for the Upyun upload callback. """ pass @upload_router.post( path='/aws/{session_id}', summary='AWS S3上传回调', description='Handle AWS S3 upload callback and return upload status.', ) def router_callback_aws(session_id: str) -> ResponseModel: """ Handle AWS S3 upload callback and return upload status. Args: session_id (str): The session ID for the upload. Returns: ResponseModel: A model containing the response data for the AWS S3 upload callback. """ pass @upload_router.post( path='/onedrive/finish/{session_id}', summary='OneDrive上传完成回调', description='Handle OneDrive upload completion callback and return upload status.', ) def router_callback_onedrive_finish(session_id: str) -> ResponseModel: """ Handle OneDrive upload completion callback and return upload status. Args: session_id (str): The session ID for the upload. Returns: ResponseModel: A model containing the response data for the OneDrive upload completion callback. """ pass @upload_router.get( path='/ondrive/auth', summary='OneDrive授权回调', description='Handle OneDrive authorization callback and return authorization status.', ) def router_callback_onedrive_auth() -> ResponseModel: """ Handle OneDrive authorization callback and return authorization status. Returns: ResponseModel: A model containing the response data for the OneDrive authorization callback. """ pass @upload_router.get( path='/google/auth', summary='Google OAuth 完成', description='Handle Google OAuth completion callback and return authorization status.', ) def router_callback_google_auth() -> ResponseModel: """ Handle Google OAuth completion callback and return authorization status. Returns: ResponseModel: A model containing the response data for the Google OAuth completion callback. """ pass