mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 15:42:44 +00:00 
			
		
		
		
	 c3351d4b9f
			
		
	
	
		c3351d4b9f
		
	
	
	
	
		
			
			Instead of getting credentials from Process::current(), we now require that they be provided as input to the various VFS functions. This ensures that an atomic set of credentials is used throughout an entire VFS operation.
		
			
				
	
	
		
			36 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <AK/StringView.h>
 | |
| #include <Kernel/FileSystem/VirtualFileSystem.h>
 | |
| #include <Kernel/Process.h>
 | |
| 
 | |
| namespace Kernel {
 | |
| 
 | |
| ErrorOr<FlatPtr> Process::sys$link(Userspace<Syscall::SC_link_params const*> user_params)
 | |
| {
 | |
|     VERIFY_NO_PROCESS_BIG_LOCK(this);
 | |
|     TRY(require_promise(Pledge::cpath));
 | |
|     auto params = TRY(copy_typed_from_user(user_params));
 | |
|     auto old_path = TRY(try_copy_kstring_from_user(params.old_path));
 | |
|     auto new_path = TRY(try_copy_kstring_from_user(params.new_path));
 | |
|     TRY(VirtualFileSystem::the().link(credentials(), old_path->view(), new_path->view(), current_directory()));
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| ErrorOr<FlatPtr> Process::sys$symlink(Userspace<Syscall::SC_symlink_params const*> user_params)
 | |
| {
 | |
|     VERIFY_NO_PROCESS_BIG_LOCK(this);
 | |
|     TRY(require_promise(Pledge::cpath));
 | |
|     auto params = TRY(copy_typed_from_user(user_params));
 | |
| 
 | |
|     auto target = TRY(get_syscall_path_argument(params.target));
 | |
|     auto linkpath = TRY(get_syscall_path_argument(params.linkpath));
 | |
|     TRY(VirtualFileSystem::the().symlink(credentials(), target->view(), linkpath->view(), current_directory()));
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| }
 |