|
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 GNUTLS_STATE_H
|
|
Packit |
549fdc |
#define GNUTLS_STATE_H
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#include "gnutls_int.h"
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
inline static const gnutls_group_entry_st *
|
|
Packit |
549fdc |
get_group(gnutls_session_t session)
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
return session->security_parameters.grp;
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_session_is_ecc(gnutls_session_t session);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
inline static void
|
|
Packit |
549fdc |
_gnutls_session_group_set(gnutls_session_t session,
|
|
Packit |
549fdc |
const gnutls_group_entry_st *e)
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
_gnutls_handshake_log("HSK[%p]: Selected group %s (%d)\n",
|
|
Packit |
549fdc |
session, e->name, e->id);
|
|
Packit |
549fdc |
session->security_parameters.grp = e;
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
void
|
|
Packit |
549fdc |
_gnutls_record_set_default_version(gnutls_session_t session,
|
|
Packit |
549fdc |
unsigned char major,
|
|
Packit |
549fdc |
unsigned char minor);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
void
|
|
Packit |
549fdc |
_gnutls_hello_set_default_version(gnutls_session_t session,
|
|
Packit |
549fdc |
unsigned char major,
|
|
Packit |
549fdc |
unsigned char minor);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#include <auth.h>
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#define CHECK_AUTH(auth, ret) if (gnutls_auth_get_type(session) != auth) { \
|
|
Packit |
549fdc |
gnutls_assert(); \
|
|
Packit |
549fdc |
return ret; \
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#endif
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_dh_set_secret_bits(gnutls_session_t session, unsigned bits);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_dh_set_peer_public(gnutls_session_t session, bigint_t public);
|
|
Packit |
549fdc |
int _gnutls_dh_save_group(gnutls_session_t session, bigint_t gen,
|
|
Packit |
549fdc |
bigint_t prime);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
static inline int _gnutls_dh_get_min_prime_bits(gnutls_session_t session)
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
if (session->internals.dh_prime_bits != 0)
|
|
Packit |
549fdc |
return session->internals.dh_prime_bits;
|
|
Packit |
549fdc |
else
|
|
Packit |
549fdc |
return gnutls_sec_param_to_pk_bits(GNUTLS_PK_DH,
|
|
Packit |
549fdc |
session->internals.
|
|
Packit |
549fdc |
priorities->level);
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
void _gnutls_handshake_internal_state_clear(gnutls_session_t);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_session_is_resumable(gnutls_session_t session);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_session_is_psk(gnutls_session_t session);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
int _gnutls_openpgp_send_fingerprint(gnutls_session_t session);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
inline static int
|
|
Packit |
549fdc |
_gnutls_PRF(gnutls_session_t session,
|
|
Packit |
549fdc |
const uint8_t * secret, unsigned int secret_size,
|
|
Packit |
549fdc |
const char *label, int label_size, const uint8_t * seed,
|
|
Packit |
549fdc |
int seed_size, int total_bytes, void *ret)
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
return _gnutls_prf_raw(session->security_parameters.prf_mac,
|
|
Packit |
549fdc |
secret_size, secret,
|
|
Packit |
549fdc |
label_size, label,
|
|
Packit |
549fdc |
seed_size, seed,
|
|
Packit |
549fdc |
total_bytes, ret);
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#define DEFAULT_CERT_TYPE GNUTLS_CRT_X509
|