
Some checks failed
CIFuzz / Fuzzing (push) Waiting to run
C/C++ CI self-hosted / win10 cygwin-release (push) Waiting to run
C/C++ CI self-hosted / ARM default (push) Waiting to run
C/C++ CI self-hosted / ARM64 default (push) Waiting to run
C/C++ CI self-hosted / alpine default (push) Waiting to run
C/C++ CI self-hosted / centos7 default (push) Waiting to run
C/C++ CI self-hosted / debian-i386 default (push) Waiting to run
C/C++ CI self-hosted / dfly30 default (push) Waiting to run
C/C++ CI self-hosted / dfly48 default (push) Waiting to run
C/C++ CI self-hosted / dfly60 default (push) Waiting to run
C/C++ CI self-hosted / dfly62 default (push) Waiting to run
C/C++ CI self-hosted / dfly64 default (push) Waiting to run
C/C++ CI self-hosted / fbsd10 default (push) Waiting to run
C/C++ CI self-hosted / fbsd12 default (push) Waiting to run
C/C++ CI self-hosted / fbsd13 default (push) Waiting to run
C/C++ CI self-hosted / fbsd14 default (push) Waiting to run
C/C++ CI self-hosted / nbsd10 default (push) Waiting to run
C/C++ CI self-hosted / nbsd3 default (push) Waiting to run
C/C++ CI self-hosted / nbsd4 default (push) Waiting to run
C/C++ CI self-hosted / nbsd8 default (push) Waiting to run
C/C++ CI self-hosted / nbsd9 default (push) Waiting to run
C/C++ CI self-hosted / obsd51 default (push) Waiting to run
C/C++ CI self-hosted / obsd67 default (push) Waiting to run
C/C++ CI self-hosted / obsd72 default (push) Waiting to run
C/C++ CI self-hosted / obsd73 default (push) Waiting to run
C/C++ CI self-hosted / obsd74 default (push) Waiting to run
C/C++ CI self-hosted / obsdsnap default (push) Waiting to run
C/C++ CI self-hosted / obsdsnap-i386 default (push) Waiting to run
C/C++ CI self-hosted / omnios default (push) Waiting to run
C/C++ CI self-hosted / openindiana default (push) Waiting to run
C/C++ CI self-hosted / ubuntu-2204 default (push) Waiting to run
C/C++ CI self-hosted / obsd-arm64 default (push) Waiting to run
C/C++ CI self-hosted / aix51 default (push) Waiting to run
C/C++ CI self-hosted / fbsd14-ppc64 default (push) Waiting to run
C/C++ CI self-hosted / sol10 default (push) Waiting to run
C/C++ CI self-hosted / sol11 default (push) Waiting to run
C/C++ CI self-hosted / win10 default (push) Waiting to run
C/C++ CI self-hosted / debian-riscv64 default (push) Waiting to run
C/C++ CI self-hosted / openwrt-mips default (push) Waiting to run
C/C++ CI self-hosted / openwrt-mipsel default (push) Waiting to run
C/C++ CI self-hosted / ARM64 pam (push) Waiting to run
C/C++ CI self-hosted / centos7 pam (push) Waiting to run
C/C++ CI self-hosted / debian-i386 pam (push) Waiting to run
C/C++ CI self-hosted / dfly48 pam (push) Waiting to run
C/C++ CI self-hosted / dfly58 pam (push) Waiting to run
C/C++ CI self-hosted / dfly60 pam (push) Waiting to run
C/C++ CI self-hosted / dfly62 pam (push) Waiting to run
C/C++ CI self-hosted / dfly64 pam (push) Waiting to run
C/C++ CI self-hosted / fbsd10 pam (push) Waiting to run
C/C++ CI self-hosted / fbsd12 pam (push) Waiting to run
C/C++ CI self-hosted / fbsd13 pam (push) Waiting to run
C/C++ CI self-hosted / fbsd14 pam (push) Waiting to run
C/C++ CI self-hosted / nbsd10 pam (push) Waiting to run
C/C++ CI self-hosted / nbsd8 pam (push) Waiting to run
C/C++ CI self-hosted / nbsd9 pam (push) Waiting to run
C/C++ CI self-hosted / omnios pam (push) Waiting to run
C/C++ CI self-hosted / openindiana pam (push) Waiting to run
C/C++ CI self-hosted / sol10 pam (push) Waiting to run
C/C++ CI self-hosted / sol11 pam-krb5 (push) Waiting to run
C/C++ CI self-hosted / sol11 sol64 (push) Waiting to run
C/C++ CI self-hosted / dfly30 without-openssl (push) Waiting to run
C/C++ CI / ubuntu-latest aws-lc (push) Failing after 31s
C/C++ CI / ubuntu-latest boringssl (push) Failing after 31s
C/C++ CI / ubuntu-latest clang-15 (push) Failing after 31s
C/C++ CI / ubuntu-latest clang-19 (push) Failing after 19s
C/C++ CI / ubuntu-latest default (push) Failing after 3s
C/C++ CI / ubuntu-latest gcc-14 (push) Failing after 4s
C/C++ CI / ubuntu-latest libressl-3.2.6 (push) Failing after 4s
C/C++ CI / ubuntu-latest libressl-3.3.6 (push) Failing after 3s
C/C++ CI / ubuntu-latest libressl-3.4.3 (push) Failing after 3s
C/C++ CI / ubuntu-latest libressl-3.5.3 (push) Failing after 4s
C/C++ CI / ubuntu-latest libressl-3.6.1 (push) Failing after 4s
C/C++ CI / ubuntu-latest libressl-3.7.2 (push) Failing after 4s
C/C++ CI / ubuntu-latest libressl-3.8.4 (push) Failing after 3s
C/C++ CI / ubuntu-latest libressl-3.9.2 (push) Failing after 3s
C/C++ CI / ubuntu-latest libressl-4.0.0 (push) Failing after 4s
C/C++ CI / ubuntu-latest libressl-master (push) Failing after 4s
C/C++ CI / ubuntu-latest musl (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-1.1.1 (push) Failing after 4s
C/C++ CI / ubuntu-latest openssl-1.1.1_stable (push) Failing after 4s
C/C++ CI / ubuntu-latest openssl-1.1.1t (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-1.1.1w (push) Failing after 4s
C/C++ CI / ubuntu-latest openssl-3.0 (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-3.0.0 (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-3.0.15 (push) Failing after 4s
C/C++ CI / ubuntu-latest openssl-3.1 (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-3.1.0 (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-3.1.7 (push) Failing after 4s
C/C++ CI / ubuntu-latest openssl-3.2 (push) Failing after 4s
C/C++ CI / ubuntu-latest openssl-3.2.3 (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-3.3 (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-3.3.2 (push) Failing after 4s
C/C++ CI / ubuntu-latest openssl-3.4.0 (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-master (push) Failing after 3s
C/C++ CI / ubuntu-latest openssl-noec (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-0.71 (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-0.72 (push) Failing after 3s
C/C++ CI / ubuntu-latest putty-0.73 (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-0.74 (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-0.75 (push) Failing after 3s
C/C++ CI / ubuntu-latest putty-0.76 (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-0.77 (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-0.78 (push) Failing after 3s
C/C++ CI / ubuntu-latest putty-0.79 (push) Failing after 3s
C/C++ CI / ubuntu-latest putty-0.80 (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-0.81 (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-0.82 (push) Failing after 3s
C/C++ CI / ubuntu-latest putty-0.83 (push) Failing after 4s
C/C++ CI / ubuntu-latest putty-snapshot (push) Failing after 4s
C/C++ CI / ubuntu-latest tcmalloc (push) Failing after 3s
C/C++ CI / ubuntu-latest zlib-develop (push) Failing after 3s
C/C++ CI / ubuntu-22.04 c89 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 clang-11 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 clang-12-Werror (push) Has been cancelled
C/C++ CI / ubuntu-22.04 clang-14 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 clang-sanitize-address (push) Has been cancelled
C/C++ CI / ubuntu-22.04 clang-sanitize-undefined (push) Has been cancelled
C/C++ CI / windows-2019 cygwin-release (push) Has been cancelled
C/C++ CI / windows-2022 cygwin-release (push) Has been cancelled
C/C++ CI / macos-13 default (push) Has been cancelled
C/C++ CI / macos-14 default (push) Has been cancelled
C/C++ CI / macos-15 default (push) Has been cancelled
C/C++ CI / ubuntu-22.04 default (push) Has been cancelled
C/C++ CI / ubuntu-22.04-arm default (push) Has been cancelled
C/C++ CI / ubuntu-24.04-arm default (push) Has been cancelled
C/C++ CI / windows-2019 default (push) Has been cancelled
C/C++ CI / windows-2022 default (push) Has been cancelled
C/C++ CI / ubuntu-22.04 gcc-11-Werror (push) Has been cancelled
C/C++ CI / ubuntu-22.04 gcc-12-Werror (push) Has been cancelled
C/C++ CI / ubuntu-22.04 gcc-9 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 gcc-sanitize-address (push) Has been cancelled
C/C++ CI / ubuntu-22.04 gcc-sanitize-undefined (push) Has been cancelled
C/C++ CI / ubuntu-22.04 hardenedmalloc (push) Has been cancelled
C/C++ CI / ubuntu-22.04 heimdal (push) Has been cancelled
C/C++ CI / ubuntu-22.04 kitchensink (push) Has been cancelled
C/C++ CI / ubuntu-22.04-arm kitchensink (push) Has been cancelled
C/C++ CI / ubuntu-24.04-arm kitchensink (push) Has been cancelled
C/C++ CI / ubuntu-22.04 krb5 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 libedit (push) Has been cancelled
C/C++ CI / macos-13 pam (push) Has been cancelled
C/C++ CI / macos-14 pam (push) Has been cancelled
C/C++ CI / macos-15 pam (push) Has been cancelled
C/C++ CI / ubuntu-22.04 pam (push) Has been cancelled
C/C++ CI / ubuntu-22.04 selinux (push) Has been cancelled
C/C++ CI / ubuntu-22.04 sk (push) Has been cancelled
C/C++ CI / ubuntu-22.04 valgrind-1 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 valgrind-2 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 valgrind-3 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 valgrind-4 (push) Has been cancelled
C/C++ CI / ubuntu-22.04 valgrind-unit (push) Has been cancelled
C/C++ CI / ubuntu-22.04 without-openssl (push) Has been cancelled
185 lines
3.6 KiB
C
185 lines
3.6 KiB
C
#include "fixed-keys.h"
|
|
#include <assert.h>
|
|
|
|
#define main(ac, av) xxxmain(ac, av)
|
|
#include "../../../ssh-agent.c"
|
|
|
|
void test_one(const uint8_t* s, size_t slen);
|
|
|
|
static int
|
|
devnull_or_die(void)
|
|
{
|
|
int fd;
|
|
|
|
if ((fd = open("/dev/null", O_RDWR)) == -1) {
|
|
error_f("open /dev/null: %s", strerror(errno));
|
|
abort();
|
|
}
|
|
return fd;
|
|
}
|
|
|
|
static struct sshkey *
|
|
pubkey_or_die(const char *s)
|
|
{
|
|
char *tmp, *cp;
|
|
struct sshkey *pubkey;
|
|
int r;
|
|
|
|
tmp = cp = xstrdup(s);
|
|
if ((pubkey = sshkey_new(KEY_UNSPEC)) == NULL)
|
|
abort();
|
|
if ((r = sshkey_read(pubkey, &cp)) != 0) {
|
|
error_fr(r, "parse");
|
|
abort();
|
|
}
|
|
free(tmp);
|
|
return pubkey;
|
|
}
|
|
|
|
static struct sshkey *
|
|
privkey_or_die(const char *s)
|
|
{
|
|
int r;
|
|
struct sshbuf *b;
|
|
struct sshkey *privkey;
|
|
|
|
if ((b = sshbuf_from(s, strlen(s))) == NULL) {
|
|
error_f("sshbuf_from failed");
|
|
abort();
|
|
}
|
|
if ((r = sshkey_parse_private_fileblob(b, "", &privkey, NULL)) != 0) {
|
|
error_fr(r, "parse");
|
|
abort();
|
|
}
|
|
sshbuf_free(b);
|
|
return privkey;
|
|
}
|
|
|
|
static void
|
|
add_key(const char *privkey, const char *certpath)
|
|
{
|
|
Identity *id;
|
|
int r;
|
|
struct sshkey *cert;
|
|
|
|
id = xcalloc(1, sizeof(Identity));
|
|
TAILQ_INSERT_TAIL(&idtab->idlist, id, next);
|
|
idtab->nentries++;
|
|
id->key = privkey_or_die(privkey);
|
|
id->comment = xstrdup("rhododaktulos Eos");
|
|
if (sshkey_is_sk(id->key))
|
|
id->sk_provider = xstrdup("internal");
|
|
|
|
/* Now the cert too */
|
|
id = xcalloc(1, sizeof(Identity));
|
|
TAILQ_INSERT_TAIL(&idtab->idlist, id, next);
|
|
idtab->nentries++;
|
|
id->key = privkey_or_die(privkey);
|
|
cert = pubkey_or_die(certpath);
|
|
if ((r = sshkey_to_certified(id->key)) != 0) {
|
|
error_fr(r, "sshkey_to_certified");
|
|
abort();
|
|
}
|
|
if ((r = sshkey_cert_copy(cert, id->key)) != 0) {
|
|
error_fr(r, "sshkey_cert_copy");
|
|
abort();
|
|
}
|
|
sshkey_free(cert);
|
|
id->comment = xstrdup("outis");
|
|
if (sshkey_is_sk(id->key))
|
|
id->sk_provider = xstrdup("internal");
|
|
}
|
|
|
|
static void
|
|
cleanup_idtab(void)
|
|
{
|
|
Identity *id;
|
|
|
|
if (idtab == NULL) return;
|
|
for (id = TAILQ_FIRST(&idtab->idlist); id;
|
|
id = TAILQ_FIRST(&idtab->idlist)) {
|
|
TAILQ_REMOVE(&idtab->idlist, id, next);
|
|
free_identity(id);
|
|
}
|
|
free(idtab);
|
|
idtab = NULL;
|
|
}
|
|
|
|
static void
|
|
reset_idtab(void)
|
|
{
|
|
cleanup_idtab();
|
|
idtab_init();
|
|
// Load keys.
|
|
add_key(PRIV_RSA, CERT_RSA);
|
|
add_key(PRIV_ECDSA, CERT_ECDSA);
|
|
add_key(PRIV_ED25519, CERT_ED25519);
|
|
add_key(PRIV_ECDSA_SK, CERT_ECDSA_SK);
|
|
add_key(PRIV_ED25519_SK, CERT_ED25519_SK);
|
|
}
|
|
|
|
static void
|
|
cleanup_sockettab(void)
|
|
{
|
|
u_int i;
|
|
for (i = 0; i < sockets_alloc; i++) {
|
|
if (sockets[i].type != AUTH_UNUSED)
|
|
close_socket(sockets + i);
|
|
}
|
|
free(sockets);
|
|
sockets = NULL;
|
|
sockets_alloc = 0;
|
|
}
|
|
|
|
static void
|
|
reset_sockettab(int devnull)
|
|
{
|
|
int fd;
|
|
|
|
cleanup_sockettab();
|
|
if ((fd = dup(devnull)) == -1) {
|
|
error_f("dup: %s", strerror(errno));
|
|
abort();
|
|
}
|
|
new_socket(AUTH_CONNECTION, fd);
|
|
assert(sockets[0].type == AUTH_CONNECTION);
|
|
assert(sockets[0].fd == fd);
|
|
}
|
|
|
|
#define MAX_MESSAGES 256
|
|
void
|
|
test_one(const uint8_t* s, size_t slen)
|
|
{
|
|
static int devnull = -1;
|
|
size_t i, olen, nlen;
|
|
|
|
if (devnull == -1) {
|
|
log_init(__progname, SYSLOG_LEVEL_DEBUG3,
|
|
SYSLOG_FACILITY_AUTH, 1);
|
|
devnull = devnull_or_die();
|
|
allowed_providers = xstrdup("");
|
|
websafe_allowlist = xstrdup("*");
|
|
setenv("DISPLAY", "", 1); /* ban askpass */
|
|
}
|
|
|
|
reset_idtab();
|
|
reset_sockettab(devnull);
|
|
(void)sshbuf_put(sockets[0].input, s, slen);
|
|
for (i = 0; i < MAX_MESSAGES; i++) {
|
|
olen = sshbuf_len(sockets[0].input);
|
|
process_message(0);
|
|
nlen = sshbuf_len(sockets[0].input);
|
|
if (nlen == 0 || nlen == olen)
|
|
break;
|
|
}
|
|
cleanup_idtab();
|
|
cleanup_sockettab();
|
|
}
|
|
|
|
int
|
|
pkcs11_make_cert(const struct sshkey *priv,
|
|
const struct sshkey *certpub, struct sshkey **certprivp)
|
|
{
|
|
return -1; /* XXX */
|
|
}
|