|
Packit |
549fdc |
/*
|
|
Packit |
549fdc |
* Copyright (C) 2000-2012 Free Software Foundation, Inc.
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* Author: Nikos Mavrogiannopoulos
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* This file is part of GnuTLS.
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* The GnuTLS is free software; you can redistribute it and/or
|
|
Packit |
549fdc |
* modify it under the terms of the GNU Lesser General Public License
|
|
Packit |
549fdc |
* as published by the Free Software Foundation; either version 2.1 of
|
|
Packit |
549fdc |
* the License, or (at your option) any later version.
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* This library is distributed in the hope that it will be useful, but
|
|
Packit |
549fdc |
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit |
549fdc |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit |
549fdc |
* Lesser General Public License for more details.
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* You should have received a copy of the GNU Lesser General Public License
|
|
Packit |
549fdc |
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
*/
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#ifndef HANDSHAKE_H
|
|
Packit |
549fdc |
#define HANDSHAKE_H
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#include "errors.h"
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_send_handshake(gnutls_session_t session, mbuffer_st * bufel,
|
|
Packit |
549fdc |
gnutls_handshake_description_t type);
|
|
Packit |
549fdc |
int _gnutls_recv_hello_request(gnutls_session_t session, void *data,
|
|
Packit |
549fdc |
uint32_t data_size);
|
|
Packit |
549fdc |
int _gnutls_recv_handshake(gnutls_session_t session,
|
|
Packit |
549fdc |
gnutls_handshake_description_t type,
|
|
Packit |
549fdc |
unsigned int optional, gnutls_buffer_st * buf);
|
|
Packit |
549fdc |
int _gnutls_generate_session_id(uint8_t * session_id, uint8_t * len);
|
|
Packit |
549fdc |
int _gnutls_set_server_random(gnutls_session_t session, uint8_t * rnd);
|
|
Packit |
549fdc |
int _gnutls_set_client_random(gnutls_session_t session, uint8_t * rnd);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_find_pk_algos_in_ciphersuites(uint8_t * data, int datalen);
|
|
Packit |
549fdc |
int _gnutls_server_select_suite(gnutls_session_t session, uint8_t * data,
|
|
Packit |
549fdc |
unsigned int datalen, unsigned int scsv_only);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_negotiate_version(gnutls_session_t session,
|
|
Packit |
549fdc |
gnutls_protocol_t adv_version, uint8_t major, uint8_t minor);
|
|
Packit |
549fdc |
int _gnutls_user_hello_func(gnutls_session_t session,
|
|
Packit |
549fdc |
gnutls_protocol_t adv_version, uint8_t major, uint8_t minor);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
void _gnutls_handshake_hash_buffers_clear(gnutls_session_t session);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#define STATE session->internals.handshake_state
|
|
Packit |
549fdc |
#define FINAL_STATE session->internals.handshake_final_state
|
|
Packit |
549fdc |
/* This returns true if we have got there
|
|
Packit |
549fdc |
* before (and not finished due to an interrupt).
|
|
Packit |
549fdc |
*/
|
|
Packit |
549fdc |
#define AGAIN(target) (STATE==target?1:0)
|
|
Packit |
549fdc |
#define FAGAIN(target) (FINAL_STATE==target?1:0)
|
|
Packit |
549fdc |
#define AGAIN2(state, target) (state==target?1:0)
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
inline static int handshake_remaining_time(gnutls_session_t session)
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
if (session->internals.handshake_endtime) {
|
|
Packit |
549fdc |
struct timespec now;
|
|
Packit |
549fdc |
gettime(&now;;
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
if (now.tv_sec < session->internals.handshake_endtime)
|
|
Packit |
549fdc |
return (session->internals.handshake_endtime -
|
|
Packit |
549fdc |
now.tv_sec) * 1000;
|
|
Packit |
549fdc |
else
|
|
Packit |
549fdc |
return gnutls_assert_val(GNUTLS_E_TIMEDOUT);
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
return 0;
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_handshake_get_session_hash(gnutls_session_t session, gnutls_datum_t *shash);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_check_id_for_change(gnutls_session_t session);
|
|
Packit |
549fdc |
int _gnutls_check_if_cert_hash_is_same(gnutls_session_t session, gnutls_certificate_credentials_t cred);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#endif
|