mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-24 17:09:43 +00:00 
			
		
		
		
	This abstraction will help us to support multiple IPC transport mechanisms going forward. For now, we only have a TransportSocket that implements the same behavior we previously had, using Unix Sockets for IPC.
		
			
				
	
	
		
			49 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2020, Andreas Kling <andreas@ladybird.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <LibCore/SessionManagement.h>
 | |
| #include <LibIPC/Connection.h>
 | |
| 
 | |
| namespace IPC {
 | |
| 
 | |
| #define IPC_CLIENT_CONNECTION(klass, socket_path)                                                                      \
 | |
|     C_OBJECT_ABSTRACT(klass)                                                                                           \
 | |
| public:                                                                                                                \
 | |
|     template<typename Klass = klass, class... Args>                                                                    \
 | |
|     static ErrorOr<NonnullRefPtr<klass>> try_create(Args&&... args)                                                    \
 | |
|     {                                                                                                                  \
 | |
|         auto parsed_socket_path = TRY(Core::SessionManagement::parse_path_with_sid(socket_path));                      \
 | |
|         auto socket = TRY(Core::LocalSocket::connect(move(parsed_socket_path)));                                       \
 | |
|         /* We want to rate-limit our clients */                                                                        \
 | |
|         TRY(socket->set_blocking(true));                                                                               \
 | |
|                                                                                                                        \
 | |
|         return adopt_nonnull_ref_or_enomem(new (nothrow) Klass(IPC::Transport(move(socket)), forward<Args>(args)...)); \
 | |
|     }
 | |
| 
 | |
| template<typename ClientEndpoint, typename ServerEndpoint>
 | |
| class ConnectionToServer : public IPC::Connection<ClientEndpoint, ServerEndpoint>
 | |
|     , public ClientEndpoint::Stub
 | |
|     , public ServerEndpoint::template Proxy<ClientEndpoint> {
 | |
| public:
 | |
|     using ClientStub = typename ClientEndpoint::Stub;
 | |
|     using IPCProxy = typename ServerEndpoint::template Proxy<ClientEndpoint>;
 | |
| 
 | |
|     ConnectionToServer(ClientStub& local_endpoint, Transport transport)
 | |
|         : Connection<ClientEndpoint, ServerEndpoint>(local_endpoint, move(transport))
 | |
|         , ServerEndpoint::template Proxy<ClientEndpoint>(*this, {})
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     virtual void die() override
 | |
|     {
 | |
|         // Override this function if you don't want your app to exit if it loses the connection.
 | |
|         exit(0);
 | |
|     }
 | |
| };
 | |
| 
 | |
| }
 |