1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135
|
#ifndef __CL_SSL_FRAMEWORK_H
#define __CL_SSL_FRAMEWORK_H
/*___INFO__MARK_BEGIN__*/
/*************************************************************************
*
* The Contents of this file are made available subject to the terms of
* the Sun Industry Standards Source License Version 1.2
*
* Sun Microsystems Inc., March, 2001
*
*
* Sun Industry Standards Source License Version 1.2
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.2 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://gridengine.sunsource.net/Gridengine_SISSL_license.html
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2001 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
************************************************************************/
/*___INFO__MARK_END__*/
#include "comm/lists/cl_lists.h"
#include "comm/cl_data_types.h"
#define CL_COM_SSL_FRAMEWORK_MAX_INT 32767
#define CL_COM_SSL_FRAMEWORK_MIN_INT_SIZE 4
/* ssl specific functions */
int cl_com_ssl_framework_setup(void);
int cl_com_ssl_framework_cleanup(void);
/* debug functions */
void cl_dump_ssl_private(cl_com_connection_t* connection);
/* global security function */
int cl_com_ssl_get_unique_id(cl_com_handle_t* handle,
char* un_resolved_hostname, char* component_name, unsigned long component_id,
char** uniqueIdentifier );
/* get/set functions */
int cl_com_ssl_get_connect_port(cl_com_connection_t* connection,
int* port);
int cl_com_ssl_set_connect_port(cl_com_connection_t* connection,
int port);
int cl_com_ssl_get_service_port(cl_com_connection_t* connection,
int* port);
int cl_com_ssl_get_fd(cl_com_connection_t* connection,
int* fd);
int cl_com_ssl_get_client_socket_in_port(cl_com_connection_t* connection,
int* port);
/* create new connection object */
int cl_com_ssl_setup_connection(cl_com_connection_t** connection,
int server_port,
int connect_port,
cl_xml_connection_type_t data_flow_type,
cl_xml_connection_autoclose_t auto_close_mode,
cl_framework_t framework_type,
cl_xml_data_format_t data_format_type,
cl_tcp_connect_t tcp_connect_mode,
cl_ssl_setup_t* ssl_setup);
/* create/destroy connection functions */
int cl_com_ssl_open_connection(cl_com_connection_t* connection,
int timeout);
int cl_com_ssl_close_connection(cl_com_connection_t** connection);
int cl_com_ssl_connection_complete_shutdown(cl_com_connection_t* connection);
int cl_com_ssl_connection_complete_accept(cl_com_connection_t* connection,
long timeout);
/* read/write functions */
int cl_com_ssl_write(cl_com_connection_t* connection,
cl_byte_t* message,
unsigned long size,
unsigned long* only_one_write);
int cl_com_ssl_read(cl_com_connection_t* connection,
cl_byte_t* message,
unsigned long size,
unsigned long* only_one_read);
int cl_com_ssl_read_GMSH(cl_com_connection_t* connection,
unsigned long* only_one_read);
/* create service, accept new connections */
int cl_com_ssl_connection_request_handler_setup(cl_com_connection_t* connection, bool only_prepare_service);
int cl_com_ssl_connection_request_handler(cl_com_connection_t* connection,
cl_com_connection_t** new_connection);
int cl_com_ssl_connection_request_handler_cleanup(cl_com_connection_t* connection);
/* select mechanism */
int cl_com_ssl_open_connection_request_handler(cl_com_poll_t* poll_handle,
cl_com_handle_t* handle,
cl_raw_list_t* connection_list,
cl_com_connection_t* service_connection,
int timeout_val_sec,
int timeout_val_usec,
cl_select_method_t select_mode);
#endif /* __CL_SSL_FRAMEWORK_H */
|