mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 09:42:35 +00:00 
			
		
		
		
	 436693c0c9
			
		
	
	
		436693c0c9
		
	
	
	
	
		
			
			The callback should be called as soon as the connection is established, and if we actually set the callback when it already is, we expect it to be called immediately.
		
			
				
	
	
		
			97 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Dex♪ <dexes.ttp@gmail.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <LibWebSocket/Impl/TLSv12WebSocketConnectionImpl.h>
 | |
| 
 | |
| namespace WebSocket {
 | |
| 
 | |
| TLSv12WebSocketConnectionImpl::TLSv12WebSocketConnectionImpl(Core::Object* parent)
 | |
|     : AbstractWebSocketImpl(parent)
 | |
| {
 | |
| }
 | |
| 
 | |
| TLSv12WebSocketConnectionImpl::~TLSv12WebSocketConnectionImpl()
 | |
| {
 | |
|     discard_connection();
 | |
| }
 | |
| 
 | |
| void TLSv12WebSocketConnectionImpl::connect(ConnectionInfo const& connection)
 | |
| {
 | |
|     VERIFY(!m_socket);
 | |
|     VERIFY(on_connected);
 | |
|     VERIFY(on_connection_error);
 | |
|     VERIFY(on_ready_to_read);
 | |
|     m_socket = TLS::TLSv12::construct(this);
 | |
| 
 | |
|     m_socket->set_root_certificates(DefaultRootCACertificates::the().certificates());
 | |
|     m_socket->on_tls_error = [this](TLS::AlertDescription) {
 | |
|         on_connection_error();
 | |
|     };
 | |
|     m_socket->on_tls_ready_to_read = [this](auto&) {
 | |
|         on_ready_to_read();
 | |
|     };
 | |
|     m_socket->set_on_tls_ready_to_write([this](auto& tls) {
 | |
|         tls.set_on_tls_ready_to_write(nullptr);
 | |
|         on_connected();
 | |
|     });
 | |
|     m_socket->on_tls_finished = [this] {
 | |
|         on_connection_error();
 | |
|     };
 | |
|     m_socket->on_tls_certificate_request = [](auto&) {
 | |
|         // FIXME : Once we handle TLS certificate requests, handle it here as well.
 | |
|     };
 | |
|     bool success = m_socket->connect(connection.url().host(), connection.url().port_or_default());
 | |
|     if (!success) {
 | |
|         deferred_invoke([this] {
 | |
|             on_connection_error();
 | |
|         });
 | |
|     }
 | |
| }
 | |
| 
 | |
| bool TLSv12WebSocketConnectionImpl::send(ReadonlyBytes data)
 | |
| {
 | |
|     return m_socket->write(data);
 | |
| }
 | |
| 
 | |
| bool TLSv12WebSocketConnectionImpl::can_read_line()
 | |
| {
 | |
|     return m_socket->can_read_line();
 | |
| }
 | |
| 
 | |
| String TLSv12WebSocketConnectionImpl::read_line(size_t size)
 | |
| {
 | |
|     return m_socket->read_line(size);
 | |
| }
 | |
| 
 | |
| bool TLSv12WebSocketConnectionImpl::can_read()
 | |
| {
 | |
|     return m_socket->can_read();
 | |
| }
 | |
| 
 | |
| ByteBuffer TLSv12WebSocketConnectionImpl::read(int max_size)
 | |
| {
 | |
|     return m_socket->read(max_size);
 | |
| }
 | |
| 
 | |
| bool TLSv12WebSocketConnectionImpl::eof()
 | |
| {
 | |
|     return m_socket->eof();
 | |
| }
 | |
| 
 | |
| void TLSv12WebSocketConnectionImpl::discard_connection()
 | |
| {
 | |
|     if (!m_socket)
 | |
|         return;
 | |
|     m_socket->on_tls_connected = nullptr;
 | |
|     m_socket->on_tls_error = nullptr;
 | |
|     m_socket->on_tls_finished = nullptr;
 | |
|     m_socket->on_tls_certificate_request = nullptr;
 | |
|     m_socket->on_ready_to_read = nullptr;
 | |
|     remove_child(*m_socket);
 | |
|     m_socket = nullptr;
 | |
| }
 | |
| 
 | |
| }
 |