|
Packit |
549fdc |
/*
|
|
Packit |
549fdc |
* Copyright (C) 2016, 2017 Red Hat, Inc.
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* Author: Nikos Mavrogiannopoulos
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* This file is part of GnuTLS.
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* GnuTLS is free software; you can redistribute it and/or modify it
|
|
Packit |
549fdc |
* under the terms of the GNU General Public License as published by
|
|
Packit |
549fdc |
* the Free Software Foundation; either version 3 of the License, or
|
|
Packit |
549fdc |
* (at your option) any later version.
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* GnuTLS 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 |
* General Public License for more details.
|
|
Packit |
549fdc |
*
|
|
Packit |
549fdc |
* You should have received a copy of the GNU General Public License
|
|
Packit |
549fdc |
* along with GnuTLS; if not, write to the Free Software Foundation,
|
|
Packit |
549fdc |
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
|
Packit |
549fdc |
*/
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
/* Parts copied from GnuTLS example programs. */
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#ifdef HAVE_CONFIG_H
|
|
Packit |
549fdc |
#include <config.h>
|
|
Packit |
549fdc |
#endif
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#include <stdio.h>
|
|
Packit |
549fdc |
#include <stdlib.h>
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#include <string.h>
|
|
Packit |
549fdc |
#include <gnutls/gnutls.h>
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
#include "utils.h"
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
/* This checks random art encoding */
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
static void encode(const char *test_name, const char *type, unsigned key_size, unsigned char *input, unsigned input_size, const char *expected)
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
int ret;
|
|
Packit |
549fdc |
gnutls_datum_t out;
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
ret = gnutls_random_art(GNUTLS_RANDOM_ART_OPENSSH, type, key_size, input, input_size, &out;;
|
|
Packit |
549fdc |
if (ret < 0) {
|
|
Packit |
549fdc |
fail("%s: gnutls_random_art: %s\n", test_name, gnutls_strerror(ret));
|
|
Packit |
549fdc |
exit(1);
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
if (strlen(expected)!=out.size) {
|
|
Packit |
549fdc |
fail("%s: gnutls_random_art: output has incorrect size (%d, expected %d)\n%s\n", test_name, (int)out.size, (int)strlen(expected), out.data);
|
|
Packit |
549fdc |
exit(1);
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
if (strncasecmp(expected, (char*)out.data, out.size) != 0) {
|
|
Packit |
549fdc |
fail("%s: gnutls_random_art: output does not match the expected:\n%s\n", test_name, out.data);
|
|
Packit |
549fdc |
exit(1);
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
gnutls_free(out.data);
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
return;
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
struct encode_tests_st {
|
|
Packit |
549fdc |
const char *name;
|
|
Packit |
549fdc |
unsigned char *raw;
|
|
Packit |
549fdc |
unsigned raw_size;
|
|
Packit |
549fdc |
const char *key_type;
|
|
Packit |
549fdc |
unsigned key_size;
|
|
Packit |
549fdc |
const char *art;
|
|
Packit |
549fdc |
};
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
struct encode_tests_st encode_tests[] = {
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
.name = "key1",
|
|
Packit |
549fdc |
.raw = (void*)"\x38\x17\x0c\x08\xcb\x45\x8f\xd4\x87\x9c\x34\xb6\xf6\x08\x29\x4c\x50\x31\x2b\xbb",
|
|
Packit |
549fdc |
.raw_size = 20,
|
|
Packit |
549fdc |
.key_type = "RSA",
|
|
Packit |
549fdc |
.key_size = 2048,
|
|
Packit |
549fdc |
.art = "+--[ RSA 2048]----+\n"
|
|
Packit |
549fdc |
"|.o*++==o |\n"
|
|
Packit |
549fdc |
"| + *.===. |\n"
|
|
Packit |
549fdc |
"|. * + +.o |\n"
|
|
Packit |
549fdc |
"| o . o + . |\n"
|
|
Packit |
549fdc |
"|. + S |\n"
|
|
Packit |
549fdc |
"| . o |\n"
|
|
Packit |
549fdc |
"|E |\n"
|
|
Packit |
549fdc |
"| |\n"
|
|
Packit |
549fdc |
"| |\n"
|
|
Packit |
549fdc |
"+-----------------+"
|
|
Packit |
549fdc |
},
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
.name = "key2",
|
|
Packit |
549fdc |
.raw = (void*)"\xf8\xa7\x1c\x08\x76\x47\x2c\x08\x38\x17\x0c\x08\x38\x17\x0c\x08\xcb\x45\x8f\xd4\x87\x9c\xa4\xb6\xf6\xf8\x29\xfc\x50\x3f\x2b\xbb",
|
|
Packit |
549fdc |
.raw_size = 32,
|
|
Packit |
549fdc |
.key_type = "RSA",
|
|
Packit |
549fdc |
.key_size = 3072,
|
|
Packit |
549fdc |
.art = "+--[ RSA 3072]----+\n"
|
|
Packit |
549fdc |
"|@*=*+.o |\n"
|
|
Packit |
549fdc |
"|O.B.+* o |\n"
|
|
Packit |
549fdc |
"|.* +..o o |\n"
|
|
Packit |
549fdc |
"| . . + |\n"
|
|
Packit |
549fdc |
"| oo.o S |\n"
|
|
Packit |
549fdc |
"| ..+o.+ |\n"
|
|
Packit |
549fdc |
"| .o ..oo . |\n"
|
|
Packit |
549fdc |
"| oo...o+ |\n"
|
|
Packit |
549fdc |
"| oE+.o |\n"
|
|
Packit |
549fdc |
"+-----------------+"
|
|
Packit |
549fdc |
},
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
.name = "key3",
|
|
Packit |
549fdc |
.raw = (void*)"\x38\xf7\x0c\x08\xcb\x34\x8a\xd4\xb7\x9c\x34\xb4\xf6\x08\x29\x4c\x50\x3f\x2b\xbb",
|
|
Packit |
549fdc |
.raw_size = 20,
|
|
Packit |
549fdc |
.key_type = "ECDSA",
|
|
Packit |
549fdc |
.key_size = 256,
|
|
Packit |
549fdc |
.art = "+--[ECDSA 256]---+\n"
|
|
Packit |
549fdc |
"|oo. . |\n"
|
|
Packit |
549fdc |
"|o ..o . |\n"
|
|
Packit |
549fdc |
"| + +** |\n"
|
|
Packit |
549fdc |
"|...+***o |\n"
|
|
Packit |
549fdc |
"|. o +=+.S |\n"
|
|
Packit |
549fdc |
"| o o + |\n"
|
|
Packit |
549fdc |
"| . o |\n"
|
|
Packit |
549fdc |
"| . |\n"
|
|
Packit |
549fdc |
"| E |\n"
|
|
Packit |
549fdc |
"+-----------------+"
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
};
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
void doit(void)
|
|
Packit |
549fdc |
{
|
|
Packit |
549fdc |
unsigned i;
|
|
Packit |
549fdc |
|
|
Packit |
549fdc |
for (i=0;i
|
|
Packit |
549fdc |
encode(encode_tests[i].name, encode_tests[i].key_type, encode_tests[i].key_size,
|
|
Packit |
549fdc |
encode_tests[i].raw, encode_tests[i].raw_size, encode_tests[i].art);
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
}
|
|
Packit |
549fdc |
|