utils.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. import black
  2. import markdown
  3. from open_webui.models.chats import ChatTitleMessagesForm
  4. from open_webui.config import DATA_DIR, ENABLE_ADMIN_EXPORT
  5. from open_webui.constants import ERROR_MESSAGES
  6. from fastapi import APIRouter, Depends, HTTPException, Request, Response, status
  7. from pydantic import BaseModel
  8. from starlette.responses import FileResponse
  9. from open_webui.utils.misc import get_gravatar_url
  10. from open_webui.utils.pdf_generator import PDFGenerator
  11. from open_webui.utils.auth import get_admin_user, get_verified_user
  12. from open_webui.utils.code_interpreter import execute_code_jupyter
  13. router = APIRouter()
  14. @router.get("/gravatar")
  15. async def get_gravatar(email: str, user=Depends(get_verified_user)):
  16. return get_gravatar_url(email)
  17. class CodeForm(BaseModel):
  18. code: str
  19. @router.post("/code/format")
  20. async def format_code(form_data: CodeForm, user=Depends(get_verified_user)):
  21. try:
  22. formatted_code = black.format_str(form_data.code, mode=black.Mode())
  23. return {"code": formatted_code}
  24. except black.NothingChanged:
  25. return {"code": form_data.code}
  26. except Exception as e:
  27. raise HTTPException(status_code=400, detail=str(e))
  28. @router.post("/code/execute")
  29. async def execute_code(
  30. request: Request, form_data: CodeForm, user=Depends(get_verified_user)
  31. ):
  32. if request.app.state.config.CODE_EXECUTION_ENGINE == "jupyter":
  33. output = await execute_code_jupyter(
  34. request.app.state.config.CODE_EXECUTION_JUPYTER_URL,
  35. form_data.code,
  36. (
  37. request.app.state.config.CODE_EXECUTION_JUPYTER_AUTH_TOKEN
  38. if request.app.state.config.CODE_EXECUTION_JUPYTER_AUTH == "token"
  39. else None
  40. ),
  41. (
  42. request.app.state.config.CODE_EXECUTION_JUPYTER_AUTH_PASSWORD
  43. if request.app.state.config.CODE_EXECUTION_JUPYTER_AUTH == "password"
  44. else None
  45. ),
  46. request.app.state.config.CODE_EXECUTION_JUPYTER_TIMEOUT,
  47. )
  48. return output
  49. else:
  50. raise HTTPException(
  51. status_code=400,
  52. detail="Code execution engine not supported",
  53. )
  54. class MarkdownForm(BaseModel):
  55. md: str
  56. @router.post("/markdown")
  57. async def get_html_from_markdown(
  58. form_data: MarkdownForm, user=Depends(get_verified_user)
  59. ):
  60. return {"html": markdown.markdown(form_data.md)}
  61. class ChatForm(BaseModel):
  62. title: str
  63. messages: list[dict]
  64. @router.post("/pdf")
  65. async def download_chat_as_pdf(
  66. form_data: ChatTitleMessagesForm, user=Depends(get_verified_user)
  67. ):
  68. try:
  69. pdf_bytes = PDFGenerator(form_data).generate_chat_pdf()
  70. return Response(
  71. content=pdf_bytes,
  72. media_type="application/pdf",
  73. headers={"Content-Disposition": "attachment;filename=chat.pdf"},
  74. )
  75. except Exception as e:
  76. print(e)
  77. raise HTTPException(status_code=400, detail=str(e))
  78. @router.get("/db/download")
  79. async def download_db(user=Depends(get_admin_user)):
  80. if not ENABLE_ADMIN_EXPORT:
  81. raise HTTPException(
  82. status_code=status.HTTP_401_UNAUTHORIZED,
  83. detail=ERROR_MESSAGES.ACCESS_PROHIBITED,
  84. )
  85. from open_webui.internal.db import engine
  86. if engine.name != "sqlite":
  87. raise HTTPException(
  88. status_code=status.HTTP_400_BAD_REQUEST,
  89. detail=ERROR_MESSAGES.DB_NOT_SQLITE,
  90. )
  91. return FileResponse(
  92. engine.url.database,
  93. media_type="application/octet-stream",
  94. filename="webui.db",
  95. )
  96. @router.get("/litellm/config")
  97. async def download_litellm_config_yaml(user=Depends(get_admin_user)):
  98. return FileResponse(
  99. f"{DATA_DIR}/litellm/config.yaml",
  100. media_type="application/octet-stream",
  101. filename="config.yaml",
  102. )