138 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Haxe
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Haxe
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C)2005-2019 Haxe Foundation
 | |
|  *
 | |
|  * 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.
 | |
|  */
 | |
| 
 | |
| package cpp;
 | |
| 
 | |
| @:buildXml('<include name="${HXCPP}/src/hx/libs/ssl/Build.xml"/>')
 | |
| extern class NativeSsl {
 | |
| 	@:native("_hx_ssl_debug_set")
 | |
| 	static function ssl_debug_set(int:Int):Void;
 | |
| 	
 | |
| 	@:native("_hx_ssl_new")
 | |
| 	static function ssl_new(conf:Dynamic):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_close")
 | |
| 	static function ssl_close(ctx:Dynamic):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_handshake")
 | |
| 	static function ssl_handshake(ctx:Dynamic):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_set_socket")
 | |
| 	static function ssl_set_socket(ctx:Dynamic, socket:Dynamic):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_set_hostname")
 | |
| 	static function ssl_set_hostname(ctx:Dynamic, hostname:String):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_get_peer_certificate")
 | |
| 	static function ssl_get_peer_certificate(ctx:Dynamic):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_get_verify_result")
 | |
| 	static function ssl_get_verify_result(ctx:Dynamic):Bool;
 | |
| 
 | |
| 	@:native("_hx_ssl_send_char")
 | |
| 	static function ssl_send_char(ctx:Dynamic, char:Int):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_send")
 | |
| 	static function ssl_send(ctx:Dynamic, buf:haxe.io.BytesData, p:Int, l:Int):Int;
 | |
| 
 | |
| 	@:native("_hx_ssl_write")
 | |
| 	static function ssl_write(ctx:Dynamic, data:haxe.io.BytesData):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_recv_char")
 | |
| 	static function ssl_recv_char(ctx:Dynamic):Int;
 | |
| 
 | |
| 	@:native("_hx_ssl_recv")
 | |
| 	static function ssl_recv(ctx:Dynamic, buf:haxe.io.BytesData, p:Int, l:Int):Int;
 | |
| 
 | |
| 	@:native("_hx_ssl_read")
 | |
| 	static function ssl_read(ctx:Dynamic):haxe.io.BytesData;
 | |
| 
 | |
| 	@:native("_hx_ssl_conf_new")
 | |
| 	static function conf_new(server:Bool):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_conf_close")
 | |
| 	static function conf_close(conf:Dynamic):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_conf_set_ca")
 | |
| 	static function conf_set_ca(conf:Dynamic, cert:Dynamic):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_conf_set_verify")
 | |
| 	static function conf_set_verify(conf:Dynamic, mode:Int):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_conf_set_cert")
 | |
| 	static function conf_set_cert(conf:Dynamic, cert:Dynamic, pkey:Dynamic):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_conf_set_servername_callback")
 | |
| 	static function conf_set_servername_callback(conf:Dynamic, cb:Dynamic):Void;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_load_defaults")
 | |
| 	static function cert_load_defaults():Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_load_file")
 | |
| 	static function cert_load_file(file:String):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_load_path")
 | |
| 	static function cert_load_path(path:String):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_get_subject")
 | |
| 	static function cert_get_subject(cert:Dynamic, field:String):String;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_get_issuer")
 | |
| 	static function cert_get_issuer(cert:Dynamic, field:String):String;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_get_altnames")
 | |
| 	static function cert_get_altnames(cert:Dynamic):Array<String>;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_get_notbefore")
 | |
| 	static function cert_get_notbefore(cert:Dynamic):Array<Int>;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_get_notafter")
 | |
| 	static function cert_get_notafter(cert:Dynamic):Array<Int>;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_get_next")
 | |
| 	static function cert_get_next(cert:Dynamic):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_add_pem")
 | |
| 	static function cert_add_pem(cert:Dynamic, data:String):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_cert_add_der")
 | |
| 	static function cert_add_der(cert:Dynamic, data:haxe.io.BytesData):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_key_from_der")
 | |
| 	static function key_from_der(data:haxe.io.BytesData, pub:Bool):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_key_from_pem")
 | |
| 	static function key_from_pem(data:String, pub:Bool, pass:String):Dynamic;
 | |
| 
 | |
| 	@:native("_hx_ssl_dgst_make")
 | |
| 	static function dgst_make(data:haxe.io.BytesData, alg:String):haxe.io.BytesData;
 | |
| 
 | |
| 	@:native("_hx_ssl_dgst_sign")
 | |
| 	static function dgst_sign(data:haxe.io.BytesData, key:Dynamic, alg:String):haxe.io.BytesData;
 | |
| 
 | |
| 	@:native("_hx_ssl_dgst_verify")
 | |
| 	static function dgst_verify(data:haxe.io.BytesData, sign:haxe.io.BytesData, key:Dynamic, alg:String):Bool;
 | |
| 
 | |
| 	@:native("_hx_ssl_init")
 | |
| 	static function init():Void;
 | |
| }
 |