| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | /*************************************************************************/ | 
					
						
							| 
									
										
										
										
											2019-08-28 09:19:52 +02:00
										 |  |  | /*  stream_peer_mbedtls.h                                                */ | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | /*************************************************************************/ | 
					
						
							|  |  |  | /*                       This file is part of:                           */ | 
					
						
							|  |  |  | /*                           GODOT ENGINE                                */ | 
					
						
							|  |  |  | /*                      https://godotengine.org                          */ | 
					
						
							|  |  |  | /*************************************************************************/ | 
					
						
							| 
									
										
										
										
											2022-01-03 21:27:34 +01:00
										 |  |  | /* Copyright (c) 2007-2022 Juan Linietsky, Ariel Manzur.                 */ | 
					
						
							|  |  |  | /* Copyright (c) 2014-2022 Godot Engine contributors (cf. AUTHORS.md).   */ | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | /*                                                                       */ | 
					
						
							|  |  |  | /* Permission is hereby granted, free of charge, to any person obtaining */ | 
					
						
							|  |  |  | /* a copy of this software and associated documentation files (the       */ | 
					
						
							|  |  |  | /* "Software"), to deal in the Software without restriction, including   */ | 
					
						
							|  |  |  | /* without limitation the rights to use, copy, modify, merge, publish,   */ | 
					
						
							|  |  |  | /* distribute, sublicense, and/or sell copies of the Software, and to    */ | 
					
						
							|  |  |  | /* permit persons to whom the Software is furnished to do so, subject to */ | 
					
						
							|  |  |  | /* the following conditions:                                             */ | 
					
						
							|  |  |  | /*                                                                       */ | 
					
						
							|  |  |  | /* The above copyright notice and this permission notice shall be        */ | 
					
						
							|  |  |  | /* included in all copies or substantial portions of the Software.       */ | 
					
						
							|  |  |  | /*                                                                       */ | 
					
						
							|  |  |  | /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,       */ | 
					
						
							|  |  |  | /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF    */ | 
					
						
							|  |  |  | /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/ | 
					
						
							|  |  |  | /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY  */ | 
					
						
							|  |  |  | /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,  */ | 
					
						
							|  |  |  | /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE     */ | 
					
						
							|  |  |  | /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.                */ | 
					
						
							|  |  |  | /*************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-23 23:41:51 +02:00
										 |  |  | #ifndef STREAM_PEER_MBEDTLS_H
 | 
					
						
							|  |  |  | #define STREAM_PEER_MBEDTLS_H
 | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-07 00:46:12 +02:00
										 |  |  | #include "core/io/stream_peer_tls.h"
 | 
					
						
							| 
									
										
										
										
											2022-09-07 08:25:47 +02:00
										 |  |  | #include "tls_context_mbedtls.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-07 00:46:12 +02:00
										 |  |  | class StreamPeerMbedTLS : public StreamPeerTLS { | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2021-02-08 10:57:18 +01:00
										 |  |  | 	Status status = STATUS_DISCONNECTED; | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 	String hostname; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Ref<StreamPeer> base; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-07 00:46:12 +02:00
										 |  |  | 	static StreamPeerTLS *_create_func(); | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	static int bio_recv(void *ctx, unsigned char *buf, size_t len); | 
					
						
							|  |  |  | 	static int bio_send(void *ctx, const unsigned char *buf, size_t len); | 
					
						
							| 
									
										
										
										
											2018-07-14 22:33:30 +02:00
										 |  |  | 	void _cleanup(); | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | protected: | 
					
						
							| 
									
										
										
										
											2022-09-07 08:25:47 +02:00
										 |  |  | 	Ref<TLSContextMbedTLS> tls_ctx; | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-14 22:33:30 +02:00
										 |  |  | 	Error _do_handshake(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | public: | 
					
						
							|  |  |  | 	virtual void poll(); | 
					
						
							| 
									
										
										
										
											2019-07-19 15:29:57 +02:00
										 |  |  | 	virtual Error accept_stream(Ref<StreamPeer> p_base, Ref<CryptoKey> p_key, Ref<X509Certificate> p_cert, Ref<X509Certificate> p_ca_chain = Ref<X509Certificate>()); | 
					
						
							|  |  |  | 	virtual Error connect_to_stream(Ref<StreamPeer> p_base, bool p_validate_certs = false, const String &p_for_hostname = String(), Ref<X509Certificate> p_valid_cert = Ref<X509Certificate>()); | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 	virtual Status get_status() const; | 
					
						
							| 
									
										
										
										
											2022-05-23 15:07:44 -07:00
										 |  |  | 	virtual Ref<StreamPeer> get_stream() const; | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	virtual void disconnect_from_stream(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	virtual Error put_data(const uint8_t *p_data, int p_bytes); | 
					
						
							|  |  |  | 	virtual Error put_partial_data(const uint8_t *p_data, int p_bytes, int &r_sent); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	virtual Error get_data(uint8_t *p_buffer, int p_bytes); | 
					
						
							|  |  |  | 	virtual Error get_partial_data(uint8_t *p_buffer, int p_bytes, int &r_received); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	virtual int get_available_bytes() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-07 08:25:47 +02:00
										 |  |  | 	static void initialize_tls(); | 
					
						
							|  |  |  | 	static void finalize_tls(); | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	StreamPeerMbedTLS(); | 
					
						
							|  |  |  | 	~StreamPeerMbedTLS(); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-23 23:41:51 +02:00
										 |  |  | #endif // STREAM_PEER_MBEDTLS_H
 |