query("SELECT id FROM files WHERE parent=0 AND owner=" . SQLite3::escapeString($owner) . " AND folder='DIRECTORY' " . $share . ";"); $root_ar = $root_db->fetchArray(SQLITE3_NUM); $root_id = $root_ar[0]; if(empty($root_ar[0])){ failure("Seems like the user doesn't want to show his tree: " . $root_id); } $tmp_length = count($folder_array_unsafe); if(empty($folder_array_unsafe[$tmp_length-1])){ $length = $tmp_length-1; } else { $length = $tmp_length; } $parentdir = SQLite3::escapeString($root_id); if(empty($folder_array_unsafe[0])){ return $root_id; // returns the primary key from the root dir } for($i=0; $i<$length; $i++){ $parentdir_db = $db->query("SELECT id, parent FROM files WHERE owner=" . $owner . $share . " AND parent=" . $parentdir . " AND name='" . SQLite3::escapeString($folder_array_unsafe[$i]) . "' COLLATE NOCASE;"); $prim_id = $parentdir_db->fetchArray(SQLITE3_NUM); if($parentdir != $prim_id[1]){ /* $wrong_folder = $folder_array_unsafe[$i]; $working_path[0] = $wrong_folder; for($j=0; $j<$i; $j++){ $working_path[$j] = $folder_array_unsafe[$j]; } get_404($working_path, $wrong_folder); */ return false; } $parentdir = $prim_id[0]; } return $parentdir; // returns the primary key from the last entry in the folder array }