Bläddra i källkod

fix: enhance filename validation and extraction in FileService #16867 (#16869)

tags/1.2.0
GuanMu 7 månader sedan
förälder
incheckning
d65da600e5
Inget konto är kopplat till bidragsgivarens mejladress
1 ändrade filer med 7 tillägg och 1 borttagningar
  1. 7
    1
      api/services/file_service.py

+ 7
- 1
api/services/file_service.py Visa fil

@@ -1,5 +1,6 @@
import datetime
import hashlib
import os
import uuid
from typing import Any, Literal, Union

@@ -38,7 +39,12 @@ class FileService:
source_url: str = "",
) -> UploadFile:
# get file extension
extension = filename.split(".")[-1].lower()
extension = os.path.splitext(filename)[1].lstrip(".").lower()

# check if filename contains invalid characters
if any(c in filename for c in ["/", "\\", ":", "*", "?", '"', "<", ">", "|"]):
raise ValueError("Filename contains invalid characters")

if len(filename) > 200:
filename = filename.split(".")[0][:200] + "." + extension


Laddar…
Avbryt
Spara