From 7d0e104cb63c737509efe214a3d7e486f429712c Mon Sep 17 00:00:00 2001 From: Hiran Wijesinghe Date: Fri, 23 Feb 2024 04:06:24 -0500 Subject: [PATCH] sanitize file path better * replaces unsupport characters with underscores _ * github artifact upload does not support the special chars: - Double quote " - Colon : - Less than < - Greater than > - Vertical bar | - Asterisk * - Question mark ? - Carriage return \r - Line feed \n * note that \r, \n are included in whitespace regex symbol \s --- src/srx_caproto_iocs/base.py | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/src/srx_caproto_iocs/base.py b/src/srx_caproto_iocs/base.py index 9fb1faf..570794d 100644 --- a/src/srx_caproto_iocs/base.py +++ b/src/srx_caproto_iocs/base.py @@ -1,5 +1,6 @@ from __future__ import annotations +import re import textwrap import threading import time as ttime @@ -116,12 +117,15 @@ async def stage(self, instance, value): if value == StageStates.STAGED.value: # Steps: - # 1. Render 'write_dir' with datetime lib and replace any blank spaces with underscores. - # 2. Render 'file_name' with .format(). - # 3. Replace blank spaces with underscores. + # 1. Render 'write_dir' with datetime lib + # 2. Replace unsupported characters with underscores (sanitize). + # 3. Check if sanitized 'write_dir' exists + # 4. Render 'file_name' with .format(). + # 5. Replace unsupported characters with underscores. + sanitizer = re.compile(pattern=r"[\":<>|\*\?\s]") date = now(as_object=True) - write_dir = Path(date.strftime(self.write_dir.value).replace(" ", "_")) + write_dir = Path(sanitizer.sub("_", date.strftime(self.write_dir.value))) if not write_dir.exists(): msg = f"Path '{write_dir}' does not exist." print(msg) @@ -136,8 +140,7 @@ async def stage(self, instance, value): full_file_path = write_dir / file_name.format( num=self.frame_num.value, uid=uid, suid=uid[:8] ) - full_file_path = str(full_file_path) - full_file_path.replace(" ", "_") + full_file_path = sanitizer.sub("_", str(full_file_path)) print(f"{now()}: {full_file_path = }")