libssh
libssh.h
1 /*
2  * This file is part of the SSH Library
3  *
4  * Copyright (c) 2003-2009 by Aris Adamantiadis
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 
21 #ifndef _LIBSSH_H
22 #define _LIBSSH_H
23 
24 #if defined _WIN32 || defined __CYGWIN__
25  #ifdef LIBSSH_STATIC
26  #define LIBSSH_API
27  #else
28  #ifdef LIBSSH_EXPORTS
29  #ifdef __GNUC__
30  #define LIBSSH_API __attribute__((dllexport))
31  #else
32  #define LIBSSH_API __declspec(dllexport)
33  #endif
34  #else
35  #ifdef __GNUC__
36  #define LIBSSH_API __attribute__((dllimport))
37  #else
38  #define LIBSSH_API __declspec(dllimport)
39  #endif
40  #endif
41  #endif
42 #else
43  #if __GNUC__ >= 4 && !defined(__OS2__)
44  #define LIBSSH_API __attribute__((visibility("default")))
45  #else
46  #define LIBSSH_API
47  #endif
48 #endif
49 
50 #ifdef _MSC_VER
51  /* Visual Studio hasn't inttypes.h so it doesn't know uint32_t */
52  typedef int int32_t;
53  typedef unsigned int uint32_t;
54  typedef unsigned short uint16_t;
55  typedef unsigned char uint8_t;
56  typedef unsigned long long uint64_t;
57  typedef int mode_t;
58 #else /* _MSC_VER */
59  #include <unistd.h>
60  #include <inttypes.h>
61  #include <sys/types.h>
62 #endif /* _MSC_VER */
63 
64 #ifdef _WIN32
65  #include <winsock2.h>
66 #else /* _WIN32 */
67  #include <sys/select.h> /* for fd_set * */
68  #include <netdb.h>
69 #endif /* _WIN32 */
70 
71 #define SSH_STRINGIFY(s) SSH_TOSTRING(s)
72 #define SSH_TOSTRING(s) #s
73 
74 /* libssh version macros */
75 #define SSH_VERSION_INT(a, b, c) ((a) << 16 | (b) << 8 | (c))
76 #define SSH_VERSION_DOT(a, b, c) a ##.## b ##.## c
77 #define SSH_VERSION(a, b, c) SSH_VERSION_DOT(a, b, c)
78 
79 /* libssh version */
80 #define LIBSSH_VERSION_MAJOR 0
81 #define LIBSSH_VERSION_MINOR 8
82 #define LIBSSH_VERSION_MICRO 90
83 
84 #define LIBSSH_VERSION_INT SSH_VERSION_INT(LIBSSH_VERSION_MAJOR, \
85  LIBSSH_VERSION_MINOR, \
86  LIBSSH_VERSION_MICRO)
87 #define LIBSSH_VERSION SSH_VERSION(LIBSSH_VERSION_MAJOR, \
88  LIBSSH_VERSION_MINOR, \
89  LIBSSH_VERSION_MICRO)
90 
91 /* GCC have printf type attribute check. */
92 #ifdef __GNUC__
93 #define PRINTF_ATTRIBUTE(a,b) __attribute__ ((__format__ (__printf__, a, b)))
94 #else
95 #define PRINTF_ATTRIBUTE(a,b)
96 #endif /* __GNUC__ */
97 
98 #ifdef __GNUC__
99 #define SSH_DEPRECATED __attribute__ ((deprecated))
100 #else
101 #define SSH_DEPRECATED
102 #endif
103 
104 #ifdef __cplusplus
105 extern "C" {
106 #endif
107 
108 struct ssh_counter_struct {
109  uint64_t in_bytes;
110  uint64_t out_bytes;
111  uint64_t in_packets;
112  uint64_t out_packets;
113 };
114 typedef struct ssh_counter_struct *ssh_counter;
115 
116 typedef struct ssh_agent_struct* ssh_agent;
117 typedef struct ssh_buffer_struct* ssh_buffer;
118 typedef struct ssh_channel_struct* ssh_channel;
119 typedef struct ssh_message_struct* ssh_message;
120 typedef struct ssh_pcap_file_struct* ssh_pcap_file;
121 typedef struct ssh_key_struct* ssh_key;
122 typedef struct ssh_scp_struct* ssh_scp;
123 typedef struct ssh_session_struct* ssh_session;
124 typedef struct ssh_string_struct* ssh_string;
125 typedef struct ssh_event_struct* ssh_event;
126 typedef struct ssh_connector_struct * ssh_connector;
127 typedef void* ssh_gssapi_creds;
128 
129 /* Socket type */
130 #ifdef _WIN32
131 #ifndef socket_t
132 typedef SOCKET socket_t;
133 #endif /* socket_t */
134 #else /* _WIN32 */
135 #ifndef socket_t
136 typedef int socket_t;
137 #endif
138 #endif /* _WIN32 */
139 
140 #define SSH_INVALID_SOCKET ((socket_t) -1)
141 
142 /* the offsets of methods */
143 enum ssh_kex_types_e {
144  SSH_KEX=0,
145  SSH_HOSTKEYS,
146  SSH_CRYPT_C_S,
147  SSH_CRYPT_S_C,
148  SSH_MAC_C_S,
149  SSH_MAC_S_C,
150  SSH_COMP_C_S,
151  SSH_COMP_S_C,
152  SSH_LANG_C_S,
153  SSH_LANG_S_C
154 };
155 
156 #define SSH_CRYPT 2
157 #define SSH_MAC 3
158 #define SSH_COMP 4
159 #define SSH_LANG 5
160 
161 enum ssh_auth_e {
162  SSH_AUTH_SUCCESS=0,
163  SSH_AUTH_DENIED,
164  SSH_AUTH_PARTIAL,
165  SSH_AUTH_INFO,
166  SSH_AUTH_AGAIN,
167  SSH_AUTH_ERROR=-1
168 };
169 
170 /* auth flags */
171 #define SSH_AUTH_METHOD_UNKNOWN 0
172 #define SSH_AUTH_METHOD_NONE 0x0001
173 #define SSH_AUTH_METHOD_PASSWORD 0x0002
174 #define SSH_AUTH_METHOD_PUBLICKEY 0x0004
175 #define SSH_AUTH_METHOD_HOSTBASED 0x0008
176 #define SSH_AUTH_METHOD_INTERACTIVE 0x0010
177 #define SSH_AUTH_METHOD_GSSAPI_MIC 0x0020
178 
179 /* messages */
180 enum ssh_requests_e {
181  SSH_REQUEST_AUTH=1,
182  SSH_REQUEST_CHANNEL_OPEN,
183  SSH_REQUEST_CHANNEL,
184  SSH_REQUEST_SERVICE,
185  SSH_REQUEST_GLOBAL
186 };
187 
188 enum ssh_channel_type_e {
189  SSH_CHANNEL_UNKNOWN=0,
190  SSH_CHANNEL_SESSION,
191  SSH_CHANNEL_DIRECT_TCPIP,
192  SSH_CHANNEL_FORWARDED_TCPIP,
193  SSH_CHANNEL_X11,
194  SSH_CHANNEL_AUTH_AGENT
195 };
196 
197 enum ssh_channel_requests_e {
198  SSH_CHANNEL_REQUEST_UNKNOWN=0,
199  SSH_CHANNEL_REQUEST_PTY,
200  SSH_CHANNEL_REQUEST_EXEC,
201  SSH_CHANNEL_REQUEST_SHELL,
202  SSH_CHANNEL_REQUEST_ENV,
203  SSH_CHANNEL_REQUEST_SUBSYSTEM,
204  SSH_CHANNEL_REQUEST_WINDOW_CHANGE,
205  SSH_CHANNEL_REQUEST_X11
206 };
207 
208 enum ssh_global_requests_e {
209  SSH_GLOBAL_REQUEST_UNKNOWN=0,
210  SSH_GLOBAL_REQUEST_TCPIP_FORWARD,
211  SSH_GLOBAL_REQUEST_CANCEL_TCPIP_FORWARD,
212  SSH_GLOBAL_REQUEST_KEEPALIVE
213 };
214 
215 enum ssh_publickey_state_e {
216  SSH_PUBLICKEY_STATE_ERROR=-1,
217  SSH_PUBLICKEY_STATE_NONE=0,
218  SSH_PUBLICKEY_STATE_VALID=1,
219  SSH_PUBLICKEY_STATE_WRONG=2
220 };
221 
222 /* Status flags */
224 #define SSH_CLOSED 0x01
225 
226 #define SSH_READ_PENDING 0x02
227 
228 #define SSH_CLOSED_ERROR 0x04
229 
230 #define SSH_WRITE_PENDING 0x08
231 
232 enum ssh_server_known_e {
233  SSH_SERVER_ERROR=-1,
234  SSH_SERVER_NOT_KNOWN=0,
235  SSH_SERVER_KNOWN_OK,
236  SSH_SERVER_KNOWN_CHANGED,
237  SSH_SERVER_FOUND_OTHER,
238  SSH_SERVER_FILE_NOT_FOUND
239 };
240 
241 enum ssh_known_hosts_e {
242  SSH_KNOWN_HOSTS_ERROR = -2,
243  SSH_KNOWN_HOSTS_NOT_FOUND = -1,
244  SSH_KNOWN_HOSTS_UNKNOWN = 0,
245  SSH_KNOWN_HOSTS_OK,
246  SSH_KNOWN_HOSTS_CHANGED,
247  SSH_KNOWN_HOSTS_OTHER,
248 };
249 
250 #ifndef MD5_DIGEST_LEN
251  #define MD5_DIGEST_LEN 16
252 #endif
253 /* errors */
254 
255 enum ssh_error_types_e {
256  SSH_NO_ERROR=0,
257  SSH_REQUEST_DENIED,
258  SSH_FATAL,
259  SSH_EINTR
260 };
261 
262 /* some types for keys */
263 enum ssh_keytypes_e{
264  SSH_KEYTYPE_UNKNOWN=0,
265  SSH_KEYTYPE_DSS=1,
266  SSH_KEYTYPE_RSA,
267  SSH_KEYTYPE_RSA1,
268  SSH_KEYTYPE_ECDSA,
269  SSH_KEYTYPE_ED25519,
270  SSH_KEYTYPE_DSS_CERT01,
271  SSH_KEYTYPE_RSA_CERT01
272 };
273 
274 enum ssh_keycmp_e {
275  SSH_KEY_CMP_PUBLIC = 0,
276  SSH_KEY_CMP_PRIVATE
277 };
278 
279 #define SSH_ADDRSTRLEN 46
280 
281 struct ssh_knownhosts_entry {
282  char *hostname;
283  char *unparsed;
284  ssh_key publickey;
285  char *comment;
286 };
287 
288 
289 /* Error return codes */
290 #define SSH_OK 0 /* No error */
291 #define SSH_ERROR -1 /* Error of some kind */
292 #define SSH_AGAIN -2 /* The nonblocking call must be repeated */
293 #define SSH_EOF -127 /* We have already a eof */
294 
301 enum {
317 };
319 #define SSH_LOG_RARE SSH_LOG_WARNING
320 
329 #define SSH_LOG_NONE 0
330 
331 #define SSH_LOG_WARN 1
332 
333 #define SSH_LOG_INFO 2
334 
335 #define SSH_LOG_DEBUG 3
336 
337 #define SSH_LOG_TRACE 4
338 
341 enum ssh_options_e {
342  SSH_OPTIONS_HOST,
343  SSH_OPTIONS_PORT,
344  SSH_OPTIONS_PORT_STR,
345  SSH_OPTIONS_FD,
346  SSH_OPTIONS_USER,
347  SSH_OPTIONS_SSH_DIR,
348  SSH_OPTIONS_IDENTITY,
349  SSH_OPTIONS_ADD_IDENTITY,
350  SSH_OPTIONS_KNOWNHOSTS,
351  SSH_OPTIONS_TIMEOUT,
352  SSH_OPTIONS_TIMEOUT_USEC,
353  SSH_OPTIONS_SSH1,
354  SSH_OPTIONS_SSH2,
355  SSH_OPTIONS_LOG_VERBOSITY,
356  SSH_OPTIONS_LOG_VERBOSITY_STR,
357  SSH_OPTIONS_CIPHERS_C_S,
358  SSH_OPTIONS_CIPHERS_S_C,
359  SSH_OPTIONS_COMPRESSION_C_S,
360  SSH_OPTIONS_COMPRESSION_S_C,
361  SSH_OPTIONS_PROXYCOMMAND,
362  SSH_OPTIONS_BINDADDR,
363  SSH_OPTIONS_STRICTHOSTKEYCHECK,
364  SSH_OPTIONS_COMPRESSION,
365  SSH_OPTIONS_COMPRESSION_LEVEL,
366  SSH_OPTIONS_KEY_EXCHANGE,
367  SSH_OPTIONS_HOSTKEYS,
368  SSH_OPTIONS_GSSAPI_SERVER_IDENTITY,
369  SSH_OPTIONS_GSSAPI_CLIENT_IDENTITY,
370  SSH_OPTIONS_GSSAPI_DELEGATE_CREDENTIALS,
371  SSH_OPTIONS_HMAC_C_S,
372  SSH_OPTIONS_HMAC_S_C,
373  SSH_OPTIONS_PASSWORD_AUTH,
374  SSH_OPTIONS_PUBKEY_AUTH,
375  SSH_OPTIONS_KBDINT_AUTH,
376  SSH_OPTIONS_GSSAPI_AUTH,
377  SSH_OPTIONS_GLOBAL_KNOWNHOSTS,
378  SSH_OPTIONS_NODELAY,
379 };
380 
381 enum {
383  SSH_SCP_WRITE,
385  SSH_SCP_READ,
386  SSH_SCP_RECURSIVE=0x10
387 };
388 
389 enum ssh_scp_request_types {
391  SSH_SCP_REQUEST_NEWDIR=1,
393  SSH_SCP_REQUEST_NEWFILE,
395  SSH_SCP_REQUEST_EOF,
397  SSH_SCP_REQUEST_ENDDIR,
399  SSH_SCP_REQUEST_WARNING
400 };
401 
402 enum ssh_connector_flags_e {
404  SSH_CONNECTOR_STDOUT = 1,
406  SSH_CONNECTOR_STDERR = 2,
408  SSH_CONNECTOR_BOTH = 3
409 };
410 
411 LIBSSH_API int ssh_blocking_flush(ssh_session session, int timeout);
412 LIBSSH_API ssh_channel ssh_channel_accept_x11(ssh_channel channel, int timeout_ms);
413 LIBSSH_API int ssh_channel_change_pty_size(ssh_channel channel,int cols,int rows);
414 LIBSSH_API int ssh_channel_close(ssh_channel channel);
415 LIBSSH_API void ssh_channel_free(ssh_channel channel);
416 LIBSSH_API int ssh_channel_get_exit_status(ssh_channel channel);
417 LIBSSH_API ssh_session ssh_channel_get_session(ssh_channel channel);
418 LIBSSH_API int ssh_channel_is_closed(ssh_channel channel);
419 LIBSSH_API int ssh_channel_is_eof(ssh_channel channel);
420 LIBSSH_API int ssh_channel_is_open(ssh_channel channel);
421 LIBSSH_API ssh_channel ssh_channel_new(ssh_session session);
422 LIBSSH_API int ssh_channel_open_auth_agent(ssh_channel channel);
423 LIBSSH_API int ssh_channel_open_forward(ssh_channel channel, const char *remotehost,
424  int remoteport, const char *sourcehost, int localport);
425 LIBSSH_API int ssh_channel_open_session(ssh_channel channel);
426 LIBSSH_API int ssh_channel_open_x11(ssh_channel channel, const char *orig_addr, int orig_port);
427 LIBSSH_API int ssh_channel_poll(ssh_channel channel, int is_stderr);
428 LIBSSH_API int ssh_channel_poll_timeout(ssh_channel channel, int timeout, int is_stderr);
429 LIBSSH_API int ssh_channel_read(ssh_channel channel, void *dest, uint32_t count, int is_stderr);
430 LIBSSH_API int ssh_channel_read_timeout(ssh_channel channel, void *dest, uint32_t count, int is_stderr, int timeout_ms);
431 LIBSSH_API int ssh_channel_read_nonblocking(ssh_channel channel, void *dest, uint32_t count,
432  int is_stderr);
433 LIBSSH_API int ssh_channel_request_env(ssh_channel channel, const char *name, const char *value);
434 LIBSSH_API int ssh_channel_request_exec(ssh_channel channel, const char *cmd);
435 LIBSSH_API int ssh_channel_request_pty(ssh_channel channel);
436 LIBSSH_API int ssh_channel_request_pty_size(ssh_channel channel, const char *term,
437  int cols, int rows);
438 LIBSSH_API int ssh_channel_request_shell(ssh_channel channel);
439 LIBSSH_API int ssh_channel_request_send_signal(ssh_channel channel, const char *signum);
440 LIBSSH_API int ssh_channel_request_send_break(ssh_channel channel, uint32_t length);
441 LIBSSH_API int ssh_channel_request_sftp(ssh_channel channel);
442 LIBSSH_API int ssh_channel_request_subsystem(ssh_channel channel, const char *subsystem);
443 LIBSSH_API int ssh_channel_request_x11(ssh_channel channel, int single_connection, const char *protocol,
444  const char *cookie, int screen_number);
445 LIBSSH_API int ssh_channel_request_auth_agent(ssh_channel channel);
446 LIBSSH_API int ssh_channel_send_eof(ssh_channel channel);
447 LIBSSH_API int ssh_channel_select(ssh_channel *readchans, ssh_channel *writechans, ssh_channel *exceptchans, struct
448  timeval * timeout);
449 LIBSSH_API void ssh_channel_set_blocking(ssh_channel channel, int blocking);
450 LIBSSH_API void ssh_channel_set_counter(ssh_channel channel,
451  ssh_counter counter);
452 LIBSSH_API int ssh_channel_write(ssh_channel channel, const void *data, uint32_t len);
453 LIBSSH_API int ssh_channel_write_stderr(ssh_channel channel,
454  const void *data,
455  uint32_t len);
456 LIBSSH_API uint32_t ssh_channel_window_size(ssh_channel channel);
457 
458 LIBSSH_API char *ssh_basename (const char *path);
459 LIBSSH_API void ssh_clean_pubkey_hash(unsigned char **hash);
460 LIBSSH_API int ssh_connect(ssh_session session);
461 
462 LIBSSH_API ssh_connector ssh_connector_new(ssh_session session);
463 LIBSSH_API void ssh_connector_free(ssh_connector connector);
464 LIBSSH_API int ssh_connector_set_in_channel(ssh_connector connector,
465  ssh_channel channel,
466  enum ssh_connector_flags_e flags);
467 LIBSSH_API int ssh_connector_set_out_channel(ssh_connector connector,
468  ssh_channel channel,
469  enum ssh_connector_flags_e flags);
470 LIBSSH_API void ssh_connector_set_in_fd(ssh_connector connector, socket_t fd);
471 LIBSSH_API void ssh_connector_set_out_fd(ssh_connector connector, socket_t fd);
472 
473 LIBSSH_API const char *ssh_copyright(void);
474 LIBSSH_API void ssh_disconnect(ssh_session session);
475 LIBSSH_API char *ssh_dirname (const char *path);
476 LIBSSH_API int ssh_finalize(void);
477 
478 /* REVERSE PORT FORWARDING */
479 LIBSSH_API ssh_channel ssh_channel_accept_forward(ssh_session session,
480  int timeout_ms,
481  int *destination_port);
482 LIBSSH_API int ssh_channel_cancel_forward(ssh_session session,
483  const char *address,
484  int port);
485 LIBSSH_API int ssh_channel_listen_forward(ssh_session session,
486  const char *address,
487  int port,
488  int *bound_port);
489 
490 LIBSSH_API void ssh_free(ssh_session session);
491 LIBSSH_API const char *ssh_get_disconnect_message(ssh_session session);
492 LIBSSH_API const char *ssh_get_error(void *error);
493 LIBSSH_API int ssh_get_error_code(void *error);
494 LIBSSH_API socket_t ssh_get_fd(ssh_session session);
495 LIBSSH_API char *ssh_get_hexa(const unsigned char *what, size_t len);
496 LIBSSH_API char *ssh_get_issue_banner(ssh_session session);
497 LIBSSH_API int ssh_get_openssh_version(ssh_session session);
498 
499 LIBSSH_API int ssh_get_server_publickey(ssh_session session, ssh_key *key);
500 
501 enum ssh_publickey_hash_type {
502  SSH_PUBLICKEY_HASH_SHA1,
503  SSH_PUBLICKEY_HASH_MD5
504 };
505 LIBSSH_API int ssh_get_publickey_hash(const ssh_key key,
506  enum ssh_publickey_hash_type type,
507  unsigned char **hash,
508  size_t *hlen);
509 
510 /* DEPRECATED FUNCTIONS */
511 SSH_DEPRECATED LIBSSH_API int ssh_get_pubkey_hash(ssh_session session, unsigned char **hash);
512 SSH_DEPRECATED LIBSSH_API ssh_channel ssh_forward_accept(ssh_session session, int timeout_ms);
513 SSH_DEPRECATED LIBSSH_API int ssh_forward_cancel(ssh_session session, const char *address, int port);
514 SSH_DEPRECATED LIBSSH_API int ssh_forward_listen(ssh_session session, const char *address, int port, int *bound_port);
515 SSH_DEPRECATED LIBSSH_API int ssh_get_publickey(ssh_session session, ssh_key *key);
516 
517 
518 LIBSSH_API int ssh_get_random(void *where,int len,int strong);
519 LIBSSH_API int ssh_get_version(ssh_session session);
520 LIBSSH_API int ssh_get_status(ssh_session session);
521 LIBSSH_API int ssh_get_poll_flags(ssh_session session);
522 LIBSSH_API int ssh_init(void);
523 LIBSSH_API int ssh_is_blocking(ssh_session session);
524 LIBSSH_API int ssh_is_connected(ssh_session session);
525 LIBSSH_API int ssh_is_server_known(ssh_session session);
526 
527 /* KNOWN HOSTS */
528 LIBSSH_API void ssh_knownhosts_entry_free(struct ssh_knownhosts_entry *entry);
529 #define SSH_KNOWNHOSTS_ENTRY_FREE(e) do { \
530  if ((e) != NULL) { \
531  ssh_knownhosts_entry_free(e); \
532  e = NULL; \
533  } \
534 } while(0)
535 
536 LIBSSH_API int ssh_known_hosts_parse_line(const char *host,
537  const char *line,
538  struct ssh_knownhosts_entry **entry);
539 LIBSSH_API enum ssh_known_hosts_e ssh_session_has_known_hosts_entry(ssh_session session);
540 
541 LIBSSH_API int ssh_session_export_known_hosts_entry(ssh_session session,
542  char **pentry_string);
543 LIBSSH_API int ssh_session_update_known_hosts(ssh_session session);
544 
545 LIBSSH_API enum ssh_known_hosts_e
546 ssh_session_get_known_hosts_entry(ssh_session session,
547  struct ssh_knownhosts_entry **pentry);
548 LIBSSH_API enum ssh_known_hosts_e ssh_session_is_known_server(ssh_session session);
549 
550 /* LOGGING */
551 LIBSSH_API int ssh_set_log_level(int level);
552 LIBSSH_API int ssh_get_log_level(void);
553 LIBSSH_API void *ssh_get_log_userdata(void);
554 LIBSSH_API int ssh_set_log_userdata(void *data);
555 LIBSSH_API void _ssh_log(int verbosity,
556  const char *function,
557  const char *format, ...) PRINTF_ATTRIBUTE(3, 4);
558 
559 /* legacy */
560 SSH_DEPRECATED LIBSSH_API void ssh_log(ssh_session session,
561  int prioriry,
562  const char *format, ...) PRINTF_ATTRIBUTE(3, 4);
563 
564 LIBSSH_API ssh_channel ssh_message_channel_request_open_reply_accept(ssh_message msg);
565 LIBSSH_API int ssh_message_channel_request_reply_success(ssh_message msg);
566 LIBSSH_API void ssh_message_free(ssh_message msg);
567 LIBSSH_API ssh_message ssh_message_get(ssh_session session);
568 LIBSSH_API int ssh_message_subtype(ssh_message msg);
569 LIBSSH_API int ssh_message_type(ssh_message msg);
570 LIBSSH_API int ssh_mkdir (const char *pathname, mode_t mode);
571 LIBSSH_API ssh_session ssh_new(void);
572 
573 LIBSSH_API int ssh_options_copy(ssh_session src, ssh_session *dest);
574 LIBSSH_API int ssh_options_getopt(ssh_session session, int *argcptr, char **argv);
575 LIBSSH_API int ssh_options_parse_config(ssh_session session, const char *filename);
576 LIBSSH_API int ssh_options_set(ssh_session session, enum ssh_options_e type,
577  const void *value);
578 LIBSSH_API int ssh_options_get(ssh_session session, enum ssh_options_e type,
579  char **value);
580 LIBSSH_API int ssh_options_get_port(ssh_session session, unsigned int * port_target);
581 LIBSSH_API int ssh_pcap_file_close(ssh_pcap_file pcap);
582 LIBSSH_API void ssh_pcap_file_free(ssh_pcap_file pcap);
583 LIBSSH_API ssh_pcap_file ssh_pcap_file_new(void);
584 LIBSSH_API int ssh_pcap_file_open(ssh_pcap_file pcap, const char *filename);
585 
599 typedef int (*ssh_auth_callback) (const char *prompt, char *buf, size_t len,
600  int echo, int verify, void *userdata);
601 
602 LIBSSH_API ssh_key ssh_key_new(void);
603 LIBSSH_API void ssh_key_free (ssh_key key);
604 LIBSSH_API enum ssh_keytypes_e ssh_key_type(const ssh_key key);
605 LIBSSH_API const char *ssh_key_type_to_char(enum ssh_keytypes_e type);
606 LIBSSH_API enum ssh_keytypes_e ssh_key_type_from_name(const char *name);
607 LIBSSH_API int ssh_key_is_public(const ssh_key k);
608 LIBSSH_API int ssh_key_is_private(const ssh_key k);
609 LIBSSH_API int ssh_key_cmp(const ssh_key k1,
610  const ssh_key k2,
611  enum ssh_keycmp_e what);
612 
613 LIBSSH_API int ssh_pki_generate(enum ssh_keytypes_e type, int parameter,
614  ssh_key *pkey);
615 LIBSSH_API int ssh_pki_import_privkey_base64(const char *b64_key,
616  const char *passphrase,
617  ssh_auth_callback auth_fn,
618  void *auth_data,
619  ssh_key *pkey);
620 LIBSSH_API int ssh_pki_import_privkey_file(const char *filename,
621  const char *passphrase,
622  ssh_auth_callback auth_fn,
623  void *auth_data,
624  ssh_key *pkey);
625 LIBSSH_API int ssh_pki_export_privkey_file(const ssh_key privkey,
626  const char *passphrase,
627  ssh_auth_callback auth_fn,
628  void *auth_data,
629  const char *filename);
630 
631 LIBSSH_API int ssh_pki_copy_cert_to_privkey(const ssh_key cert_key,
632  ssh_key privkey);
633 
634 LIBSSH_API int ssh_pki_import_pubkey_base64(const char *b64_key,
635  enum ssh_keytypes_e type,
636  ssh_key *pkey);
637 LIBSSH_API int ssh_pki_import_pubkey_file(const char *filename,
638  ssh_key *pkey);
639 
640 LIBSSH_API int ssh_pki_import_cert_base64(const char *b64_cert,
641  enum ssh_keytypes_e type,
642  ssh_key *pkey);
643 LIBSSH_API int ssh_pki_import_cert_file(const char *filename,
644  ssh_key *pkey);
645 
646 LIBSSH_API int ssh_pki_export_privkey_to_pubkey(const ssh_key privkey,
647  ssh_key *pkey);
648 LIBSSH_API int ssh_pki_export_pubkey_base64(const ssh_key key,
649  char **b64_key);
650 LIBSSH_API int ssh_pki_export_pubkey_file(const ssh_key key,
651  const char *filename);
652 
653 LIBSSH_API const char *ssh_pki_key_ecdsa_name(const ssh_key key);
654 
655 LIBSSH_API void ssh_print_hexa(const char *descr, const unsigned char *what, size_t len);
656 LIBSSH_API int ssh_send_ignore (ssh_session session, const char *data);
657 LIBSSH_API int ssh_send_debug (ssh_session session, const char *message, int always_display);
658 LIBSSH_API void ssh_gssapi_set_creds(ssh_session session, const ssh_gssapi_creds creds);
659 LIBSSH_API int ssh_scp_accept_request(ssh_scp scp);
660 LIBSSH_API int ssh_scp_close(ssh_scp scp);
661 LIBSSH_API int ssh_scp_deny_request(ssh_scp scp, const char *reason);
662 LIBSSH_API void ssh_scp_free(ssh_scp scp);
663 LIBSSH_API int ssh_scp_init(ssh_scp scp);
664 LIBSSH_API int ssh_scp_leave_directory(ssh_scp scp);
665 LIBSSH_API ssh_scp ssh_scp_new(ssh_session session, int mode, const char *location);
666 LIBSSH_API int ssh_scp_pull_request(ssh_scp scp);
667 LIBSSH_API int ssh_scp_push_directory(ssh_scp scp, const char *dirname, int mode);
668 LIBSSH_API int ssh_scp_push_file(ssh_scp scp, const char *filename, size_t size, int perms);
669 LIBSSH_API int ssh_scp_push_file64(ssh_scp scp, const char *filename, uint64_t size, int perms);
670 LIBSSH_API int ssh_scp_read(ssh_scp scp, void *buffer, size_t size);
671 LIBSSH_API const char *ssh_scp_request_get_filename(ssh_scp scp);
672 LIBSSH_API int ssh_scp_request_get_permissions(ssh_scp scp);
673 LIBSSH_API size_t ssh_scp_request_get_size(ssh_scp scp);
674 LIBSSH_API uint64_t ssh_scp_request_get_size64(ssh_scp scp);
675 LIBSSH_API const char *ssh_scp_request_get_warning(ssh_scp scp);
676 LIBSSH_API int ssh_scp_write(ssh_scp scp, const void *buffer, size_t len);
677 LIBSSH_API int ssh_select(ssh_channel *channels, ssh_channel *outchannels, socket_t maxfd,
678  fd_set *readfds, struct timeval *timeout);
679 LIBSSH_API int ssh_service_request(ssh_session session, const char *service);
680 LIBSSH_API int ssh_set_agent_channel(ssh_session session, ssh_channel channel);
681 LIBSSH_API int ssh_set_agent_socket(ssh_session session, socket_t fd);
682 LIBSSH_API void ssh_set_blocking(ssh_session session, int blocking);
683 LIBSSH_API void ssh_set_counters(ssh_session session, ssh_counter scounter,
684  ssh_counter rcounter);
685 LIBSSH_API void ssh_set_fd_except(ssh_session session);
686 LIBSSH_API void ssh_set_fd_toread(ssh_session session);
687 LIBSSH_API void ssh_set_fd_towrite(ssh_session session);
688 LIBSSH_API void ssh_silent_disconnect(ssh_session session);
689 LIBSSH_API int ssh_set_pcap_file(ssh_session session, ssh_pcap_file pcapfile);
690 
691 /* USERAUTH */
692 LIBSSH_API int ssh_userauth_none(ssh_session session, const char *username);
693 LIBSSH_API int ssh_userauth_list(ssh_session session, const char *username);
694 LIBSSH_API int ssh_userauth_try_publickey(ssh_session session,
695  const char *username,
696  const ssh_key pubkey);
697 LIBSSH_API int ssh_userauth_publickey(ssh_session session,
698  const char *username,
699  const ssh_key privkey);
700 #ifndef _WIN32
701 LIBSSH_API int ssh_userauth_agent(ssh_session session,
702  const char *username);
703 #endif
704 LIBSSH_API int ssh_userauth_publickey_auto(ssh_session session,
705  const char *username,
706  const char *passphrase);
707 LIBSSH_API int ssh_userauth_password(ssh_session session,
708  const char *username,
709  const char *password);
710 
711 LIBSSH_API int ssh_userauth_kbdint(ssh_session session, const char *user, const char *submethods);
712 LIBSSH_API const char *ssh_userauth_kbdint_getinstruction(ssh_session session);
713 LIBSSH_API const char *ssh_userauth_kbdint_getname(ssh_session session);
714 LIBSSH_API int ssh_userauth_kbdint_getnprompts(ssh_session session);
715 LIBSSH_API const char *ssh_userauth_kbdint_getprompt(ssh_session session, unsigned int i, char *echo);
716 LIBSSH_API int ssh_userauth_kbdint_getnanswers(ssh_session session);
717 LIBSSH_API const char *ssh_userauth_kbdint_getanswer(ssh_session session, unsigned int i);
718 LIBSSH_API int ssh_userauth_kbdint_setanswer(ssh_session session, unsigned int i,
719  const char *answer);
720 LIBSSH_API int ssh_userauth_gssapi(ssh_session session);
721 LIBSSH_API const char *ssh_version(int req_version);
722 LIBSSH_API int ssh_write_knownhost(ssh_session session);
723 LIBSSH_API char *ssh_dump_knownhost(ssh_session session);
724 
725 LIBSSH_API void ssh_string_burn(ssh_string str);
726 LIBSSH_API ssh_string ssh_string_copy(ssh_string str);
727 LIBSSH_API void *ssh_string_data(ssh_string str);
728 LIBSSH_API int ssh_string_fill(ssh_string str, const void *data, size_t len);
729 LIBSSH_API void ssh_string_free(ssh_string str);
730 LIBSSH_API ssh_string ssh_string_from_char(const char *what);
731 LIBSSH_API size_t ssh_string_len(ssh_string str);
732 LIBSSH_API ssh_string ssh_string_new(size_t size);
733 LIBSSH_API const char *ssh_string_get_char(ssh_string str);
734 LIBSSH_API char *ssh_string_to_char(ssh_string str);
735 LIBSSH_API void ssh_string_free_char(char *s);
736 
737 LIBSSH_API int ssh_getpass(const char *prompt, char *buf, size_t len, int echo,
738  int verify);
739 
740 
741 typedef int (*ssh_event_callback)(socket_t fd, int revents, void *userdata);
742 
743 LIBSSH_API ssh_event ssh_event_new(void);
744 LIBSSH_API int ssh_event_add_fd(ssh_event event, socket_t fd, short events,
745  ssh_event_callback cb, void *userdata);
746 LIBSSH_API int ssh_event_add_session(ssh_event event, ssh_session session);
747 LIBSSH_API int ssh_event_add_connector(ssh_event event, ssh_connector connector);
748 LIBSSH_API int ssh_event_dopoll(ssh_event event, int timeout);
749 LIBSSH_API int ssh_event_remove_fd(ssh_event event, socket_t fd);
750 LIBSSH_API int ssh_event_remove_session(ssh_event event, ssh_session session);
751 LIBSSH_API int ssh_event_remove_connector(ssh_event event, ssh_connector connector);
752 LIBSSH_API void ssh_event_free(ssh_event event);
753 LIBSSH_API const char* ssh_get_clientbanner(ssh_session session);
754 LIBSSH_API const char* ssh_get_serverbanner(ssh_session session);
755 LIBSSH_API const char* ssh_get_kex_algo(ssh_session session);
756 LIBSSH_API const char* ssh_get_cipher_in(ssh_session session);
757 LIBSSH_API const char* ssh_get_cipher_out(ssh_session session);
758 LIBSSH_API const char* ssh_get_hmac_in(ssh_session session);
759 LIBSSH_API const char* ssh_get_hmac_out(ssh_session session);
760 
761 LIBSSH_API ssh_buffer ssh_buffer_new(void);
762 LIBSSH_API void ssh_buffer_free(ssh_buffer buffer);
763 LIBSSH_API int ssh_buffer_reinit(ssh_buffer buffer);
764 LIBSSH_API int ssh_buffer_add_data(ssh_buffer buffer, const void *data, uint32_t len);
765 LIBSSH_API uint32_t ssh_buffer_get_data(ssh_buffer buffer, void *data, uint32_t requestedlen);
766 LIBSSH_API void *ssh_buffer_get(ssh_buffer buffer);
767 LIBSSH_API uint32_t ssh_buffer_get_len(ssh_buffer buffer);
768 
769 #ifndef LIBSSH_LEGACY_0_4
770 #include "libssh/legacy.h"
771 #endif
772 
773 #ifdef __cplusplus
774 }
775 #endif
776 #endif /* _LIBSSH_H */
int ssh_set_log_userdata(void *data)
Set the userdata for the logging function.
Definition: log.c:235
void * ssh_get_log_userdata(void)
Get the userdata of the logging function.
Definition: log.c:219
int ssh_pki_export_privkey_to_pubkey(const ssh_key privkey, ssh_key *pkey)
Create a public key from a private key.
Definition: pki.c:1255
int ssh_userauth_kbdint(ssh_session session, const char *user, const char *submethods)
Try to authenticate through the "keyboard-interactive" method.
Definition: auth.c:1526
int ssh_scp_init(ssh_scp scp)
Initialize the scp channel.
Definition: scp.c:95
int ssh_channel_read_timeout(ssh_channel channel, void *dest, uint32_t count, int is_stderr, int timeout_ms)
Reads data from a channel.
Definition: channels.c:2660
int ssh_options_get(ssh_session session, enum ssh_options_e type, char **value)
This function can get ssh options, it does not support all options provided for ssh options set...
Definition: options.c:1001
int ssh_get_pubkey_hash(ssh_session session, unsigned char **hash)
Definition: dh.c:945
char * ssh_string_to_char(struct ssh_string_struct *s)
Convert a SSH string to a C nul-terminated string.
Definition: string.c:176
int ssh_channel_select(ssh_channel *readchans, ssh_channel *writechans, ssh_channel *exceptchans, struct timeval *timeout)
Act like the standard select(2) on channels.
Definition: channels.c:3054
int ssh_options_parse_config(ssh_session session, const char *filename)
Parse the ssh config file.
Definition: options.c:1250
int ssh_channel_request_x11(ssh_channel channel, int single_connection, const char *protocol, const char *cookie, int screen_number)
Sends the "x11-req" channel request over an existing session channel.
Definition: channels.c:1846
const char * ssh_key_type_to_char(enum ssh_keytypes_e type)
Convert a key type to a string.
Definition: pki.c:203
int ssh_channel_request_shell(ssh_channel channel)
Request a shell.
Definition: channels.c:1735
int ssh_init(void)
Initialize global cryptographic data structures.
Definition: init.c:148
int ssh_message_type(ssh_message msg)
Get the type of the message.
Definition: messages.c:509
int ssh_send_debug(ssh_session session, const char *message, int always_display)
Send a debug message.
Definition: session.c:867
const char * ssh_get_cipher_in(ssh_session session)
get the name of the input cipher for the given session.
Definition: session.c:369
int ssh_channel_open_forward(ssh_channel channel, const char *remotehost, int remoteport, const char *sourcehost, int localport)
Open a TCP/IP forwarding channel.
Definition: channels.c:923
int ssh_channel_request_send_break(ssh_channel channel, uint32_t length)
Send a break signal to the server (as described in RFC 4335).
Definition: channels.c:2485
int ssh_channel_is_eof(ssh_channel channel)
Check if remote has sent an EOF.
Definition: channels.c:1412
int ssh_set_log_level(int level)
Set the log level of the library.
Definition: log.c:181
int ssh_channel_send_eof(ssh_channel channel)
Send an end of file on the channel.
Definition: channels.c:1054
void ssh_buffer_free(struct ssh_buffer_struct *buffer)
Deallocate a SSH buffer.
Definition: buffer.c:102
void ssh_scp_free(ssh_scp scp)
Free a scp context.
Definition: scp.c:199
void ssh_clean_pubkey_hash(unsigned char **hash)
Deallocate the hash obtained by ssh_get_pubkey_hash.
Definition: dh.c:1007
int ssh_channel_close(ssh_channel channel)
Close a channel.
Definition: channels.c:1106
int ssh_pki_export_privkey_file(const ssh_key privkey, const char *passphrase, ssh_auth_callback auth_fn, void *auth_data, const char *filename)
Export a private key to a pem file on disk, or OpenSSH format for keytype ssh-ed25519.
Definition: pki.c:566
void ssh_set_fd_toread(ssh_session session)
Tell the session it has data to read on the file descriptor without blocking.
Definition: session.c:544
int ssh_key_is_public(const ssh_key k)
Check if the key has/is a public key.
Definition: pki.c:270
uint32_t ssh_channel_window_size(ssh_channel channel)
Get the remote window size.
Definition: channels.c:1352
int ssh_scp_leave_directory(ssh_scp scp)
Leave a directory.
Definition: scp.c:271
int ssh_event_remove_connector(ssh_event event, ssh_connector connector)
Remove a connector from an event context.
Definition: poll.c:1003
ssh_string ssh_string_new(size_t size)
Create a new SSH String object.
Definition: string.c:53
int ssh_scp_deny_request(ssh_scp scp, const char *reason)
Deny the transfer of a file or creation of a directory coming from the remote party.
Definition: scp.c:644
int ssh_key_is_private(const ssh_key k)
Check if the key is a private key.
Definition: pki.c:285
int ssh_get_openssh_version(ssh_session session)
Get the version of the OpenSSH server, if it is not an OpenSSH server then 0 will be returned...
Definition: client.c:629
int ssh_channel_open_auth_agent(ssh_channel channel)
Open an agent authentication forwarding channel.
Definition: channels.c:885
const char * ssh_version(int req_version)
Check if libssh is the required version or get the version string.
Definition: misc.c:356
ssh_message ssh_message_get(ssh_session session)
Retrieve a SSH message from a SSH session.
Definition: messages.c:482
int ssh_userauth_list(ssh_session session, const char *username)
Get available authentication methods from the server.
Definition: auth.c:318
const char * ssh_get_error(void *error)
Retrieve the error text message from the last error.
Definition: error.c:113
Lower level protocol infomations, packet level.
Definition: libssh.h:313
int ssh_channel_write(ssh_channel channel, const void *data, uint32_t len)
Blocking write on a channel.
Definition: channels.c:1369
int ssh_scp_accept_request(ssh_scp scp)
Accepts transfer of a file or creation of a directory coming from the remote party.
Definition: scp.c:673
int ssh_event_add_session(ssh_event event, ssh_session session)
remove the poll handle from session and assign them to a event, when used in blocking mode...
Definition: poll.c:812
int ssh_pki_export_pubkey_base64(const ssh_key key, char **b64_key)
Convert a public key to a base64 encoded key.
Definition: pki.c:1323
int ssh_channel_request_pty_size(ssh_channel channel, const char *term, int cols, int rows)
Request a pty with a specific type and size.
Definition: channels.c:1614
int ssh_channel_request_subsystem(ssh_channel channel, const char *subsystem)
Request a subsystem (for example "sftp").
Definition: channels.c:1757
int ssh_pki_generate(enum ssh_keytypes_e type, int parameter, ssh_key *pkey)
Generates a keypair.
Definition: pki.c:1187
ssh_string ssh_string_from_char(const char *what)
Create a ssh string using a C string.
Definition: string.c:103
int ssh_getpass(const char *prompt, char *buf, size_t len, int echo, int verify)
Get a password from the console.
Definition: getpass.c:214
int ssh_event_dopoll(ssh_event event, int timeout)
Poll all the sockets and sessions associated through an event object.i.
Definition: poll.c:884
int ssh_get_version(ssh_session session)
Get the protocol version of the session.
Definition: session.c:797
int ssh_channel_request_env(ssh_channel channel, const char *name, const char *value)
Set environment variables.
Definition: channels.c:2299
void ssh_set_fd_except(ssh_session session)
Tell the session it has an exception to catch on the file descriptor.
Definition: session.c:570
uint32_t ssh_buffer_get_len(struct ssh_buffer_struct *buffer)
Get the length of the buffer from the current position.
Definition: buffer.c:527
char * ssh_get_issue_banner(ssh_session session)
Get the issue banner from the server.
Definition: client.c:603
int ssh_buffer_reinit(struct ssh_buffer_struct *buffer)
Reinitialize a SSH buffer.
Definition: buffer.c:195
int ssh_pki_copy_cert_to_privkey(const ssh_key cert_key, ssh_key privkey)
Copy the certificate part of a public key into a private key.
Definition: pki.c:1416
int ssh_string_fill(struct ssh_string_struct *s, const void *data, size_t len)
Fill a string with given data.
Definition: string.c:82
int ssh_userauth_kbdint_getnprompts(ssh_session session)
Get the number of prompts (questions) the server has given.
Definition: auth.c:1569
int ssh_event_add_fd(ssh_event event, socket_t fd, short events, ssh_event_callback cb, void *userdata)
Add a fd to the event and assign it a callback, when used in blocking mode.
Definition: poll.c:743
void ssh_set_counters(ssh_session session, ssh_counter scounter, ssh_counter rcounter)
Set the session data counters.
Definition: session.c:923
int ssh_options_copy(ssh_session src, ssh_session *dest)
Duplicate the options of a session structure.
Definition: options.c:64
const char * ssh_userauth_kbdint_getinstruction(ssh_session session)
Get the "instruction" of the message block.
Definition: auth.c:1614
int ssh_channel_open_session(ssh_channel channel)
Open a session channel (suited for a shell, not TCP forwarding).
Definition: channels.c:858
uint64_t ssh_scp_request_get_size64(ssh_scp scp)
Get the size of the file being pushed from the other party.
Definition: scp.c:789
struct ssh_string_struct * ssh_string_copy(struct ssh_string_struct *s)
Copy a string, return a newly allocated string.
Definition: string.c:216
const char * ssh_string_get_char(struct ssh_string_struct *s)
Get the the string as a C nul-terminated string.
Definition: string.c:155
void * ssh_buffer_get(struct ssh_buffer_struct *buffer)
Get a pointer to the head of a buffer at the current position.
Definition: buffer.c:514
int ssh_userauth_kbdint_getnanswers(ssh_session session)
Get the number of answers the client has given.
Definition: auth.c:1677
void ssh_set_blocking(ssh_session session, int blocking)
Set the session in blocking/nonblocking mode.
Definition: session.c:448
int ssh_channel_is_open(ssh_channel channel)
Check if the channel is open or not.
Definition: channels.c:1382
int ssh_event_add_connector(ssh_event event, ssh_connector connector)
Add a connector to the SSH event loop.
Definition: poll.c:864
enum ssh_keytypes_e ssh_key_type_from_name(const char *name)
Convert a ssh key name to a ssh key type.
Definition: pki.c:233
int ssh_write_knownhost(ssh_session session)
Write the current server as known in the known hosts file.
Definition: known_hosts.c:528
int ssh_channel_is_closed(ssh_channel channel)
Check if the channel is closed or not.
Definition: channels.c:1398
const char * ssh_userauth_kbdint_getanswer(ssh_session session, unsigned int i)
Get the answer for a question from a message block.
Definition: auth.c:1693
void ssh_key_free(ssh_key key)
deallocate a SSH key
Definition: pki.c:174
Only warnings.
Definition: libssh.h:307
Every function path.
Definition: libssh.h:316
ssh_session ssh_channel_get_session(ssh_channel channel)
Recover the session in which belongs a channel.
Definition: channels.c:2915
int ssh_channel_poll_timeout(ssh_channel channel, int timeout, int is_stderr)
Polls a channel for data to read, waiting for a certain timeout.
Definition: channels.c:2874
const char * ssh_pki_key_ecdsa_name(const ssh_key key)
returns the ECDSA key name ("ecdsa-sha2-nistp256" for example)
Definition: pki.c:92
ssh_scp ssh_scp_new(ssh_session session, int mode, const char *location)
Create a new scp session.
Definition: scp.c:60
ssh_buffer ssh_buffer_new(void)
Create a new SSH buffer.
Definition: buffer.c:86
const char * ssh_scp_request_get_filename(ssh_scp scp)
Get the name of the directory or file being pushed from the other party.
Definition: scp.c:754
int ssh_scp_write(ssh_scp scp, const void *buffer, size_t len)
Write into a remote scp file.
Definition: scp.c:437
ssh_event ssh_event_new(void)
Create a new event context.
Definition: poll.c:688
int ssh_channel_poll(ssh_channel channel, int is_stderr)
Polls a channel for data to read.
Definition: channels.c:2822
int ssh_is_connected(ssh_session session)
Check if we are connected.
Definition: session.c:512
int ssh_get_log_level(void)
Get the log level of the library.
Definition: log.c:196
int ssh_get_poll_flags(ssh_session session)
Get poll flags for an external mainloop.
Definition: session.c:752
int ssh_userauth_gssapi(ssh_session session)
Try to authenticate through the "gssapi-with-mic" method.
Definition: auth.c:1771
No logging at all.
Definition: libssh.h:304
ssh_channel ssh_channel_new(ssh_session session)
Allocate a new channel.
Definition: channels.c:79
int ssh_options_set(ssh_session session, enum ssh_options_e type, const void *value)
This function can set all possible ssh options.
Definition: options.c:417
int ssh_options_getopt(ssh_session session, int *argcptr, char **argv)
Parse command line arguments.
Definition: options.c:1073
const char * ssh_userauth_kbdint_getprompt(ssh_session session, unsigned int i, char *echo)
Get a prompt from a message block.
Definition: auth.c:1649
const char * ssh_userauth_kbdint_getname(ssh_session session)
Get the "name" of the message block.
Definition: auth.c:1591
const char * ssh_get_clientbanner(ssh_session session)
get the client banner
Definition: session.c:305
int ssh_event_remove_session(ssh_event event, ssh_session session)
Remove a session object from an event context.
Definition: poll.c:949
ssh_key ssh_key_new(void)
creates a new empty SSH key
Definition: pki.c:106
int ssh_get_server_publickey(ssh_session session, ssh_key *key)
Get the server public key from a session.
Definition: dh.c:1024
int ssh_userauth_password(ssh_session session, const char *username, const char *password)
Try to authenticate by password.
Definition: auth.c:1116
int ssh_userauth_publickey_auto(ssh_session session, const char *username, const char *passphrase)
Tries to automatically authenticate with public key and "none".
Definition: auth.c:895
int ssh_userauth_kbdint_setanswer(ssh_session session, unsigned int i, const char *answer)
Set the answer for a question from a message block.
Definition: auth.c:1724
int ssh_userauth_publickey(ssh_session session, const char *username, const ssh_key privkey)
Authenticate with public/private key or certificate.
Definition: auth.c:533
int ssh_pki_import_cert_base64(const char *b64_cert, enum ssh_keytypes_e type, ssh_key *pkey)
Import a base64 formated certificate from a memory c-string.
Definition: pki.c:1127
const char * ssh_get_cipher_out(ssh_session session)
get the name of the output cipher for the given session.
Definition: session.c:385
int ssh_select(ssh_channel *channels, ssh_channel *outchannels, socket_t maxfd, fd_set *readfds, struct timeval *timeout)
A wrapper for the select syscall.
Definition: connect.c:470
socket_t ssh_get_fd(ssh_session session)
Get the fd of a connection.
Definition: session.c:530
int ssh_channel_change_pty_size(ssh_channel channel, int cols, int rows)
Change the size of the terminal associated to a channel.
Definition: channels.c:1696
int ssh_connect(ssh_session session)
Connect to the ssh server.
Definition: client.c:488
enum ssh_keytypes_e ssh_key_type(const ssh_key key)
returns the type of a ssh key
Definition: pki.c:189
void ssh_disconnect(ssh_session session)
Disconnect from a session (client or server).
Definition: client.c:643
int ssh_userauth_none(ssh_session session, const char *username)
Try to authenticate through the "none" method.
Definition: auth.c:348
void ssh_string_free(struct ssh_string_struct *s)
Deallocate a SSH string object.
Definition: string.c:272
int ssh_channel_listen_forward(ssh_session session, const char *address, int port, int *bound_port)
Sends the "tcpip-forward" global request to ask the server to begin listening for inbound connections...
Definition: channels.c:2166
ssh_channel ssh_channel_accept_x11(ssh_channel channel, int timeout_ms)
Accept an X11 forwarding channel.
Definition: channels.c:1962
int ssh_mkdir(const char *pathname, mode_t mode)
Attempts to create a directory with the given pathname.
Definition: misc.c:632
int ssh_blocking_flush(ssh_session session, int timeout)
Blocking flush of the outgoing buffer.
Definition: session.c:487
int ssh_key_cmp(const ssh_key k1, const ssh_key k2, enum ssh_keycmp_e what)
Compare keys if they are equal.
Definition: pki.c:304
int ssh_channel_request_send_signal(ssh_channel channel, const char *signum)
Send a signal to remote process (as described in RFC 4254, section 6.9).
Definition: channels.c:2439
void ssh_set_fd_towrite(ssh_session session)
Tell the session it may write to the file descriptor without blocking.
Definition: session.c:557
void ssh_event_free(ssh_event event)
Free an event context.
Definition: poll.c:1016
High level protocol information.
Definition: libssh.h:310
char * ssh_dump_knownhost(ssh_session session)
Output the current server as a known host line.
Definition: known_hosts.c:453
ssh_channel ssh_channel_accept_forward(ssh_session session, int timeout_ms, int *destination_port)
Accept an incoming TCP/IP forwarding channel and get information about incomming connection.
Definition: channels.c:2229
void ssh_print_hexa(const char *descr, const unsigned char *what, size_t len)
Print a buffer as colon separated hex string.
Definition: dh.c:1226
const char * ssh_scp_request_get_warning(ssh_scp scp)
Get the warning string from a scp handle.
Definition: scp.c:829
int ssh_options_get_port(ssh_session session, unsigned int *port_target)
This function can get ssh the ssh port.
Definition: options.c:949
int ssh_pki_import_cert_file(const char *filename, ssh_key *pkey)
Import a certificate from the given filename.
Definition: pki.c:1166
int ssh_scp_request_get_permissions(ssh_scp scp)
Get the permissions of the directory or file being pushed from the other party.
Definition: scp.c:766
size_t ssh_scp_request_get_size(ssh_scp scp)
Get the size of the file being pushed from the other party.
Definition: scp.c:779
void * ssh_string_data(struct ssh_string_struct *s)
Get the payload of the string.
Definition: string.c:259
uint32_t ssh_buffer_get_data(struct ssh_buffer_struct *buffer, void *data, uint32_t len)
Get the remaining data out of the buffer and adjust the read pointer.
Definition: buffer.c:596
int ssh_channel_open_x11(ssh_channel channel, const char *orig_addr, int orig_port)
Open a X11 channel.
Definition: channels.c:3301
int ssh_scp_read(ssh_scp scp, void *buffer, size_t size)
Read from a remote scp file.
Definition: scp.c:703
char * ssh_basename(const char *path)
basename - parse filename component.
Definition: misc.c:581
int ssh_finalize(void)
Finalize and cleanup all libssh and cryptographic data structures.
Definition: init.c:221
void ssh_string_burn(struct ssh_string_struct *s)
Destroy the data in a string so it couldn&#39;t appear in a core dump.
Definition: string.c:244
int ssh_channel_request_exec(ssh_channel channel, const char *cmd)
Run a shell command without an interactive shell.
Definition: channels.c:2369
const char * ssh_get_hmac_out(ssh_session session)
get the name of the output HMAC algorithm for the given session.
Definition: session.c:416
int ssh_channel_request_pty(ssh_channel channel)
Request a PTY.
Definition: channels.c:1677
const char * ssh_get_serverbanner(ssh_session session)
get the server banner
Definition: session.c:320
void ssh_silent_disconnect(ssh_session session)
Disconnect impolitely from a remote host by closing the socket.
Definition: session.c:431
const char * ssh_get_disconnect_message(ssh_session session)
Get the disconnect message from the server.
Definition: session.c:772
size_t ssh_string_len(struct ssh_string_struct *s)
Return the size of a SSH string.
Definition: string.c:131
void ssh_channel_set_blocking(ssh_channel channel, int blocking)
Put the channel into blocking or nonblocking mode.
Definition: channels.c:1437
const char * ssh_get_kex_algo(ssh_session session)
get the name of the current key exchange algorithm.
Definition: session.c:334
void ssh_message_free(ssh_message msg)
Free a SSH message.
Definition: messages.c:548
int ssh_message_subtype(ssh_message msg)
Get the subtype of the message.
Definition: messages.c:524
ssh_session ssh_new(void)
Create a new ssh session.
Definition: session.c:58
int ssh_get_publickey(ssh_session session, ssh_key *key)
Definition: dh.c:1074
int ssh_get_status(ssh_session session)
Get session status.
Definition: session.c:714
void ssh_channel_set_counter(ssh_channel channel, ssh_counter counter)
Set the channel data counter.
Definition: channels.c:3188
void ssh_channel_free(ssh_channel channel)
Close and free a channel.
Definition: channels.c:979
int ssh_userauth_try_publickey(ssh_session session, const char *username, const ssh_key pubkey)
Try to authenticate with the given public key.
Definition: auth.c:430
int ssh_event_remove_fd(ssh_event event, socket_t fd)
Remove a socket fd from an event context.
Definition: poll.c:903
int ssh_scp_push_file64(ssh_scp scp, const char *filename, uint64_t size, int perms)
Initialize the sending of a file to a scp in sink mode, using a 64-bit size.
Definition: scp.c:317
int ssh_scp_pull_request(ssh_scp scp)
Wait for a scp request (file, directory).
Definition: scp.c:547
void ssh_string_free_char(char *s)
Deallocate a char string object.
Definition: string.c:204
int ssh_is_server_known(ssh_session session)
This function is depcrecated.
Definition: known_hosts.c:309
int ssh_send_ignore(ssh_session session, const char *data)
Send a message that should be ignored.
Definition: session.c:832
int ssh_is_blocking(ssh_session session)
Return the blocking mode of libssh.
Definition: session.c:462
char * ssh_get_hexa(const unsigned char *what, size_t len)
Convert a buffer into a colon separated hex string.
Definition: dh.c:1192
int ssh_get_publickey_hash(const ssh_key key, enum ssh_publickey_hash_type type, unsigned char **hash, size_t *hlen)
Allocates a buffer with the hash of the public key.
Definition: dh.c:1107
int ssh_channel_get_exit_status(ssh_channel channel)
Get the exit status of the channel (error code from the executed instruction).
Definition: channels.c:2951
int ssh_pki_import_pubkey_file(const char *filename, ssh_key *pkey)
Import a public key from the given filename.
Definition: pki.c:1026
int ssh_channel_cancel_forward(ssh_session session, const char *address, int port)
Sends the "cancel-tcpip-forward" global request to ask the server to cancel the tcpip-forward request...
Definition: channels.c:2248
int ssh_channel_request_auth_agent(ssh_channel channel)
Send an "auth-agent-req" channel request over an existing session channel.
Definition: channels.c:1977
int ssh_channel_write_stderr(ssh_channel channel, const void *data, uint32_t len)
Blocking write on a channel stderr.
Definition: channels.c:3208
int ssh_userauth_agent(ssh_session session, const char *username)
Try to do public key authentication with ssh agent.
Definition: auth.c:760
const char * ssh_get_hmac_in(ssh_session session)
get the name of the input HMAC algorithm for the given session.
Definition: session.c:401
int ssh_scp_push_file(ssh_scp scp, const char *filename, size_t size, int perms)
Initialize the sending of a file to a scp in sink mode.
Definition: scp.c:372
int ssh_pki_import_pubkey_base64(const char *b64_key, enum ssh_keytypes_e type, ssh_key *pkey)
Import a base64 formated public key from a memory c-string.
Definition: pki.c:910
int ssh_scp_push_directory(ssh_scp scp, const char *dirname, int mode)
Create a directory in a scp in sink mode.
Definition: scp.c:227
int ssh_channel_read(ssh_channel channel, void *dest, uint32_t count, int is_stderr)
Reads data from a channel.
Definition: channels.c:2632
int ssh_pki_import_privkey_base64(const char *b64_key, const char *passphrase, ssh_auth_callback auth_fn, void *auth_data, ssh_key *pkey)
import a base64 formated key from a memory c-string
Definition: pki.c:408
void ssh_free(ssh_session session)
Deallocate a SSH session handle.
Definition: session.c:170
int ssh_scp_close(ssh_scp scp)
Close the scp channel.
Definition: scp.c:161
int ssh_channel_read_nonblocking(ssh_channel channel, void *dest, uint32_t count, int is_stderr)
Do a nonblocking read on the channel.
Definition: channels.c:2770
int ssh_buffer_add_data(struct ssh_buffer_struct *buffer, const void *data, uint32_t len)
Add data at the tail of a buffer.
Definition: buffer.c:225
char * ssh_dirname(const char *path)
Parse directory component.
Definition: misc.c:526
int ssh_get_error_code(void *error)
Retrieve the error code from the last error.
Definition: error.c:133
int ssh_pki_import_privkey_file(const char *filename, const char *passphrase, ssh_auth_callback auth_fn, void *auth_data, ssh_key *pkey)
Import a key from a file.
Definition: pki.c:472