25#include "libssh/priv.h"
26#include "libssh/callbacks.h"
27#include "libssh/kex.h"
28#include "libssh/packet.h"
29#include "libssh/pcap.h"
30#include "libssh/auth.h"
31#include "libssh/channels.h"
32#include "libssh/poll.h"
33#include "libssh/config.h"
34#include "libssh/misc.h"
37enum ssh_session_state_e {
38 SSH_SESSION_STATE_NONE=0,
39 SSH_SESSION_STATE_CONNECTING,
40 SSH_SESSION_STATE_SOCKET_CONNECTED,
41 SSH_SESSION_STATE_BANNER_RECEIVED,
42 SSH_SESSION_STATE_INITIAL_KEX,
43 SSH_SESSION_STATE_KEXINIT_RECEIVED,
45 SSH_SESSION_STATE_AUTHENTICATING,
46 SSH_SESSION_STATE_AUTHENTICATED,
47 SSH_SESSION_STATE_ERROR,
48 SSH_SESSION_STATE_DISCONNECTED
54 DH_STATE_REQUEST_SENT,
56 DH_STATE_NEWKEYS_SENT,
60enum ssh_pending_call_e {
61 SSH_PENDING_CALL_NONE = 0,
62 SSH_PENDING_CALL_CONNECT,
63 SSH_PENDING_CALL_AUTH_NONE,
64 SSH_PENDING_CALL_AUTH_PASSWORD,
65 SSH_PENDING_CALL_AUTH_OFFER_PUBKEY,
66 SSH_PENDING_CALL_AUTH_PUBKEY,
67 SSH_PENDING_CALL_AUTH_AGENT,
68 SSH_PENDING_CALL_AUTH_KBDINT_INIT,
69 SSH_PENDING_CALL_AUTH_KBDINT_SEND,
70 SSH_PENDING_CALL_AUTH_GSSAPI_MIC,
71 SSH_PENDING_CALL_AUTH_GSSAPI_KEYEX,
75#define SSH_SESSION_FLAG_BLOCKING 0x0001
78#define SSH_SESSION_FLAG_AUTHENTICATED 0x0002
81#define SSH_SESSION_FLAG_NO_MORE_SESSIONS 0x0004
86#define SSH_SESSION_FLAG_KEXINIT_SENT 0x0008
90#define SSH_SESSION_FLAG_KEX_STRICT 0x0010
92#define SSH_SESSION_FLAG_KEX_TAINTED 0x0020
95#define SSH_SESSION_FLAG_SCP_QUOTING_BROKEN 0x0040
99#define SSH_TIMEOUT_INFINITE -1
101#define SSH_TIMEOUT_USER -2
103#define SSH_TIMEOUT_DEFAULT -3
105#define SSH_TIMEOUT_NONBLOCKING 0
109#define SSH_OPT_FLAG_PASSWORD_AUTH 0x1
110#define SSH_OPT_FLAG_PUBKEY_AUTH 0x2
111#define SSH_OPT_FLAG_KBDINT_AUTH 0x4
112#define SSH_OPT_FLAG_GSSAPI_AUTH 0x8
115#define SSH_OPT_EXP_FLAG_KNOWNHOSTS 0x1
116#define SSH_OPT_EXP_FLAG_GLOBAL_KNOWNHOSTS 0x2
117#define SSH_OPT_EXP_FLAG_PROXYCOMMAND 0x4
118#define SSH_OPT_EXP_FLAG_IDENTITY 0x8
119#define SSH_OPT_EXP_FLAG_CONTROL_PATH 0x10
123#define SSH_EXT_NEGOTIATION 0x01
125#define SSH_EXT_SIG_RSA_SHA256 0x02
126#define SSH_EXT_SIG_RSA_SHA512 0x04
128#define SSH_EXT_PUBLICKEY_HOSTBOUND 0x08
131struct ssh_common_struct {
132 struct error_struct error;
133 ssh_callbacks callbacks;
137struct ssh_session_struct {
138 struct ssh_common_struct common;
139 struct ssh_socket_struct *socket;
148 struct ssh_timestamp last_rekey_time;
164 char *peer_discon_msg;
165 char *disconnect_message;
166 ssh_buffer in_buffer;
168 ssh_buffer out_buffer;
169 struct ssh_list *out_queue;
174 enum ssh_pending_call_e pending_call_state;
175 enum ssh_session_state_e session_state;
176 enum ssh_packet_state_e packet_state;
177 enum ssh_dh_state_e dh_handshake_state;
178 enum ssh_channel_request_state_e global_req_state;
179 struct ssh_agent_state_struct *agent_state;
182 struct ssh_auth_auto_state_struct *auto_state;
183 enum ssh_auth_service_state_e service_state;
184 enum ssh_auth_state_e state;
185 uint32_t supported_methods;
186 uint32_t current_method;
193 bool send_first_kex_follows;
203 bool first_kex_follows_guess_wrong;
205 ssh_string gssapi_key_exchange_mic;
207 ssh_buffer in_hashbuf;
208 ssh_buffer out_hashbuf;
209 struct ssh_crypto_struct *current_crypto;
211 struct ssh_crypto_struct *next_crypto;
213 struct ssh_list *channels;
218 struct ssh_kbdint_struct *kbdint;
219 struct ssh_gssapi_struct *gssapi;
227 enum ssh_keytypes_e hostkey;
228 enum ssh_digest_e hostkey_digest;
232 struct ssh_list *ssh_message_list;
233 int (*ssh_message_callback)(
struct ssh_session_struct *session,
234 ssh_message msg,
void *userdata);
235 void *ssh_message_callback_data;
236 ssh_server_callbacks server_callbacks;
237 void (*ssh_connection_callback)(
struct ssh_session_struct *session);
238 struct ssh_packet_callbacks_struct default_packet_callbacks;
239 struct ssh_list *packet_callbacks;
240 struct ssh_socket_callbacks_struct socket_callbacks;
241 ssh_poll_ctx default_poll_ctx;
244 ssh_pcap_context pcap_ctx;
247 struct ssh_list *identity;
248 struct ssh_list *identity_non_exp;
249 struct ssh_iterator *identity_it;
250 struct ssh_list *certificate;
251 struct ssh_list *certificate_non_exp;
252 struct ssh_list *proxy_jumps;
253 struct ssh_list *proxy_jumps_user_cb;
254 char *proxy_jumps_str;
261 char *global_knownhosts;
262 char *wanted_methods[SSH_KEX_METHODS];
263 char *pubkey_accepted_types;
266 unsigned long timeout;
267 unsigned long timeout_usec;
270 int StrictHostKeyChecking;
271 char compressionlevel;
272 char *gss_server_identity;
273 char *gss_client_identity;
274 bool gssapi_key_exchange;
275 char *gssapi_key_exchange_algs;
276 int gss_delegate_creds;
280 bool config_processed;
281 uint8_t options_seen[SOC_MAX];
285 bool identities_only;
298 ssh_counter socket_counter;
299 ssh_counter raw_counter;
303 struct ssh_pki_ctx_struct *pki_context;
311typedef int (*ssh_termination_function)(
void *user);
312int ssh_handle_packets(ssh_session session,
int timeout);
313int ssh_handle_packets_termination(ssh_session session,
315 ssh_termination_function fct,
317void ssh_socket_exception_callback(
int code,
int errno_code,
void *user);