Blame tests/crl_apis.c

Packit aea12f
/*
Packit aea12f
 * Copyright (C) 2016 Red Hat, Inc.
Packit aea12f
 *
Packit aea12f
 * Author: Nikos Mavrogiannopoulos
Packit aea12f
 *
Packit aea12f
 * This file is part of GnuTLS.
Packit aea12f
 *
Packit aea12f
 * GnuTLS is free software; you can redistribute it and/or modify it
Packit aea12f
 * under the terms of the GNU General Public License as published by
Packit aea12f
 * the Free Software Foundation; either version 3 of the License, or
Packit aea12f
 * (at your option) any later version.
Packit aea12f
 *
Packit aea12f
 * GnuTLS is distributed in the hope that it will be useful, but
Packit aea12f
 * WITHOUT ANY WARRANTY; without even the implied warranty of
Packit aea12f
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit aea12f
 * General Public License for more details.
Packit aea12f
 *
Packit aea12f
 * You should have received a copy of the GNU Lesser General Public License
Packit aea12f
 * along with this program.  If not, see <https://www.gnu.org/licenses/>
Packit aea12f
 *
Packit aea12f
 */
Packit aea12f
Packit aea12f
#ifdef HAVE_CONFIG_H
Packit aea12f
#include <config.h>
Packit aea12f
#endif
Packit aea12f
Packit aea12f
#include <stdlib.h>
Packit aea12f
#include <stdio.h>
Packit aea12f
#include <string.h>
Packit aea12f
#include <gnutls/gnutls.h>
Packit aea12f
#include <gnutls/x509.h>
Packit aea12f
#include <assert.h>
Packit aea12f
Packit aea12f
#include "utils.h"
Packit aea12f
#include "cert-common.h"
Packit aea12f
Packit aea12f
static time_t then = 1207000800;
Packit aea12f
Packit aea12f
static time_t mytime(time_t * t)
Packit aea12f
{
Packit aea12f
	if (t)
Packit aea12f
		*t = then;
Packit aea12f
Packit aea12f
	return then;
Packit aea12f
}
Packit aea12f
Packit aea12f
static unsigned char saved_crl_pem[] =
Packit aea12f
	"-----BEGIN X509 CRL-----\n"
Packit aea12f
	"MIICXzCByAIBADANBgkqhkiG9w0BAQsFADAPMQ0wCwYDVQQDEwRDQS0zFw0wODAz\n"
Packit aea12f
	"MzEyMjAwMDBaFw0wODAzMzEyMjAyMDBaMFQwFAIDAQIDFw0wODAzMzEyMjAwMDBa\n"
Packit aea12f
	"MB0CDFejHTI2Wi75obBaUhcNMDgwMzMxMjIwMDAwWjAdAgxXox0yNbNP0Ln15zwX\n"
Packit aea12f
	"DTA4MDMzMTIyMDAwMFqgLzAtMB8GA1UdIwQYMBaAFPmohhljtqQUE2B2DwGaNTbv\n"
Packit aea12f
	"8bSvMAoGA1UdFAQDAgEBMA0GCSqGSIb3DQEBCwUAA4IBgQAFpyifa5AJclRpJfjh\n"
Packit aea12f
	"QOcSoiCJz5QsrGaK5I/UYHcY958hhFjnE2c9g3wYEEt13M2gkgOTXapImPbLXHv+\n"
Packit aea12f
	"cHWGoTqX6+crs7xcC6mFc6JfY7q9O2eP1x386dzCxhsXMti5ml0iOeBpNrMO46Pr\n"
Packit aea12f
	"PuvNaY7OE1UgN0Ha3YjmhP8HtWJSQCMmqIo6vP1/HBSzaXP/cjS7f0WBZemj0eE7\n"
Packit aea12f
	"wwA1GUoUx9wHipvNkCSKy/eQz4fpOJExrvHeb1/N3po9hfZaZJAqR+rsC0j9J+wd\n"
Packit aea12f
	"ZGAdVFKCJUZs0IgsWQqagg0tXGJ8ejdt4yE8zvhhcpf4pcGoYUqtoUPT+Fjnsw7C\n"
Packit aea12f
	"P1GCVZQ2ciGxixljTJFdifhqPshgC1Ytd75MkDYH2RRir/JwypQK9CcqIAOjBzTl\n"
Packit aea12f
	"uk4SkKL2xAIduw6Dz5kAC7G2EM94uODoI/RO5b6eN6Kb/592JrKAfB96jh2wwqW+\n"
Packit aea12f
	"swaA4JPFqNQaiMWW1IXM3VJwXBt8DRSRo46JV5OktvvFRwI=\n"
Packit aea12f
	"-----END X509 CRL-----\n";
Packit aea12f
Packit aea12f
static unsigned char saved_min_crl_pem[] =
Packit aea12f
	"-----BEGIN X509 CRL-----\n"
Packit aea12f
	"MIICUDCBuQIBADANBgkqhkiG9w0BAQsFADAPMQ0wCwYDVQQDEwRDQS0zFw0wODAz\n"
Packit aea12f
	"MzEyMjAwMTBaMFQwFAIDAQIDFw0wODAzMzEyMjAwMTBaMB0CDFejHTI2Wi75obBa\n"
Packit aea12f
	"UhcNMDgwMzMxMjIwMDEwWjAdAgxXox0yNbNP0Ln15zwXDTA4MDMzMTIyMDAxMFqg\n"
Packit aea12f
	"LzAtMB8GA1UdIwQYMBaAFPmohhljtqQUE2B2DwGaNTbv8bSvMAoGA1UdFAQDAgEB\n"
Packit aea12f
	"MA0GCSqGSIb3DQEBCwUAA4IBgQB/Y7MxKf7HpYBoi7N5lNCe7nSd0epQiNPOford\n"
Packit aea12f
	"hGb1ZirZk9m67zg146Cwc0W4ipPzW/OjwgUoVQTm21I7oZj/GPItAABlILd6eRQe\n"
Packit aea12f
	"jYJap0fxiXV7aMRfu2o3qCRGAITQf306H5zJmpdeNxbxzlr3t6IAHBDbLI1WYXiC\n"
Packit aea12f
	"pTHo3wlpwFJEPw5NQ0j6rCAzSH81FHTrEiIOar17uRqeMjbGN6Eo4zjezEx2+ewg\n"
Packit aea12f
	"unsdzx4OWx3KgzsQnyV9EoU6l9jREe519mICx7La6DZkhO4dSPJv6R5jEFitWDNB\n"
Packit aea12f
	"lxZMA5ePrYXuE/3b+Li89R53O+xZxShLQYwBRSHDue44xUv6hh6YNIKDgt4ycIs8\n"
Packit aea12f
	"9JAWsOYJDYUEbAUo+S4sWCU6LzloEvmg7EdJtvJWsScUKK4qbwkDfkBTKjbeBdFj\n"
Packit aea12f
	"w6naZIjzbjMPEe8/T+hmu/txFj3fGj/GzOM1GaJNZ4vMWA4Y6LhB+H1Zf3xK+hV0\n"
Packit aea12f
	"sc0eYw7RpIzEyc9PPz/uM+XabsI=\n"
Packit aea12f
	"-----END X509 CRL-----\n";
Packit aea12f
Packit aea12f
const gnutls_datum_t saved_crl = { saved_crl_pem, sizeof(saved_crl_pem) - 1 };
Packit aea12f
const gnutls_datum_t saved_min_crl =
Packit aea12f
    { saved_min_crl_pem, sizeof(saved_min_crl_pem) - 1 };
Packit aea12f
Packit aea12f
static void append_crt(gnutls_x509_crl_t crl, const gnutls_datum_t * pem)
Packit aea12f
{
Packit aea12f
	gnutls_x509_crt_t crt;
Packit aea12f
	int ret;
Packit aea12f
Packit aea12f
	assert(gnutls_x509_crt_init(&crt) >= 0);
Packit aea12f
	assert(gnutls_x509_crt_import(crt, pem, GNUTLS_X509_FMT_PEM) >= 0);
Packit aea12f
	ret = gnutls_x509_crl_set_crt(crl, crt, mytime(0));
Packit aea12f
	if (ret != 0)
Packit aea12f
		fail("gnutls_x509_crl_set_crt: %s\n", gnutls_strerror(ret));
Packit aea12f
Packit aea12f
	gnutls_x509_crt_deinit(crt);
Packit aea12f
}
Packit aea12f
Packit aea12f
static void append_aki(gnutls_x509_crl_t crl, const gnutls_datum_t * pem)
Packit aea12f
{
Packit aea12f
	gnutls_x509_crt_t crt;
Packit aea12f
	int ret;
Packit aea12f
	unsigned char aki[128];
Packit aea12f
	size_t aki_size;
Packit aea12f
Packit aea12f
	assert(gnutls_x509_crt_init(&crt) >= 0);
Packit aea12f
	assert(gnutls_x509_crt_import(crt, pem, GNUTLS_X509_FMT_PEM) >= 0);
Packit aea12f
Packit aea12f
	aki_size = sizeof(aki);
Packit aea12f
	assert(gnutls_x509_crt_get_subject_key_id(crt, aki, &aki_size, NULL) >=
Packit aea12f
	       0);
Packit aea12f
Packit aea12f
	ret = gnutls_x509_crl_set_authority_key_id(crl, aki, aki_size);
Packit aea12f
	if (ret != 0)
Packit aea12f
		fail("gnutls_x509_crl_set_authority_key_id: %s\n",
Packit aea12f
		     gnutls_strerror(ret));
Packit aea12f
Packit aea12f
	gnutls_x509_crt_deinit(crt);
Packit aea12f
}
Packit aea12f
Packit aea12f
static void verify_crl(gnutls_x509_crl_t _crl, gnutls_x509_crt_t crt)
Packit aea12f
{
Packit aea12f
	int ret;
Packit aea12f
	gnutls_x509_crl_t crl;
Packit aea12f
	unsigned status;
Packit aea12f
	gnutls_datum_t out;
Packit aea12f
Packit aea12f
	assert(gnutls_x509_crl_export2(_crl, GNUTLS_X509_FMT_DER, &out) >= 0);
Packit aea12f
Packit aea12f
	assert(gnutls_x509_crl_init(&crl) >= 0);
Packit aea12f
	assert(gnutls_x509_crl_import(crl, &out, GNUTLS_X509_FMT_DER) >= 0);
Packit aea12f
Packit aea12f
	gnutls_free(out.data);
Packit aea12f
Packit aea12f
	ret = gnutls_x509_crl_verify(crl, &crt, 1, 0, &status);
Packit aea12f
	if (ret < 0)
Packit aea12f
		fail("gnutls_x509_crl_verify: %s\n", gnutls_strerror(ret));
Packit aea12f
Packit aea12f
	if (status != 0)
Packit aea12f
		fail("gnutls_x509_crl_verify status: %x\n", status);
Packit aea12f
	gnutls_x509_crl_deinit(crl);
Packit aea12f
}
Packit aea12f
Packit aea12f
static void sign_crl(gnutls_x509_crl_t crl, const gnutls_datum_t * cert,
Packit aea12f
		     const gnutls_datum_t * key)
Packit aea12f
{
Packit aea12f
	gnutls_x509_crt_t crt;
Packit aea12f
	gnutls_x509_privkey_t pkey;
Packit aea12f
	int ret;
Packit aea12f
Packit aea12f
	assert(gnutls_x509_crt_init(&crt) >= 0);
Packit aea12f
	assert(gnutls_x509_privkey_init(&pkey) >= 0);
Packit aea12f
Packit aea12f
	assert(gnutls_x509_crt_import(crt, cert, GNUTLS_X509_FMT_PEM) >= 0);
Packit aea12f
	assert(gnutls_x509_privkey_import(pkey, key, GNUTLS_X509_FMT_PEM) >= 0);
Packit aea12f
Packit aea12f
	ret = gnutls_x509_crl_sign(crl, crt, pkey);
Packit aea12f
	if (ret != 0)
Packit aea12f
		fail("gnutls_x509_crl_sign: %s\n", gnutls_strerror(ret));
Packit aea12f
Packit aea12f
	then+=10;
Packit aea12f
Packit aea12f
	verify_crl(crl, crt);
Packit aea12f
Packit aea12f
	gnutls_x509_crt_deinit(crt);
Packit aea12f
	gnutls_x509_privkey_deinit(pkey);
Packit aea12f
}
Packit aea12f
Packit aea12f
static gnutls_x509_crl_t generate_crl(unsigned skip_optional)
Packit aea12f
{
Packit aea12f
	gnutls_x509_crl_t crl;
Packit aea12f
	int ret;
Packit aea12f
Packit aea12f
	success("Generating CRL (%d)\n", skip_optional);
Packit aea12f
Packit aea12f
	ret = gnutls_x509_crl_init(&crl;;
Packit aea12f
	if (ret != 0)
Packit aea12f
		fail("gnutls_x509_crl_init\n");
Packit aea12f
Packit aea12f
	ret = gnutls_x509_crl_set_version(crl, 1);
Packit aea12f
	if (ret != 0)
Packit aea12f
		fail("gnutls_x509_crl_set_version\n");
Packit aea12f
Packit aea12f
	ret = gnutls_x509_crl_set_this_update(crl, mytime(0));
Packit aea12f
	if (ret != 0)
Packit aea12f
		fail("gnutls_x509_crl_set_this_update\n");
Packit aea12f
Packit aea12f
	if (!skip_optional) {
Packit aea12f
		ret = gnutls_x509_crl_set_next_update(crl, mytime(0) + 120);
Packit aea12f
		if (ret != 0)
Packit aea12f
			fail("gnutls_x509_crl_set_next_update\n");
Packit aea12f
	}
Packit aea12f
Packit aea12f
	ret = gnutls_x509_crl_set_crt_serial(crl, "\x01\x02\x03", 3, mytime(0));
Packit aea12f
	if (ret != 0)
Packit aea12f
		fail("gnutls_x509_crl_set_serial %d\n", ret);
Packit aea12f
Packit aea12f
	append_crt(crl, &cli_ca3_cert);
Packit aea12f
	append_crt(crl, &subca3_cert);
Packit aea12f
Packit aea12f
	append_aki(crl, &ca3_cert);
Packit aea12f
Packit aea12f
	ret = gnutls_x509_crl_set_number(crl, "\x01", 1);
Packit aea12f
	if (ret != 0)
Packit aea12f
		fail("gnutls_x509_crl_set_number %d: %s\n",
Packit aea12f
		     ret, gnutls_strerror(ret));
Packit aea12f
Packit aea12f
	sign_crl(crl, &ca3_cert, &ca3_key);
Packit aea12f
Packit aea12f
	return crl;
Packit aea12f
}
Packit aea12f
Packit aea12f
void doit(void)
Packit aea12f
{
Packit aea12f
	gnutls_datum_t out;
Packit aea12f
	gnutls_x509_crl_t crl;
Packit aea12f
Packit aea12f
	gnutls_global_set_time_function(mytime);
Packit aea12f
Packit aea12f
	crl = generate_crl(0);
Packit aea12f
Packit aea12f
	assert(gnutls_x509_crl_export2(crl, GNUTLS_X509_FMT_PEM, &out) >= 0);
Packit aea12f
Packit aea12f
	fprintf(stdout, "%s", out.data);
Packit aea12f
Packit aea12f
	assert(out.size == saved_crl.size);
Packit aea12f
	assert(memcmp(out.data, saved_crl.data, out.size) == 0);
Packit aea12f
Packit aea12f
	gnutls_free(out.data);
Packit aea12f
	gnutls_x509_crl_deinit(crl);
Packit aea12f
Packit aea12f
	/* skip optional parts */
Packit aea12f
	crl = generate_crl(1);
Packit aea12f
Packit aea12f
	assert(gnutls_x509_crl_export2(crl, GNUTLS_X509_FMT_PEM, &out) >= 0);
Packit aea12f
Packit aea12f
	fprintf(stdout, "%s", out.data);
Packit aea12f
Packit aea12f
	assert(out.size == saved_min_crl.size);
Packit aea12f
	assert(memcmp(out.data, saved_min_crl.data, out.size) == 0);
Packit aea12f
Packit aea12f
	gnutls_free(out.data);
Packit aea12f
	gnutls_x509_crl_deinit(crl);
Packit aea12f
Packit aea12f
}