mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-26 18:02:06 +00:00 
			
		
		
		
	 d4b65f644e
			
		
	
	
		d4b65f644e
		
	
	
	
	
		
			
			From now on, we don't allow jailed processes to open all device nodes in /dev, but only allow jailed processes to open /dev/full, /dev/zero, /dev/null, and various TTY and PTY devices (and not including virtual consoles) so we basically restrict applications to what they can do when they are in jail. The motivation for this type of restriction is to ensure that even if a remote code execution occurred, the damage that can be done is very small. We also don't restrict reading and writing on device nodes that were already opened, because that limit seems not useful, especially in the case where we do want to provide an OpenFileDescription to such device but nothing further than that.
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Badge.h>
 | |
| #include <Kernel/Devices/CharacterDevice.h>
 | |
| #include <Kernel/DoubleBuffer.h>
 | |
| 
 | |
| namespace Kernel {
 | |
| 
 | |
| class SlavePTY;
 | |
| 
 | |
| class MasterPTY final : public CharacterDevice {
 | |
| public:
 | |
|     static ErrorOr<NonnullLockRefPtr<MasterPTY>> try_create(unsigned index);
 | |
|     virtual ~MasterPTY() override;
 | |
| 
 | |
|     unsigned index() const { return m_index; }
 | |
|     ErrorOr<size_t> on_slave_write(UserOrKernelBuffer const&, size_t);
 | |
|     bool can_write_from_slave() const;
 | |
|     void notify_slave_closed(Badge<SlavePTY>);
 | |
|     bool is_closed() const { return m_closed; }
 | |
| 
 | |
|     virtual ErrorOr<NonnullOwnPtr<KString>> pseudo_path(OpenFileDescription const&) const override;
 | |
| 
 | |
| private:
 | |
|     explicit MasterPTY(unsigned index, NonnullOwnPtr<DoubleBuffer> buffer);
 | |
| 
 | |
|     // ^Device
 | |
|     virtual bool is_openable_by_jailed_processes() const override { return true; }
 | |
| 
 | |
|     // ^CharacterDevice
 | |
|     virtual ErrorOr<size_t> read(OpenFileDescription&, u64, UserOrKernelBuffer&, size_t) override;
 | |
|     virtual ErrorOr<size_t> write(OpenFileDescription&, u64, UserOrKernelBuffer const&, size_t) override;
 | |
|     virtual bool can_read(OpenFileDescription const&, u64) const override;
 | |
|     virtual bool can_write(OpenFileDescription const&, u64) const override;
 | |
|     virtual ErrorOr<void> close() override;
 | |
|     virtual bool is_master_pty() const override { return true; }
 | |
|     virtual ErrorOr<void> ioctl(OpenFileDescription&, unsigned request, Userspace<void*> arg) override;
 | |
|     virtual StringView class_name() const override { return "MasterPTY"sv; }
 | |
| 
 | |
|     LockRefPtr<SlavePTY> m_slave;
 | |
|     unsigned m_index;
 | |
|     bool m_closed { false };
 | |
|     NonnullOwnPtr<DoubleBuffer> m_buffer;
 | |
| };
 | |
| 
 | |
| }
 |