file_manager: update request handlers to accept WebRequest objects
Signed-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
870cabfa05
commit
27a17ed5a6
|
@ -102,12 +102,12 @@ class FileManager:
|
||||||
def get_fixed_path_args(self):
|
def get_fixed_path_args(self):
|
||||||
return dict(self.fixed_path_args)
|
return dict(self.fixed_path_args)
|
||||||
|
|
||||||
async def _handle_filelist_request(self, path, method, args):
|
async def _handle_filelist_request(self, web_request):
|
||||||
root = args.get('root', "gcodes")
|
root = web_request.get_str('root', "gcodes")
|
||||||
return self.get_file_list(root, list_format=True, notify=True)
|
return self.get_file_list(root, list_format=True, notify=True)
|
||||||
|
|
||||||
async def _handle_metadata_request(self, path, method, args):
|
async def _handle_metadata_request(self, web_request):
|
||||||
requested_file = args.get('filename')
|
requested_file = web_request.get_str('filename')
|
||||||
metadata = self.gcode_metadata.get(requested_file, None)
|
metadata = self.gcode_metadata.get(requested_file, None)
|
||||||
if metadata is None:
|
if metadata is None:
|
||||||
raise self.server.error(
|
raise self.server.error(
|
||||||
|
@ -115,19 +115,12 @@ class FileManager:
|
||||||
metadata['filename'] = requested_file
|
metadata['filename'] = requested_file
|
||||||
return metadata
|
return metadata
|
||||||
|
|
||||||
async def _handle_directory_request(self, path, method, args):
|
async def _handle_directory_request(self, web_request):
|
||||||
directory = args.get('path', "gcodes")
|
directory = web_request.get_str('path', "gcodes")
|
||||||
root, rel_path, dir_path = self._convert_path(directory)
|
root, rel_path, dir_path = self._convert_path(directory)
|
||||||
method = method.upper()
|
action = web_request.get_action()
|
||||||
if method == 'GET':
|
if action == 'GET':
|
||||||
is_extended = args.get('extended', False)
|
is_extended = web_request.get_boolean('extended', False)
|
||||||
if isinstance(is_extended, str):
|
|
||||||
val = is_extended.lower()
|
|
||||||
if val in ["true", "false"]:
|
|
||||||
is_extended = True if val == "true" else False
|
|
||||||
if not isinstance(is_extended, bool):
|
|
||||||
raise self.server.error(
|
|
||||||
f"Invalid argument for 'extended': {is_extended}")
|
|
||||||
# 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)
|
dir_info = self._list_directory(dir_path)
|
||||||
# Check to see if a filelist update is necessary
|
# Check to see if a filelist update is necessary
|
||||||
|
@ -142,14 +135,14 @@ class FileManager:
|
||||||
if metadata is not None and is_extended:
|
if metadata is not None and is_extended:
|
||||||
f.update(metadata)
|
f.update(metadata)
|
||||||
return dir_info
|
return dir_info
|
||||||
elif method == 'POST' and root in FULL_ACCESS_ROOTS:
|
elif action == 'POST' and root in FULL_ACCESS_ROOTS:
|
||||||
# Create a new directory
|
# Create a new directory
|
||||||
try:
|
try:
|
||||||
os.mkdir(dir_path)
|
os.mkdir(dir_path)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
raise self.server.error(str(e))
|
raise self.server.error(str(e))
|
||||||
self.notify_filelist_changed("create_dir", rel_path, root)
|
self.notify_filelist_changed("create_dir", rel_path, root)
|
||||||
elif method == 'DELETE' and root in FULL_ACCESS_ROOTS:
|
elif action == 'DELETE' and root in FULL_ACCESS_ROOTS:
|
||||||
# Remove a directory
|
# Remove a directory
|
||||||
if directory.strip("/") == root:
|
if directory.strip("/") == root:
|
||||||
raise self.server.error(
|
raise self.server.error(
|
||||||
|
@ -157,9 +150,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 ({directory})")
|
f"Directory does not exist ({directory})")
|
||||||
force = args.get('force', False)
|
force = web_request.get_boolean('force', False)
|
||||||
if isinstance(force, str):
|
|
||||||
force = force.lower() == "true"
|
|
||||||
if force:
|
if force:
|
||||||
# Make sure that the directory does not contain a file
|
# Make sure that the directory does not contain a file
|
||||||
# loaded by the virtual_sdcard
|
# loaded by the virtual_sdcard
|
||||||
|
@ -211,9 +202,10 @@ class FileManager:
|
||||||
disk_path = os.path.join(disk_path, rel_path)
|
disk_path = os.path.join(disk_path, rel_path)
|
||||||
return root, rel_path, disk_path
|
return root, rel_path, disk_path
|
||||||
|
|
||||||
async def _handle_file_move_copy(self, path, method, args):
|
async def _handle_file_move_copy(self, web_request):
|
||||||
source = args.get("source")
|
source = web_request.get_str("source")
|
||||||
destination = args.get("dest")
|
destination = web_request.get_str("dest")
|
||||||
|
ep = web_request.get_endpoint()
|
||||||
if source is None:
|
if source is None:
|
||||||
raise self.server.error("File move/copy request issing source")
|
raise self.server.error("File move/copy request issing source")
|
||||||
if destination is None:
|
if destination is None:
|
||||||
|
@ -230,7 +222,7 @@ class FileManager:
|
||||||
if os.path.exists(dest_path):
|
if os.path.exists(dest_path):
|
||||||
await self._handle_operation_check(dest_path)
|
await self._handle_operation_check(dest_path)
|
||||||
action = op_result = ""
|
action = op_result = ""
|
||||||
if path == "/server/files/move":
|
if ep == "/server/files/move":
|
||||||
if source_root not in FULL_ACCESS_ROOTS:
|
if source_root not in FULL_ACCESS_ROOTS:
|
||||||
raise self.server.error(
|
raise self.server.error(
|
||||||
f"Source path is read-only, cannot move: {source_root}")
|
f"Source path is read-only, cannot move: {source_root}")
|
||||||
|
@ -246,7 +238,7 @@ class FileManager:
|
||||||
else:
|
else:
|
||||||
self.gcode_metadata.remove_file(src_rel_path)
|
self.gcode_metadata.remove_file(src_rel_path)
|
||||||
action = "move_item"
|
action = "move_item"
|
||||||
elif path == "/server/files/copy":
|
elif ep == "/server/files/copy":
|
||||||
try:
|
try:
|
||||||
if os.path.isdir(source_path):
|
if os.path.isdir(source_path):
|
||||||
op_result = shutil.copytree(source_path, dest_path)
|
op_result = shutil.copytree(source_path, dest_path)
|
||||||
|
@ -504,8 +496,8 @@ class FileManager:
|
||||||
return simple_list
|
return simple_list
|
||||||
return flist
|
return flist
|
||||||
|
|
||||||
async def _handle_file_delete(self, path, method, args):
|
async def _handle_file_delete(self, web_request):
|
||||||
file_path = args.get("path")
|
file_path = web_request.get_str("path")
|
||||||
return await self.delete_file(file_path)
|
return await self.delete_file(file_path)
|
||||||
|
|
||||||
async def delete_file(self, path):
|
async def delete_file(self, path):
|
||||||
|
|
Loading…
Reference in New Issue