Compare commits
4 Commits
v1.4.2-rc.
...
v1.4.2-rc.
| Author | SHA1 | Date | |
|---|---|---|---|
| 042505d5a6 | |||
| 72f3d4a55e | |||
| e8ff0a0dcb | |||
| 9bc6780a8e |
@@ -86,6 +86,10 @@ def load_config(app, config_override=None):
|
|||||||
app.config["FEED_CACHE_ENABLED"] = os.getenv("FEED_CACHE_ENABLED", "true").lower() == "true"
|
app.config["FEED_CACHE_ENABLED"] = os.getenv("FEED_CACHE_ENABLED", "true").lower() == "true"
|
||||||
app.config["FEED_CACHE_MAX_SIZE"] = int(os.getenv("FEED_CACHE_MAX_SIZE", "50"))
|
app.config["FEED_CACHE_MAX_SIZE"] = int(os.getenv("FEED_CACHE_MAX_SIZE", "50"))
|
||||||
|
|
||||||
|
# Upload limits (v1.4.2)
|
||||||
|
# Flask MAX_CONTENT_LENGTH limits request body size (matches media.py MAX_FILE_SIZE)
|
||||||
|
app.config["MAX_CONTENT_LENGTH"] = 50 * 1024 * 1024 # 50MB
|
||||||
|
|
||||||
# Metrics configuration (v1.1.2 Phase 1)
|
# Metrics configuration (v1.1.2 Phase 1)
|
||||||
app.config["METRICS_ENABLED"] = os.getenv("METRICS_ENABLED", "true").lower() == "true"
|
app.config["METRICS_ENABLED"] = os.getenv("METRICS_ENABLED", "true").lower() == "true"
|
||||||
app.config["METRICS_SLOW_QUERY_THRESHOLD"] = float(os.getenv("METRICS_SLOW_QUERY_THRESHOLD", "1.0"))
|
app.config["METRICS_SLOW_QUERY_THRESHOLD"] = float(os.getenv("METRICS_SLOW_QUERY_THRESHOLD", "1.0"))
|
||||||
|
|||||||
@@ -108,6 +108,37 @@ def validate_image(file_data: bytes, filename: str) -> Tuple[bytes, str, int, in
|
|||||||
# Re-open after verify (verify() closes the file)
|
# Re-open after verify (verify() closes the file)
|
||||||
img = Image.open(io.BytesIO(file_data))
|
img = Image.open(io.BytesIO(file_data))
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
|
# v1.4.2: If Pillow can't open, try explicitly as HEIC
|
||||||
|
# iOS sometimes saves HEIC with .jpeg extension
|
||||||
|
if HEIC_SUPPORTED:
|
||||||
|
try:
|
||||||
|
heif_file = pillow_heif.read_heif(file_data)
|
||||||
|
img = Image.frombytes(
|
||||||
|
heif_file.mode,
|
||||||
|
heif_file.size,
|
||||||
|
heif_file.data,
|
||||||
|
"raw",
|
||||||
|
)
|
||||||
|
# Mark as HEIF so conversion happens below
|
||||||
|
img.format = 'HEIF'
|
||||||
|
except Exception as heic_error:
|
||||||
|
# Log the magic bytes and save file for debugging (if in app context)
|
||||||
|
try:
|
||||||
|
magic = file_data[:12].hex() if len(file_data) >= 12 else file_data.hex()
|
||||||
|
current_app.logger.warning(
|
||||||
|
f'Media upload failed both Pillow and HEIC: filename="{filename}", '
|
||||||
|
f'magic_bytes={magic}, pillow_error="{e}", heic_error="{heic_error}"'
|
||||||
|
)
|
||||||
|
# Save failed file for analysis
|
||||||
|
debug_dir = Path(current_app.config.get('DATA_PATH', 'data')) / 'debug'
|
||||||
|
debug_dir.mkdir(parents=True, exist_ok=True)
|
||||||
|
debug_file = debug_dir / f"failed_{datetime.now().strftime('%Y%m%d_%H%M%S')}_{filename}"
|
||||||
|
debug_file.write_bytes(file_data)
|
||||||
|
current_app.logger.info(f'Saved failed upload for analysis: {debug_file}')
|
||||||
|
except RuntimeError:
|
||||||
|
pass # Outside app context (e.g., tests)
|
||||||
|
raise ValueError(f"Invalid or corrupted image: {e}")
|
||||||
|
else:
|
||||||
raise ValueError(f"Invalid or corrupted image: {e}")
|
raise ValueError(f"Invalid or corrupted image: {e}")
|
||||||
|
|
||||||
# HEIC/HEIF conversion (v1.4.2)
|
# HEIC/HEIF conversion (v1.4.2)
|
||||||
|
|||||||
Reference in New Issue
Block a user