Blame tests/pkd/pkd_client.h

Packit Service 31306d
/*
Packit Service 31306d
 * pkd_client.h -- macros for generating client-specific command
Packit Service 31306d
 *                 invocations for use with pkd testing
Packit Service 31306d
 *
Packit Service 31306d
 * (c) 2014, 2018 Jon Simons <jon@jonsimons.org>
Packit Service 31306d
 */
Packit Service 31306d
Packit Service 31306d
#ifndef __PKD_CLIENT_H__
Packit Service 31306d
#define __PKD_CLIENT_H__
Packit Service 31306d
Packit Service 31306d
#include "config.h"
Packit Service 31306d
Packit Service 31306d
/* OpenSSH */
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_BINARY "ssh"
Packit Service 31306d
#define OPENSSH_KEYGEN "ssh-keygen"
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_HOSTKEY_ALGOS_DEFAULT "ssh-ed25519,rsa-sha2-512,rsa-sha2-256,ssh-rsa"
Packit Service 31306d
#define OPENSSH_PKACCEPTED_DEFAULT    "ssh-ed25519,rsa-sha2-512,rsa-sha2-256,ssh-rsa,ssh-rsa-cert-v01@openssh.com,ssh-ed25519-cert-v01@openssh.com,rsa-sha2-256-cert-v01@openssh.com,rsa-sha2-512-cert-v01@openssh.com"
Packit Service 31306d
Packit Service 31306d
#if       HAVE_ECC
Packit Service 31306d
#define OPENSSH_HOSTKEY_ALGOS_ECDSA   ",ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521"
Packit Service 31306d
#define OPENSSH_PKACCEPTED_ECDSA      ",ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521,ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp521-cert-v01@openssh.com"
Packit Service 31306d
#else  /* HAVE_ECC */
Packit Service 31306d
#define OPENSSH_HOSTKEY_ALGOS_ECDSA   ""
Packit Service 31306d
#define OPENSSH_PKACCEPTED_ECDSA      ""
Packit Service 31306d
#endif /* HAVE_ECC */
Packit Service 31306d
Packit Service 31306d
#if       HAVE_DSA
Packit Service 31306d
#define OPENSSH_HOSTKEY_ALGOS_DSA     ",ssh-dss"
Packit Service 31306d
#define OPENSSH_PKACCEPTED_DSA        ",ssh-dss,ssh-dss-cert-v01@openssh.com"
Packit Service 31306d
#else  /* HAVE_DSA */
Packit Service 31306d
#define OPENSSH_HOSTKEY_ALGOS_DSA     ""
Packit Service 31306d
#define OPENSSH_PKACCEPTED_DSA        ""
Packit Service 31306d
#endif /* HAVE_DSA */
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_HOSTKEY_ALGOS \
Packit Service 31306d
  "-o HostKeyAlgorithms="        \
Packit Service 31306d
  OPENSSH_HOSTKEY_ALGOS_DEFAULT  \
Packit Service 31306d
  OPENSSH_HOSTKEY_ALGOS_ECDSA    \
Packit Service 31306d
  OPENSSH_HOSTKEY_ALGOS_DSA
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_PKACCEPTED_TYPES \
Packit Service 31306d
  "-o PubkeyAcceptedKeyTypes="  \
Packit Service 31306d
  OPENSSH_PKACCEPTED_DEFAULT    \
Packit Service 31306d
  OPENSSH_PKACCEPTED_ECDSA      \
Packit Service 31306d
  OPENSSH_PKACCEPTED_DSA
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_CMD_START(hostkey_algos) \
Packit Service 31306d
    OPENSSH_BINARY " "                  \
Packit Service 31306d
    "-o UserKnownHostsFile=/dev/null "  \
Packit Service 31306d
    "-o StrictHostKeyChecking=no "      \
Packit Service 31306d
    "-F /dev/null "                     \
Packit Service 31306d
    hostkey_algos " "                   \
Packit Service 31306d
    OPENSSH_PKACCEPTED_TYPES " "        \
Packit Service 31306d
    "-i " CLIENT_ID_FILE " "            \
Packit Service 31306d
    "1> %s.out "                        \
Packit Service 31306d
    "2> %s.err "                        \
Packit Service 31306d
    "-vvv "
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_CMD_END "-p 1234 localhost ls"
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_CMD \
Packit Service 31306d
    OPENSSH_CMD_START(OPENSSH_HOSTKEY_ALGOS) OPENSSH_CMD_END
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_KEX_CMD(kexalgo) \
Packit Service 31306d
    OPENSSH_CMD_START(OPENSSH_HOSTKEY_ALGOS) "-o KexAlgorithms=" kexalgo " " OPENSSH_CMD_END
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_CIPHER_CMD(ciphers) \
Packit Service 31306d
    OPENSSH_CMD_START(OPENSSH_HOSTKEY_ALGOS) "-c " ciphers " " OPENSSH_CMD_END
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_MAC_CMD(macs) \
Packit Service 31306d
    OPENSSH_CMD_START(OPENSSH_HOSTKEY_ALGOS) "-c aes128-ctr,aes192-ctr,aes256-ctr,aes256-cbc,aes192-cbc,aes128-cbc -o MACs=" macs " " OPENSSH_CMD_END
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_HOSTKEY_CMD(hostkeyalgo) \
Packit Service 31306d
    OPENSSH_CMD_START("-o HostKeyAlgorithms=" hostkeyalgo " ") OPENSSH_CMD_END
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_CERT_CMD \
Packit Service 31306d
    OPENSSH_CMD_START(OPENSSH_HOSTKEY_ALGOS) "-o CertificateFile=" CLIENT_ID_FILE "-cert.pub " OPENSSH_CMD_END
Packit Service 31306d
Packit Service 31306d
#define OPENSSH_SHA256_CERT_CMD \
Packit Service 31306d
    OPENSSH_CMD_START(OPENSSH_HOSTKEY_ALGOS) "-o CertificateFile=" CLIENT_ID_FILE "-sha256-cert.pub " OPENSSH_CMD_END
Packit Service 31306d
Packit Service 31306d
/* Dropbear */
Packit Service 31306d
Packit Service 31306d
#define DROPBEAR_BINARY "dbclient"
Packit Service 31306d
#define DROPBEAR_KEYGEN "dropbearkey"
Packit Service 31306d
Packit Service 31306d
#define DROPBEAR_CMD_START \
Packit Service 31306d
    DROPBEAR_BINARY " "      \
Packit Service 31306d
    "-y -y "                 \
Packit Service 31306d
    "-i " CLIENT_ID_FILE " " \
Packit Service 31306d
    "1> %s.out "             \
Packit Service 31306d
    "2> %s.err "
Packit Service 31306d
Packit Service 31306d
#define DROPBEAR_CMD_END "-p 1234 localhost ls"
Packit Service 31306d
Packit Service 31306d
#define DROPBEAR_CMD \
Packit Service 31306d
    DROPBEAR_CMD_START DROPBEAR_CMD_END
Packit Service 31306d
Packit Service 31306d
#if 0 /* dbclient does not expose control over kex algo */
Packit Service 31306d
#define DROPBEAR_KEX_CMD(kexalgo) \
Packit Service 31306d
    DROPBEAR_CMD
Packit Service 31306d
#endif
Packit Service 31306d
Packit Service 31306d
#define DROPBEAR_CIPHER_CMD(ciphers) \
Packit Service 31306d
    DROPBEAR_CMD_START "-c " ciphers " " DROPBEAR_CMD_END
Packit Service 31306d
Packit Service 31306d
#define DROPBEAR_MAC_CMD(macs) \
Packit Service 31306d
    DROPBEAR_CMD_START "-m " macs " " DROPBEAR_CMD_END
Packit Service 31306d
Packit Service 31306d
#endif /* __PKD_CLIENT_H__ */