file_manager: report file and directory permissions
Signed-off-by: Eric Callahan <arksine.code@gmail.com> fix
This commit is contained in:
parent
1dd89bac4b
commit
4c42b8d072
|
@ -229,7 +229,7 @@ class FileManager:
|
||||||
if action == 'GET':
|
if action == 'GET':
|
||||||
is_extended = web_request.get_boolean('extended', False)
|
is_extended = web_request.get_boolean('extended', False)
|
||||||
# Get list of files and subdirectories for this target
|
# Get list of files and subdirectories for this target
|
||||||
dir_info = self._list_directory(dir_path, is_extended)
|
dir_info = self._list_directory(dir_path, root, is_extended)
|
||||||
return dir_info
|
return dir_info
|
||||||
async with self.write_mutex:
|
async with self.write_mutex:
|
||||||
result = {
|
result = {
|
||||||
|
@ -368,6 +368,7 @@ class FileManager:
|
||||||
|
|
||||||
def _list_directory(self,
|
def _list_directory(self,
|
||||||
path: str,
|
path: str,
|
||||||
|
root: str,
|
||||||
is_extended: bool = False
|
is_extended: bool = False
|
||||||
) -> Dict[str, Any]:
|
) -> Dict[str, Any]:
|
||||||
if not os.path.isdir(path):
|
if not os.path.isdir(path):
|
||||||
|
@ -378,7 +379,7 @@ class FileManager:
|
||||||
full_path = os.path.join(path, fname)
|
full_path = os.path.join(path, fname)
|
||||||
if not os.path.exists(full_path):
|
if not os.path.exists(full_path):
|
||||||
continue
|
continue
|
||||||
path_info = self.get_path_info(full_path)
|
path_info = self.get_path_info(full_path, root)
|
||||||
if os.path.isdir(full_path):
|
if os.path.isdir(full_path):
|
||||||
path_info['dirname'] = fname
|
path_info['dirname'] = fname
|
||||||
flist['dirs'].append(path_info)
|
flist['dirs'].append(path_info)
|
||||||
|
@ -398,11 +399,21 @@ class FileManager:
|
||||||
flist['disk_usage'] = usage._asdict()
|
flist['disk_usage'] = usage._asdict()
|
||||||
return flist
|
return flist
|
||||||
|
|
||||||
def get_path_info(self, path: str) -> Dict[str, Any]:
|
def get_path_info(self, path: str, root: str) -> Dict[str, Any]:
|
||||||
modified = os.path.getmtime(path)
|
fstat = os.stat(path)
|
||||||
size = os.path.getsize(path)
|
real_path = os.path.realpath(path)
|
||||||
path_info = {'modified': modified, 'size': size}
|
permissions = "rw"
|
||||||
return path_info
|
if (
|
||||||
|
(os.path.islink(path) and os.path.isfile(real_path)) or
|
||||||
|
not os.access(real_path, os.R_OK | os.W_OK) or
|
||||||
|
root not in FULL_ACCESS_ROOTS
|
||||||
|
):
|
||||||
|
permissions = "r"
|
||||||
|
return {
|
||||||
|
'modified': fstat.st_mtime,
|
||||||
|
'size': fstat.st_size,
|
||||||
|
'permissions': permissions
|
||||||
|
}
|
||||||
|
|
||||||
def gen_temp_upload_path(self) -> str:
|
def gen_temp_upload_path(self) -> str:
|
||||||
loop_time = int(self.event_loop.get_loop_time())
|
loop_time = int(self.event_loop.get_loop_time())
|
||||||
|
@ -549,12 +560,13 @@ class FileManager:
|
||||||
await asyncio.sleep(.1)
|
await asyncio.sleep(.1)
|
||||||
if upload_info['unzip_ufp']:
|
if upload_info['unzip_ufp']:
|
||||||
tmp_path = upload_info['tmp_file_path']
|
tmp_path = upload_info['tmp_file_path']
|
||||||
finfo = self.get_path_info(tmp_path)
|
finfo = self.get_path_info(tmp_path, upload_info['root'])
|
||||||
finfo['ufp_path'] = tmp_path
|
finfo['ufp_path'] = tmp_path
|
||||||
else:
|
else:
|
||||||
shutil.move(upload_info['tmp_file_path'],
|
shutil.move(upload_info['tmp_file_path'],
|
||||||
upload_info['dest_path'])
|
upload_info['dest_path'])
|
||||||
finfo = self.get_path_info(upload_info['dest_path'])
|
finfo = self.get_path_info(upload_info['dest_path'],
|
||||||
|
upload_info['root'])
|
||||||
except Exception:
|
except Exception:
|
||||||
logging.exception("Upload Write Error")
|
logging.exception("Upload Write Error")
|
||||||
raise self.server.error("Unable to save file", 500)
|
raise self.server.error("Unable to save file", 500)
|
||||||
|
@ -596,7 +608,7 @@ class FileManager:
|
||||||
if not os.path.exists(full_path):
|
if not os.path.exists(full_path):
|
||||||
continue
|
continue
|
||||||
fname = full_path[len(path) + 1:]
|
fname = full_path[len(path) + 1:]
|
||||||
finfo = self.get_path_info(full_path)
|
finfo = self.get_path_info(full_path, root)
|
||||||
filelist[fname] = finfo
|
filelist[fname] = finfo
|
||||||
if list_format:
|
if list_format:
|
||||||
flist: List[Dict[str, Any]] = []
|
flist: List[Dict[str, Any]] = []
|
||||||
|
@ -638,7 +650,7 @@ class FileManager:
|
||||||
if not os.path.isdir(dir_path):
|
if not os.path.isdir(dir_path):
|
||||||
raise self.server.error(
|
raise self.server.error(
|
||||||
f"Directory does not exist ({dir_path})")
|
f"Directory does not exist ({dir_path})")
|
||||||
flist = self._list_directory(dir_path)
|
flist = self._list_directory(dir_path, root)
|
||||||
if simple_format:
|
if simple_format:
|
||||||
simple_list = []
|
simple_list = []
|
||||||
for dirobj in flist['dirs']:
|
for dirobj in flist['dirs']:
|
||||||
|
@ -1114,7 +1126,7 @@ class INotifyHandler:
|
||||||
def parse_gcode_metadata(self, file_path: str) -> asyncio.Event:
|
def parse_gcode_metadata(self, file_path: str) -> asyncio.Event:
|
||||||
rel_path = self.file_manager.get_relative_path("gcodes", file_path)
|
rel_path = self.file_manager.get_relative_path("gcodes", file_path)
|
||||||
try:
|
try:
|
||||||
path_info = self.file_manager.get_path_info(file_path)
|
path_info = self.file_manager.get_path_info(file_path, "gcodes")
|
||||||
except Exception:
|
except Exception:
|
||||||
logging.exception(
|
logging.exception(
|
||||||
f"Error retreiving path info for file {file_path}")
|
f"Error retreiving path info for file {file_path}")
|
||||||
|
@ -1287,7 +1299,7 @@ class INotifyHandler:
|
||||||
is_valid = True
|
is_valid = True
|
||||||
if os.path.exists(full_path):
|
if os.path.exists(full_path):
|
||||||
try:
|
try:
|
||||||
file_info = self.file_manager.get_path_info(full_path)
|
file_info = self.file_manager.get_path_info(full_path, root)
|
||||||
except Exception:
|
except Exception:
|
||||||
is_valid = False
|
is_valid = False
|
||||||
elif action not in ["delete_file", "delete_dir"]:
|
elif action not in ["delete_file", "delete_dir"]:
|
||||||
|
|
Loading…
Reference in New Issue