From bb9d4f024e7cfa1c79fc1e4118774fa4ea2fd3bd Mon Sep 17 00:00:00 2001 From: Alex Vitkov Date: Sat, 13 Feb 2021 11:58:04 +0200 Subject: /php/rename.php --- php/rename.php | 75 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 php/rename.php (limited to 'php') diff --git a/php/rename.php b/php/rename.php new file mode 100644 index 0000000..3721c22 --- /dev/null +++ b/php/rename.php @@ -0,0 +1,75 @@ +home_directory; + +$dir = get_directory($folder, $user); +if (!$dir) { + error_log("/php/rename.php invalid directory"); + http_response_code(409); + exit(0); +} + +// Check if the new filename is taken in the new dir +$contents_of_dir = $database->get_links_of($dir); +foreach ($contents_of_dir as $c) { + if ($c['name'] == $new_filename) { + error_log("/php/rename.php failed - filename $filename taken in $new_folder"); + http_response_code(409); + exit(0); + } +} + +// Get the file node +$file_node = null; +$contents_of_old_dir = $database->get_links_of($dir); +foreach ($contents_of_old_dir as $c) { + if ($c['name'] == $old_filename) { + $file_node = $c['id']; + break; + } +} + +if ($file_node == null) { + error_log("/php/rename.php failed - file $old_folder/$filename doesn't exist"); + http_response_code(409); + exit(0); +} + +// Update the node_link +$move = $database->pdo->prepare(" + UPDATE node_links + SET name = :new_filename + WHERE directory_id = :dir + AND node_id = :file_node + AND name = :old_filename +"); + +$move->bindParam(':dir', $dir); +$move->bindParam(':file_node', $file_node); +$move->bindParam(':old_filename', $old_filename); +$move->bindParam(':new_filename', $new_filename); + +if(!$move->execute()) { + error_log("extremely sad shit"); + http_response_code(409); + exit(0); +} + +?> -- cgit v1.2.3