/*
* Copyright (C) 2001-2012 Free Software Foundation, Inc.
*
* Author: Nikos Mavrogiannopoulos
*
* This file is part of GnuTLS.
*
* The GnuTLS is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see
*
*/
#include "gnutls_int.h"
#include "gnutls_errors.h"
#include
#include
#include "debug.h"
#include
#ifdef DEBUG
void
_gnutls_dump_mpi (const char *prefix, bigint_t a)
{
char buf[400];
char buf_hex[2 * sizeof (buf)];
size_t n = sizeof buf;
if (_gnutls_mpi_print (a, buf, &n))
strcpy (buf, "[can't print value]"); /* Flawfinder: ignore */
_gnutls_debug_log ("MPI: length: %d\n\t%s%s\n", (int) n, prefix,
_gnutls_bin2hex (buf, n, buf_hex, sizeof (buf_hex),
NULL));
}
void
_gnutls_dump_vector (const char *prefix, const uint8_t *a, size_t a_size)
{
char buf_hex[2 * a_size];
_gnutls_debug_log ("Vector: length: %d\n\t%s%s\n", (int) a_size, prefix,
_gnutls_bin2hex (a, a_size, buf_hex, sizeof (buf_hex),
NULL));
}
#endif
const char *
_gnutls_packet2str (content_type_t packet)
{
switch (packet)
{
case GNUTLS_CHANGE_CIPHER_SPEC:
return "ChangeCipherSpec";
case GNUTLS_ALERT:
return "Alert";
case GNUTLS_HANDSHAKE:
return "Handshake";
case GNUTLS_APPLICATION_DATA:
return "Application Data";
case GNUTLS_HEARTBEAT:
return "HeartBeat";
default:
return "Unknown Packet";
}
}
const char *
_gnutls_handshake2str (gnutls_handshake_description_t handshake)
{
switch (handshake)
{
case GNUTLS_HANDSHAKE_HELLO_REQUEST:
return "HELLO REQUEST";
break;
case GNUTLS_HANDSHAKE_CLIENT_HELLO:
return "CLIENT HELLO";
break;
case GNUTLS_HANDSHAKE_CLIENT_HELLO_V2:
return "SSL2 CLIENT HELLO";
break;
case GNUTLS_HANDSHAKE_SERVER_HELLO:
return "SERVER HELLO";
break;
case GNUTLS_HANDSHAKE_HELLO_VERIFY_REQUEST:
return "HELLO VERIFY REQUEST";
break;
case GNUTLS_HANDSHAKE_CERTIFICATE_PKT:
return "CERTIFICATE";
break;
case GNUTLS_HANDSHAKE_SERVER_KEY_EXCHANGE:
return "SERVER KEY EXCHANGE";
break;
case GNUTLS_HANDSHAKE_CERTIFICATE_REQUEST:
return "CERTIFICATE REQUEST";
break;
case GNUTLS_HANDSHAKE_SERVER_HELLO_DONE:
return "SERVER HELLO DONE";
break;
case GNUTLS_HANDSHAKE_CERTIFICATE_VERIFY:
return "CERTIFICATE VERIFY";
break;
case GNUTLS_HANDSHAKE_CLIENT_KEY_EXCHANGE:
return "CLIENT KEY EXCHANGE";
break;
case GNUTLS_HANDSHAKE_FINISHED:
return "FINISHED";
break;
case GNUTLS_HANDSHAKE_SUPPLEMENTAL:
return "SUPPLEMENTAL";
break;
case GNUTLS_HANDSHAKE_CERTIFICATE_STATUS:
return "CERTIFICATE STATUS";
break;
case GNUTLS_HANDSHAKE_NEW_SESSION_TICKET:
return "NEW SESSION TICKET";
break;
case GNUTLS_HANDSHAKE_CHANGE_CIPHER_SPEC:
return "CHANGE CIPHER SPEC";
break;
default:
return "Unknown Handshake packet";
}
}