|
Packit Service |
4684c1 |
/*
|
|
Packit Service |
4684c1 |
* Copyright (C) 2000-2012 Free Software Foundation, Inc.
|
|
Packit Service |
4684c1 |
*
|
|
Packit Service |
4684c1 |
* Author: Nikos Mavrogiannopoulos
|
|
Packit Service |
4684c1 |
*
|
|
Packit Service |
4684c1 |
* This file is part of GnuTLS.
|
|
Packit Service |
4684c1 |
*
|
|
Packit Service |
4684c1 |
* The GnuTLS is free software; you can redistribute it and/or
|
|
Packit Service |
4684c1 |
* modify it under the terms of the GNU Lesser General Public License
|
|
Packit Service |
4684c1 |
* as published by the Free Software Foundation; either version 2.1 of
|
|
Packit Service |
4684c1 |
* the License, or (at your option) any later version.
|
|
Packit Service |
4684c1 |
*
|
|
Packit Service |
4684c1 |
* This library is distributed in the hope that it will be useful, but
|
|
Packit Service |
4684c1 |
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit Service |
4684c1 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit Service |
4684c1 |
* Lesser General Public License for more details.
|
|
Packit Service |
4684c1 |
*
|
|
Packit Service |
4684c1 |
* You should have received a copy of the GNU Lesser General Public License
|
|
Packit Service |
4684c1 |
* along with this program. If not, see <https://www.gnu.org/licenses/>
|
|
Packit Service |
4684c1 |
*
|
|
Packit Service |
4684c1 |
*/
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
#ifndef GNUTLS_LIB_STATE_H
|
|
Packit Service |
4684c1 |
#define GNUTLS_LIB_STATE_H
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
#include "gnutls_int.h"
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
void _gnutls_session_client_cert_type_set(gnutls_session_t session,
|
|
Packit Service |
4684c1 |
gnutls_certificate_type_t);
|
|
Packit Service |
4684c1 |
void _gnutls_session_server_cert_type_set(gnutls_session_t session,
|
|
Packit Service |
4684c1 |
gnutls_certificate_type_t);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
inline static const gnutls_group_entry_st *
|
|
Packit Service |
4684c1 |
get_group(gnutls_session_t session)
|
|
Packit Service |
4684c1 |
{
|
|
Packit Service |
4684c1 |
return session->security_parameters.grp;
|
|
Packit Service |
4684c1 |
}
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
int _gnutls_session_is_ecc(gnutls_session_t session);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
inline static void
|
|
Packit Service |
4684c1 |
_gnutls_session_group_set(gnutls_session_t session,
|
|
Packit Service |
4684c1 |
const gnutls_group_entry_st *e)
|
|
Packit Service |
4684c1 |
{
|
|
Packit Service |
4684c1 |
_gnutls_handshake_log("HSK[%p]: Selected group %s (%d)\n",
|
|
Packit Service |
4684c1 |
session, e->name, e->id);
|
|
Packit Service |
4684c1 |
session->security_parameters.grp = e;
|
|
Packit Service |
4684c1 |
}
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
inline static
|
|
Packit Service |
4684c1 |
void set_default_version(gnutls_session_t session, const version_entry_st *ver)
|
|
Packit Service |
4684c1 |
{
|
|
Packit Service |
4684c1 |
if (ver->tls13_sem) {
|
|
Packit Service |
4684c1 |
session->internals.default_record_version[0] = 3;
|
|
Packit Service |
4684c1 |
session->internals.default_record_version[1] = 1;
|
|
Packit Service |
4684c1 |
} else {
|
|
Packit Service |
4684c1 |
session->internals.default_record_version[0] = ver->major;
|
|
Packit Service |
4684c1 |
session->internals.default_record_version[1] = ver->minor;
|
|
Packit Service |
4684c1 |
}
|
|
Packit Service |
4684c1 |
}
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
void
|
|
Packit Service |
4684c1 |
_gnutls_record_set_default_version(gnutls_session_t session,
|
|
Packit Service |
4684c1 |
unsigned char major,
|
|
Packit Service |
4684c1 |
unsigned char minor);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
void
|
|
Packit Service |
4684c1 |
_gnutls_hello_set_default_version(gnutls_session_t session,
|
|
Packit Service |
4684c1 |
unsigned char major,
|
|
Packit Service |
4684c1 |
unsigned char minor);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
#include <auth.h>
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
#define CHECK_AUTH_TYPE(auth, ret) if (gnutls_auth_get_type(session) != auth) { \
|
|
Packit Service |
4684c1 |
gnutls_assert(); \
|
|
Packit Service |
4684c1 |
return ret; \
|
|
Packit Service |
4684c1 |
}
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
int _gnutls_session_cert_type_supported(gnutls_session_t session,
|
|
Packit Service |
4684c1 |
gnutls_certificate_type_t cert_type,
|
|
Packit Service |
4684c1 |
bool check_credentials,
|
|
Packit Service |
4684c1 |
gnutls_ctype_target_t target);
|
|
Packit Service |
4684c1 |
int _gnutls_dh_set_secret_bits(gnutls_session_t session, unsigned bits);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
int _gnutls_dh_set_peer_public(gnutls_session_t session, bigint_t public);
|
|
Packit Service |
4684c1 |
int _gnutls_dh_save_group(gnutls_session_t session, bigint_t gen,
|
|
Packit Service |
4684c1 |
bigint_t prime);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
static inline int _gnutls_dh_get_min_prime_bits(gnutls_session_t session)
|
|
Packit Service |
4684c1 |
{
|
|
Packit Service |
4684c1 |
if (session->internals.dh_prime_bits != 0)
|
|
Packit Service |
4684c1 |
return session->internals.dh_prime_bits;
|
|
Packit Service |
4684c1 |
else
|
|
Packit Service |
4684c1 |
return gnutls_sec_param_to_pk_bits(GNUTLS_PK_DH,
|
|
Packit Service |
4684c1 |
session->internals.
|
|
Packit Service |
4684c1 |
priorities->level);
|
|
Packit Service |
4684c1 |
}
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
void _gnutls_handshake_internal_state_clear(gnutls_session_t);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
int _gnutls_session_is_resumable(gnutls_session_t session);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
int _gnutls_session_is_psk(gnutls_session_t session);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
int _gnutls_openpgp_send_fingerprint(gnutls_session_t session);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
void reset_binders(gnutls_session_t session);
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
inline static int
|
|
Packit Service |
4684c1 |
_gnutls_PRF(gnutls_session_t session,
|
|
Packit Service |
4684c1 |
const uint8_t * secret, unsigned int secret_size,
|
|
Packit Service |
4684c1 |
const char *label, int label_size, const uint8_t * seed,
|
|
Packit Service |
4684c1 |
int seed_size, int total_bytes, void *ret)
|
|
Packit Service |
4684c1 |
{
|
|
Packit Service |
4684c1 |
return _gnutls_prf_raw(session->security_parameters.prf->id,
|
|
Packit Service |
4684c1 |
secret_size, secret,
|
|
Packit Service |
4684c1 |
label_size, label,
|
|
Packit Service |
4684c1 |
seed_size, seed,
|
|
Packit Service |
4684c1 |
total_bytes, ret);
|
|
Packit Service |
4684c1 |
}
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
#define DEFAULT_CERT_TYPE GNUTLS_CRT_X509
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
#endif /* GNUTLS_LIB_STATE_H */
|