Blame include/libssh/session.h

Packit Service 31306d
/*
Packit Service 31306d
 * This file is part of the SSH Library
Packit Service 31306d
 *
Packit Service 31306d
 * Copyright (c) 2009 by Aris Adamantiadis
Packit Service 31306d
 *
Packit Service 31306d
 * This library is free software; you can redistribute it and/or
Packit Service 31306d
 * modify it under the terms of the GNU Lesser General Public
Packit Service 31306d
 * License as published by the Free Software Foundation; either
Packit Service 31306d
 * version 2.1 of the License, or (at your option) any later version.
Packit Service 31306d
 *
Packit Service 31306d
 * This library is distributed in the hope that it will be useful,
Packit Service 31306d
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 31306d
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 31306d
 * Lesser General Public License for more details.
Packit Service 31306d
 *
Packit Service 31306d
 * You should have received a copy of the GNU Lesser General Public
Packit Service 31306d
 * License along with this library; if not, write to the Free Software
Packit Service 31306d
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
Packit Service 31306d
 */
Packit Service 31306d
Packit Service 31306d
#ifndef SESSION_H_
Packit Service 31306d
#define SESSION_H_
Packit Service 31306d
#include <stdbool.h>
Packit Service 31306d
Packit Service 31306d
#include "libssh/priv.h"
Packit Service 31306d
#include "libssh/kex.h"
Packit Service 31306d
#include "libssh/packet.h"
Packit Service 31306d
#include "libssh/pcap.h"
Packit Service 31306d
#include "libssh/auth.h"
Packit Service 31306d
#include "libssh/channels.h"
Packit Service 31306d
#include "libssh/poll.h"
Packit Service 31306d
#include "libssh/config.h"
Packit Service 31306d
#include "libssh/misc.h"
Packit Service 31306d
Packit Service 31306d
/* These are the different states a SSH session can be into its life */
Packit Service 31306d
enum ssh_session_state_e {
Packit Service 31306d
	SSH_SESSION_STATE_NONE=0,
Packit Service 31306d
	SSH_SESSION_STATE_CONNECTING,
Packit Service 31306d
	SSH_SESSION_STATE_SOCKET_CONNECTED,
Packit Service 31306d
	SSH_SESSION_STATE_BANNER_RECEIVED,
Packit Service 31306d
	SSH_SESSION_STATE_INITIAL_KEX,
Packit Service 31306d
	SSH_SESSION_STATE_KEXINIT_RECEIVED,
Packit Service 31306d
	SSH_SESSION_STATE_DH,
Packit Service 31306d
	SSH_SESSION_STATE_AUTHENTICATING,
Packit Service 31306d
	SSH_SESSION_STATE_AUTHENTICATED,
Packit Service 31306d
	SSH_SESSION_STATE_ERROR,
Packit Service 31306d
	SSH_SESSION_STATE_DISCONNECTED
Packit Service 31306d
};
Packit Service 31306d
Packit Service 31306d
enum ssh_dh_state_e {
Packit Service 31306d
  DH_STATE_INIT=0,
Packit Service 31306d
  DH_STATE_GROUP_SENT,
Packit Service 31306d
  DH_STATE_REQUEST_SENT,
Packit Service 31306d
  DH_STATE_INIT_SENT,
Packit Service 31306d
  DH_STATE_NEWKEYS_SENT,
Packit Service 31306d
  DH_STATE_FINISHED
Packit Service 31306d
};
Packit Service 31306d
Packit Service 31306d
enum ssh_pending_call_e {
Packit Service 31306d
	SSH_PENDING_CALL_NONE = 0,
Packit Service 31306d
	SSH_PENDING_CALL_CONNECT,
Packit Service 31306d
	SSH_PENDING_CALL_AUTH_NONE,
Packit Service 31306d
	SSH_PENDING_CALL_AUTH_PASSWORD,
Packit Service 31306d
	SSH_PENDING_CALL_AUTH_OFFER_PUBKEY,
Packit Service 31306d
	SSH_PENDING_CALL_AUTH_PUBKEY,
Packit Service 31306d
	SSH_PENDING_CALL_AUTH_AGENT,
Packit Service 31306d
	SSH_PENDING_CALL_AUTH_KBDINT_INIT,
Packit Service 31306d
	SSH_PENDING_CALL_AUTH_KBDINT_SEND,
Packit Service 31306d
	SSH_PENDING_CALL_AUTH_GSSAPI_MIC
Packit Service 31306d
};
Packit Service 31306d
Packit Service 31306d
/* libssh calls may block an undefined amount of time */
Packit Service 31306d
#define SSH_SESSION_FLAG_BLOCKING 1
Packit Service 31306d
Packit Service 31306d
/* Client successfully authenticated */
Packit Service 31306d
#define SSH_SESSION_FLAG_AUTHENTICATED 2
Packit Service 31306d
Packit Service 31306d
/* codes to use with ssh_handle_packets*() */
Packit Service 31306d
/* Infinite timeout */
Packit Service 31306d
#define SSH_TIMEOUT_INFINITE -1
Packit Service 31306d
/* Use the timeout defined by user if any. Mostly used with new connections */
Packit Service 31306d
#define SSH_TIMEOUT_USER -2
Packit Service 31306d
/* Use the default timeout, depending on ssh_is_blocking() */
Packit Service 31306d
#define SSH_TIMEOUT_DEFAULT -3
Packit Service 31306d
/* Don't block at all */
Packit Service 31306d
#define SSH_TIMEOUT_NONBLOCKING 0
Packit Service 31306d
Packit Service 31306d
/* options flags */
Packit Service 31306d
/* Authentication with *** allowed */
Packit Service 31306d
#define SSH_OPT_FLAG_PASSWORD_AUTH 0x1
Packit Service 31306d
#define SSH_OPT_FLAG_PUBKEY_AUTH 0x2
Packit Service 31306d
#define SSH_OPT_FLAG_KBDINT_AUTH 0x4
Packit Service 31306d
#define SSH_OPT_FLAG_GSSAPI_AUTH 0x8
Packit Service 31306d
Packit Service 31306d
/* extensions flags */
Packit Service 31306d
/* negotiation enabled */
Packit Service 31306d
#define SSH_EXT_NEGOTIATION     0x01
Packit Service 31306d
/* server-sig-algs extension */
Packit Service 31306d
#define SSH_EXT_SIG_RSA_SHA256  0x02
Packit Service 31306d
#define SSH_EXT_SIG_RSA_SHA512  0x04
Packit Service 31306d
Packit Service 31306d
/* members that are common to ssh_session and ssh_bind */
Packit Service 31306d
struct ssh_common_struct {
Packit Service 31306d
    struct error_struct error;
Packit Service 31306d
    ssh_callbacks callbacks; /* Callbacks to user functions */
Packit Service 31306d
    int log_verbosity; /* verbosity of the log functions */
Packit Service 31306d
};
Packit Service 31306d
Packit Service 31306d
struct ssh_session_struct {
Packit Service 31306d
    struct ssh_common_struct common;
Packit Service 31306d
    struct ssh_socket_struct *socket;
Packit Service 31306d
    char *serverbanner;
Packit Service 31306d
    char *clientbanner;
Packit Service 31306d
    int protoversion;
Packit Service 31306d
    int server;
Packit Service 31306d
    int client;
Packit Service 31306d
    int openssh;
Packit Service 31306d
    uint32_t send_seq;
Packit Service 31306d
    uint32_t recv_seq;
Packit Service 31306d
    struct ssh_timestamp last_rekey_time;
Packit Service 31306d
Packit Service 31306d
    int connected;
Packit Service 31306d
    /* !=0 when the user got a session handle */
Packit Service 31306d
    int alive;
Packit Service 31306d
    /* two previous are deprecated */
Packit Service 31306d
    /* int auth_service_asked; */
Packit Service 31306d
Packit Service 31306d
    /* session flags (SSH_SESSION_FLAG_*) */
Packit Service 31306d
    int flags;
Packit Service 31306d
Packit Service 31306d
    /* Extensions negotiated using RFC 8308 */
Packit Service 31306d
    uint32_t extensions;
Packit Service 31306d
Packit Service 31306d
    ssh_string banner; /* that's the issue banner from
Packit Service 31306d
                       the server */
Packit Service 31306d
    char *discon_msg; /* disconnect message from
Packit Service 31306d
                         the remote host */
Packit Service 31306d
    ssh_buffer in_buffer;
Packit Service 31306d
    PACKET in_packet;
Packit Service 31306d
    ssh_buffer out_buffer;
Packit Service 31306d
    struct ssh_list *out_queue; /* This list is used for delaying packets
Packit Service 31306d
                                   when rekeying is required */
Packit Service 31306d
Packit Service 31306d
    /* the states are used by the nonblocking stuff to remember */
Packit Service 31306d
    /* where it was before being interrupted */
Packit Service 31306d
    enum ssh_pending_call_e pending_call_state;
Packit Service 31306d
    enum ssh_session_state_e session_state;
Packit Service 31306d
    enum ssh_packet_state_e packet_state;
Packit Service 31306d
    enum ssh_dh_state_e dh_handshake_state;
Packit Service 31306d
    enum ssh_channel_request_state_e global_req_state;
Packit Service 31306d
    struct ssh_agent_state_struct *agent_state;
Packit Service 31306d
Packit Service 31306d
    struct {
Packit Service 31306d
        struct ssh_auth_auto_state_struct *auto_state;
Packit Service 31306d
        enum ssh_auth_service_state_e service_state;
Packit Service 31306d
        enum ssh_auth_state_e state;
Packit Service 31306d
        uint32_t supported_methods;
Packit Service 31306d
        uint32_t current_method;
Packit Service 31306d
    } auth;
Packit Service 31306d
Packit Service 31306d
    /*
Packit Service 31306d
     * RFC 4253, 7.1: if the first_kex_packet_follows flag was set in
Packit Service 31306d
     * the received SSH_MSG_KEXINIT, but the guess was wrong, this
Packit Service 31306d
     * field will be set such that the following guessed packet will
Packit Service 31306d
     * be ignored.  Once that packet has been received and ignored,
Packit Service 31306d
     * this field is cleared.
Packit Service 31306d
     */
Packit Service 31306d
    int first_kex_follows_guess_wrong;
Packit Service 31306d
Packit Service 31306d
    ssh_buffer in_hashbuf;
Packit Service 31306d
    ssh_buffer out_hashbuf;
Packit Service 31306d
    struct ssh_crypto_struct *current_crypto;
Packit Service 31306d
    struct ssh_crypto_struct *next_crypto;  /* next_crypto is going to be used after a SSH2_MSG_NEWKEYS */
Packit Service 31306d
Packit Service 31306d
    struct ssh_list *channels; /* linked list of channels */
Packit Service 31306d
    int maxchannel;
Packit Service 31306d
    ssh_agent agent; /* ssh agent */
Packit Service 31306d
Packit Service 31306d
/* keyb interactive data */
Packit Service 31306d
    struct ssh_kbdint_struct *kbdint;
Packit Service 31306d
    struct ssh_gssapi_struct *gssapi;
Packit Service 31306d
Packit Service 31306d
    /* server host keys */
Packit Service 31306d
    struct {
Packit Service 31306d
        ssh_key rsa_key;
Packit Service 31306d
        ssh_key dsa_key;
Packit Service 31306d
        ssh_key ecdsa_key;
Packit Service 31306d
        ssh_key ed25519_key;
Packit Service 31306d
        /* The type of host key wanted by client */
Packit Service 31306d
        enum ssh_keytypes_e hostkey;
Packit Service 31306d
        enum ssh_digest_e hostkey_digest;
Packit Service 31306d
    } srv;
Packit Service 31306d
Packit Service 31306d
    /* auths accepted by server */
Packit Service 31306d
    struct ssh_list *ssh_message_list; /* list of delayed SSH messages */
Packit Service 31306d
    int (*ssh_message_callback)( struct ssh_session_struct *session, ssh_message msg, void *userdata);
Packit Service 31306d
    void *ssh_message_callback_data;
Packit Service 31306d
    ssh_server_callbacks server_callbacks;
Packit Service 31306d
    void (*ssh_connection_callback)( struct ssh_session_struct *session);
Packit Service 31306d
    struct ssh_packet_callbacks_struct default_packet_callbacks;
Packit Service 31306d
    struct ssh_list *packet_callbacks;
Packit Service 31306d
    struct ssh_socket_callbacks_struct socket_callbacks;
Packit Service 31306d
    ssh_poll_ctx default_poll_ctx;
Packit Service 31306d
    /* options */
Packit Service 31306d
#ifdef WITH_PCAP
Packit Service 31306d
    ssh_pcap_context pcap_ctx; /* pcap debugging context */
Packit Service 31306d
#endif
Packit Service 31306d
    struct {
Packit Service 31306d
        struct ssh_list *identity;
Packit Service 31306d
        char *username;
Packit Service 31306d
        char *host;
Packit Service 31306d
        char *bindaddr; /* bind the client to an ip addr */
Packit Service 31306d
        char *sshdir;
Packit Service 31306d
        char *knownhosts;
Packit Service 31306d
        char *global_knownhosts;
Packit Service 31306d
        char *wanted_methods[SSH_KEX_METHODS];
Packit Service 31306d
        char *pubkey_accepted_types;
Packit Service 31306d
        char *ProxyCommand;
Packit Service 31306d
        char *custombanner;
Packit Service 31306d
        unsigned long timeout; /* seconds */
Packit Service 31306d
        unsigned long timeout_usec;
Packit Service 31306d
        unsigned int port;
Packit Service 31306d
        socket_t fd;
Packit Service 31306d
        int StrictHostKeyChecking;
Packit Service 31306d
        char compressionlevel;
Packit Service 31306d
        char *gss_server_identity;
Packit Service 31306d
        char *gss_client_identity;
Packit Service 31306d
        int gss_delegate_creds;
Packit Service 31306d
        int flags;
Packit Service 31306d
        int nodelay;
Packit Service 31306d
        bool config_processed;
Packit Service 31306d
        uint8_t options_seen[SOC_MAX];
Packit Service 31306d
        uint64_t rekey_data;
Packit Service 31306d
        uint32_t rekey_time;
Packit Service 31306d
    } opts;
Packit Service 31306d
    /* counters */
Packit Service 31306d
    ssh_counter socket_counter;
Packit Service 31306d
    ssh_counter raw_counter;
Packit Service 31306d
};
Packit Service 31306d
Packit Service 31306d
/** @internal
Packit Service 31306d
 * @brief a termination function evaluates the status of an object
Packit Service 31306d
 * @param user[in] object to evaluate
Packit Service 31306d
 * @returns 1 if the polling routine should terminate, 0 instead
Packit Service 31306d
 */
Packit Service 31306d
typedef int (*ssh_termination_function)(void *user);
Packit Service 31306d
int ssh_handle_packets(ssh_session session, int timeout);
Packit Service 31306d
int ssh_handle_packets_termination(ssh_session session,
Packit Service 31306d
                                   long timeout,
Packit Service 31306d
                                   ssh_termination_function fct,
Packit Service 31306d
                                   void *user);
Packit Service 31306d
void ssh_socket_exception_callback(int code, int errno_code, void *user);
Packit Service 31306d
Packit Service 31306d
#endif /* SESSION_H_ */