2015-01-31 09:13:33 +00:00
|
|
|
/**
|
|
|
|
ssldecode.h
|
|
|
|
|
|
|
|
|
|
|
|
Copyright (C) 1999-2000 RTFM, Inc.
|
|
|
|
All Rights Reserved
|
|
|
|
|
|
|
|
This package is a SSLv3/TLS protocol analyzer written by Eric Rescorla
|
|
|
|
<ekr@rtfm.com> and licensed by RTFM, Inc.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
|
|
|
1. Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in the
|
|
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
3. All advertising materials mentioning features or use of this software
|
|
|
|
must display the following acknowledgement:
|
|
|
|
|
|
|
|
This product includes software developed by Eric Rescorla for
|
|
|
|
RTFM, Inc.
|
|
|
|
|
|
|
|
4. Neither the name of RTFM, Inc. nor the name of Eric Rescorla may be
|
|
|
|
used to endorse or promote products derived from this
|
|
|
|
software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY ERIC RESCORLA AND RTFM, INC. ``AS IS'' AND
|
|
|
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY SUCH DAMAGE.
|
|
|
|
|
|
|
|
$Id: ssldecode.h,v 1.3 2001/07/20 23:33:16 ekr Exp $
|
|
|
|
|
|
|
|
|
|
|
|
ekr@rtfm.com Thu Apr 1 15:02:02 1999
|
|
|
|
*/
|
|
|
|
|
2018-06-20 15:28:35 +00:00
|
|
|
|
2015-01-31 09:13:33 +00:00
|
|
|
#ifndef _ssldecode_h
|
|
|
|
#define _ssldecode_h
|
|
|
|
|
2021-01-06 16:52:45 +00:00
|
|
|
#define CRDUMP(a,b,c) P_(P_CR) {Data d; d.data=b; d.len=c; exdump(ssl,a,&d); LF;}
|
|
|
|
#define CRDUMPD(a,b) P_(P_CR) {exdump(ssl,a,b);LF;}
|
2015-01-31 09:13:33 +00:00
|
|
|
|
|
|
|
int ssl_decode_ctx_create PROTO_LIST((ssl_decode_ctx **ctx,
|
2018-07-03 01:55:51 +00:00
|
|
|
char *keyfile,char *password,char *keylogfile));
|
2021-01-15 11:11:37 +00:00
|
|
|
int ssl_decode_ctx_destroy(ssl_decode_ctx **dp);
|
2015-01-31 09:13:33 +00:00
|
|
|
int ssl_decoder_destroy PROTO_LIST((ssl_decoder **dp));
|
|
|
|
int ssl_decoder_create PROTO_LIST((ssl_decoder **dp,ssl_decode_ctx *ctx));
|
|
|
|
int ssl_set_client_random PROTO_LIST((ssl_decoder *dp,
|
|
|
|
UCHAR *msg,int len));
|
|
|
|
int ssl_set_server_random PROTO_LIST((ssl_decoder *dp,
|
|
|
|
UCHAR *msg,int len));
|
|
|
|
int ssl_set_client_session_id PROTO_LIST((ssl_decoder *dp,
|
|
|
|
UCHAR *msg,int len));
|
|
|
|
int ssl_process_server_session_id PROTO_LIST((ssl_obj *obj,ssl_decoder *dp,
|
|
|
|
UCHAR *msg,int len));
|
2020-04-28 11:46:32 +00:00
|
|
|
int ssl_process_client_session_id PROTO_LIST((ssl_obj *obj,ssl_decoder *dp,
|
|
|
|
UCHAR *msg,int len));
|
2015-01-31 09:13:33 +00:00
|
|
|
int ssl_process_client_key_exchange PROTO_LIST((struct ssl_obj_ *,
|
|
|
|
ssl_decoder *d,UCHAR *msg,int len));
|
|
|
|
int ssl_process_change_cipher_spec PROTO_LIST((ssl_obj *ssl,
|
|
|
|
ssl_decoder *d,int direction));
|
2018-06-24 17:37:19 +00:00
|
|
|
int ssl_update_handshake_messages PROTO_LIST((ssl_obj *ssl,
|
2018-06-25 04:43:19 +00:00
|
|
|
Data *data));
|
2015-01-31 09:13:33 +00:00
|
|
|
int ssl_decode_record PROTO_LIST((ssl_obj *ssl,ssl_decoder *dec,int direction,
|
|
|
|
int ct,int version,Data *d));
|
2023-03-11 05:03:19 +00:00
|
|
|
int ssl_tls13_generate_keying_material PROTO_LIST((ssl_obj *obj,ssl_decoder *dec));
|
|
|
|
int ssl_process_handshake_finished PROTO_LIST((ssl_obj* ssl,ssl_decoder *dec, Data *data));
|
|
|
|
int ssl_tls13_update_keying_material PROTO_LIST((ssl_obj *ssl,ssl_decoder *dec,int dir));
|
2015-01-31 09:13:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|