| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | /*************************************************************************/ | 
					
						
							| 
									
										
										
										
											2019-01-01 12:46:36 +01:00
										 |  |  | /*  stream_peer_mbed_tls.h                                               */ | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | /*************************************************************************/ | 
					
						
							|  |  |  | /*                       This file is part of:                           */ | 
					
						
							|  |  |  | /*                           GODOT ENGINE                                */ | 
					
						
							|  |  |  | /*                      https://godotengine.org                          */ | 
					
						
							|  |  |  | /*************************************************************************/ | 
					
						
							| 
									
										
										
										
											2019-01-01 12:53:14 +01:00
										 |  |  | /* Copyright (c) 2007-2019 Juan Linietsky, Ariel Manzur.                 */ | 
					
						
							|  |  |  | /* Copyright (c) 2014-2019 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.                */ | 
					
						
							|  |  |  | /*************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef STREAM_PEER_OPEN_SSL_H
 | 
					
						
							|  |  |  | #define STREAM_PEER_OPEN_SSL_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-11 18:13:45 +02:00
										 |  |  | #include "core/io/stream_peer_ssl.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-27 10:43:12 +02:00
										 |  |  | #include <mbedtls/config.h>
 | 
					
						
							|  |  |  | #include <mbedtls/ctr_drbg.h>
 | 
					
						
							|  |  |  | #include <mbedtls/debug.h>
 | 
					
						
							|  |  |  | #include <mbedtls/entropy.h>
 | 
					
						
							|  |  |  | #include <mbedtls/ssl.h>
 | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class StreamPeerMbedTLS : public StreamPeerSSL { | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  | 	Status status; | 
					
						
							|  |  |  | 	String hostname; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Ref<StreamPeer> base; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	static StreamPeerSSL *_create_func(); | 
					
						
							|  |  |  | 	static void _load_certs(const PoolByteArray &p_array); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	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: | 
					
						
							|  |  |  | 	static mbedtls_x509_crt cacert; | 
					
						
							| 
									
										
										
										
											2018-07-14 22:33:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | 	mbedtls_entropy_context entropy; | 
					
						
							|  |  |  | 	mbedtls_ctr_drbg_context ctr_drbg; | 
					
						
							|  |  |  | 	mbedtls_ssl_context ssl; | 
					
						
							|  |  |  | 	mbedtls_ssl_config conf; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	static void _bind_methods(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-14 22:33:30 +02:00
										 |  |  | 	Error _do_handshake(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-09 15:03:34 +01:00
										 |  |  | public: | 
					
						
							|  |  |  | 	virtual void poll(); | 
					
						
							|  |  |  | 	virtual Error accept_stream(Ref<StreamPeer> p_base); | 
					
						
							|  |  |  | 	virtual Error connect_to_stream(Ref<StreamPeer> p_base, bool p_validate_certs = false, const String &p_for_hostname = String()); | 
					
						
							|  |  |  | 	virtual Status get_status() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	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; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	static void initialize_ssl(); | 
					
						
							|  |  |  | 	static void finalize_ssl(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	StreamPeerMbedTLS(); | 
					
						
							|  |  |  | 	~StreamPeerMbedTLS(); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // STREAM_PEER_SSL_H
 |