Blame tests/pkd/pkd_keyutil.c

Packit 6c0a39
/*
Packit 6c0a39
 * pkd_keyutil.c -- pkd test key utilities
Packit 6c0a39
 *
Packit 6c0a39
 * (c) 2014 Jon Simons
Packit 6c0a39
 */
Packit 6c0a39
Packit 6c0a39
#include "config.h"
Packit 6c0a39
Packit 6c0a39
#include <setjmp.h> // for cmocka
Packit 6c0a39
#include <stdarg.h> // for cmocka
Packit 6c0a39
#include <unistd.h> // for cmocka
Packit 6c0a39
#include <cmocka.h>
Packit 6c0a39
Packit 6c0a39
#include <stdlib.h>
Packit 6c0a39
#include <stdio.h>
Packit 6c0a39
#include <string.h>
Packit 6c0a39
#include <unistd.h>
Packit 6c0a39
Packit 6c0a39
#include "torture.h" // for ssh_fips_mode()
Packit 6c0a39
Packit 6c0a39
#include "pkd_client.h"
Packit 6c0a39
#include "pkd_keyutil.h"
Packit 6c0a39
#include "pkd_util.h"
Packit 6c0a39
Packit 6c0a39
void setup_rsa_key() {
Packit 6c0a39
    int rc = 0;
Packit 6c0a39
    if (access(LIBSSH_RSA_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t rsa -q -N \"\" -f "
Packit 6c0a39
                            LIBSSH_RSA_TESTKEY);
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
void setup_ed25519_key() {
Packit 6c0a39
    int rc = 0;
Packit 6c0a39
    if (access(LIBSSH_ED25519_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t ed25519 -q -N \"\" -f "
Packit 6c0a39
                            LIBSSH_ED25519_TESTKEY);
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
#ifdef HAVE_DSA
Packit 6c0a39
void setup_dsa_key() {
Packit 6c0a39
    int rc = 0;
Packit 6c0a39
    if (access(LIBSSH_DSA_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t dsa -q -N \"\" -f "
Packit 6c0a39
                            LIBSSH_DSA_TESTKEY);
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
}
Packit 6c0a39
#endif
Packit 6c0a39
Packit 6c0a39
void setup_ecdsa_keys() {
Packit 6c0a39
    int rc = 0;
Packit 6c0a39
Packit 6c0a39
    if (access(LIBSSH_ECDSA_256_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t ecdsa -b 256 -q -N \"\" -f "
Packit 6c0a39
                            LIBSSH_ECDSA_256_TESTKEY);
Packit 6c0a39
        assert_int_equal(rc, 0);
Packit 6c0a39
    }
Packit 6c0a39
    if (access(LIBSSH_ECDSA_384_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t ecdsa -b 384 -q -N \"\" -f "
Packit 6c0a39
                            LIBSSH_ECDSA_384_TESTKEY);
Packit 6c0a39
        assert_int_equal(rc, 0);
Packit 6c0a39
    }
Packit 6c0a39
    if (access(LIBSSH_ECDSA_521_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t ecdsa -b 521 -q -N \"\" -f "
Packit 6c0a39
                            LIBSSH_ECDSA_521_TESTKEY);
Packit 6c0a39
        assert_int_equal(rc, 0);
Packit 6c0a39
    }
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
void cleanup_rsa_key() {
Packit 6c0a39
    cleanup_key(LIBSSH_RSA_TESTKEY);
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
void cleanup_ed25519_key() {
Packit 6c0a39
    cleanup_key(LIBSSH_ED25519_TESTKEY);
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
#ifdef HAVE_DSA
Packit 6c0a39
void cleanup_dsa_key() {
Packit 6c0a39
    cleanup_key(LIBSSH_DSA_TESTKEY);
Packit 6c0a39
}
Packit 6c0a39
#endif
Packit 6c0a39
Packit 6c0a39
void cleanup_ecdsa_keys() {
Packit 6c0a39
    cleanup_key(LIBSSH_ECDSA_256_TESTKEY);
Packit 6c0a39
    cleanup_key(LIBSSH_ECDSA_384_TESTKEY);
Packit 6c0a39
    cleanup_key(LIBSSH_ECDSA_521_TESTKEY);
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
void setup_openssh_client_keys() {
Packit 6c0a39
    int rc = 0;
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_CA_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t rsa -q -N \"\" -f "
Packit 6c0a39
                            OPENSSH_CA_TESTKEY);
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_RSA_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t rsa -q -N \"\" -f "
Packit 6c0a39
                            OPENSSH_RSA_TESTKEY);
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_RSA_TESTKEY "-cert.pub", F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -I ident -s " OPENSSH_CA_TESTKEY " "
Packit 6c0a39
                            OPENSSH_RSA_TESTKEY ".pub 2>/dev/null");
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_RSA_TESTKEY "-sha256-cert.pub", F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -I ident -t rsa-sha2-256 "
Packit 6c0a39
                            "-s " OPENSSH_CA_TESTKEY " "
Packit 6c0a39
                            OPENSSH_RSA_TESTKEY ".pub 2>/dev/null");
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_ECDSA256_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t ecdsa -b 256 -q -N \"\" -f "
Packit 6c0a39
                            OPENSSH_ECDSA256_TESTKEY);
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_ECDSA256_TESTKEY "-cert.pub", F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -I ident -s " OPENSSH_CA_TESTKEY " "
Packit 6c0a39
                            OPENSSH_ECDSA256_TESTKEY ".pub 2>/dev/null");
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_ECDSA384_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t ecdsa -b 384 -q -N \"\" -f "
Packit 6c0a39
                            OPENSSH_ECDSA384_TESTKEY);
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_ECDSA384_TESTKEY "-cert.pub", F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -I ident -s " OPENSSH_CA_TESTKEY " "
Packit 6c0a39
                            OPENSSH_ECDSA384_TESTKEY ".pub 2>/dev/null");
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_ECDSA521_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -t ecdsa -b 521 -q -N \"\" -f "
Packit 6c0a39
                            OPENSSH_ECDSA521_TESTKEY);
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (access(OPENSSH_ECDSA521_TESTKEY "-cert.pub", F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(OPENSSH_KEYGEN " -I ident -s " OPENSSH_CA_TESTKEY " "
Packit 6c0a39
                            OPENSSH_ECDSA521_TESTKEY ".pub 2>/dev/null");
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
    if (!ssh_fips_mode()) {
Packit 6c0a39
#ifdef HAVE_DSA
Packit 6c0a39
        if (access(OPENSSH_DSA_TESTKEY, F_OK) != 0) {
Packit 6c0a39
            rc = system_checked(OPENSSH_KEYGEN " -t dsa -q -N \"\" -f "
Packit 6c0a39
                    OPENSSH_DSA_TESTKEY);
Packit 6c0a39
        }
Packit 6c0a39
        assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
        if (access(OPENSSH_DSA_TESTKEY "-cert.pub", F_OK) != 0) {
Packit 6c0a39
            rc = system_checked(OPENSSH_KEYGEN " -I ident -s " OPENSSH_CA_TESTKEY
Packit 6c0a39
                    " " OPENSSH_DSA_TESTKEY ".pub 2>/dev/null");
Packit 6c0a39
        }
Packit 6c0a39
        assert_int_equal(rc, 0);
Packit 6c0a39
#endif
Packit 6c0a39
Packit 6c0a39
        if (access(OPENSSH_ED25519_TESTKEY, F_OK) != 0) {
Packit 6c0a39
            rc = system_checked(OPENSSH_KEYGEN " -t ed25519 -q -N \"\" -f "
Packit 6c0a39
                    OPENSSH_ED25519_TESTKEY);
Packit 6c0a39
        }
Packit 6c0a39
        assert_int_equal(rc, 0);
Packit 6c0a39
Packit 6c0a39
        if (access(OPENSSH_ED25519_TESTKEY "-cert.pub", F_OK) != 0) {
Packit 6c0a39
            rc = system_checked(OPENSSH_KEYGEN " -I ident -s " OPENSSH_CA_TESTKEY " "
Packit 6c0a39
                    OPENSSH_ED25519_TESTKEY ".pub 2>/dev/null");
Packit 6c0a39
        }
Packit 6c0a39
        assert_int_equal(rc, 0);
Packit 6c0a39
    }
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
void cleanup_openssh_client_keys() {
Packit 6c0a39
    cleanup_key(OPENSSH_CA_TESTKEY);
Packit 6c0a39
    cleanup_key(OPENSSH_RSA_TESTKEY);
Packit 6c0a39
    cleanup_file(OPENSSH_RSA_TESTKEY "-sha256-cert.pub");
Packit 6c0a39
    cleanup_key(OPENSSH_ECDSA256_TESTKEY);
Packit 6c0a39
    cleanup_key(OPENSSH_ECDSA384_TESTKEY);
Packit 6c0a39
    cleanup_key(OPENSSH_ECDSA521_TESTKEY);
Packit 6c0a39
    if (!ssh_fips_mode()) {
Packit 6c0a39
        cleanup_key(OPENSSH_ED25519_TESTKEY);
Packit 6c0a39
#ifdef HAVE_DSA
Packit 6c0a39
        cleanup_key(OPENSSH_DSA_TESTKEY);
Packit 6c0a39
#endif
Packit 6c0a39
    }
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
void setup_dropbear_client_rsa_key() {
Packit 6c0a39
    int rc = 0;
Packit 6c0a39
    if (access(DROPBEAR_RSA_TESTKEY, F_OK) != 0) {
Packit 6c0a39
        rc = system_checked(DROPBEAR_KEYGEN " -t rsa -f "
Packit 6c0a39
                            DROPBEAR_RSA_TESTKEY " 1>/dev/null 2>/dev/null");
Packit 6c0a39
    }
Packit 6c0a39
    assert_int_equal(rc, 0);
Packit 6c0a39
}
Packit 6c0a39
Packit 6c0a39
void cleanup_dropbear_client_rsa_key() {
Packit 6c0a39
    unlink(DROPBEAR_RSA_TESTKEY);
Packit 6c0a39
}