Annotation of src/usr.bin/ssh/packet.h, Revision 1.44
1.44 ! stevesk 1: /* $OpenBSD: packet.h,v 1.43 2005/07/25 11:59:40 markus Exp $ */
1.33 stevesk 2:
1.1 deraadt 3: /*
1.5 deraadt 4: * Author: Tatu Ylonen <ylo@cs.hut.fi>
5: * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
6: * All rights reserved
7: * Interface for the packet protocol functions.
1.15 markus 8: *
1.17 deraadt 9: * As far as I am concerned, the code I have written for this software
10: * can be used freely for any purpose. Any derived versions of this
11: * software must be clearly marked as such, and if the derived work is
12: * incompatible with the protocol description in the RFC file, it must be
13: * called by a name other than "ssh" or "Secure Shell".
1.5 deraadt 14: */
1.1 deraadt 15:
16: #ifndef PACKET_H
17: #define PACKET_H
1.44 ! stevesk 18:
! 19: #include <termios.h>
1.1 deraadt 20:
1.13 markus 21: #include <openssl/bn.h>
1.1 deraadt 22:
1.25 markus 23: void packet_set_connection(int, int);
24: void packet_set_nonblocking(void);
25: int packet_get_connection_in(void);
26: int packet_get_connection_out(void);
27: void packet_close(void);
28: void packet_set_encryption_key(const u_char *, u_int, int);
1.35 markus 29: u_int packet_get_encryption_key(u_char *);
1.25 markus 30: void packet_set_protocol_flags(u_int);
31: u_int packet_get_protocol_flags(void);
32: void packet_start_compression(int);
33: void packet_set_interactive(int);
34: int packet_is_interactive(void);
1.43 markus 35: void packet_set_server(void);
36: void packet_set_authenticated(void);
1.25 markus 37:
38: void packet_start(u_char);
39: void packet_put_char(int ch);
40: void packet_put_int(u_int value);
41: void packet_put_bignum(BIGNUM * value);
42: void packet_put_bignum2(BIGNUM * value);
1.27 stevesk 43: void packet_put_string(const void *buf, u_int len);
1.25 markus 44: void packet_put_cstring(const char *str);
1.27 stevesk 45: void packet_put_raw(const void *buf, u_int len);
1.25 markus 46: void packet_send(void);
47:
1.32 markus 48: int packet_read(void);
49: void packet_read_expect(int type);
50: int packet_read_poll(void);
1.25 markus 51: void packet_process_incoming(const char *buf, u_int len);
1.32 markus 52: int packet_read_seqnr(u_int32_t *seqnr_p);
53: int packet_read_poll_seqnr(u_int32_t *seqnr_p);
1.25 markus 54:
55: u_int packet_get_char(void);
56: u_int packet_get_int(void);
1.31 markus 57: void packet_get_bignum(BIGNUM * value);
58: void packet_get_bignum2(BIGNUM * value);
1.42 djm 59: void *packet_get_raw(u_int *length_ptr);
1.27 stevesk 60: void *packet_get_string(u_int *length_ptr);
1.25 markus 61: void packet_disconnect(const char *fmt,...) __attribute__((format(printf, 1, 2)));
62: void packet_send_debug(const char *fmt,...) __attribute__((format(printf, 1, 2)));
1.34 markus 63:
64: void set_newkeys(int mode);
65: int packet_get_keyiv_len(int);
66: void packet_get_keyiv(int, u_char *, u_int);
67: int packet_get_keycontext(int, u_char *);
68: void packet_set_keycontext(int, u_char *);
1.38 markus 69: void packet_get_state(int, u_int32_t *, u_int64_t *, u_int32_t *);
70: void packet_set_state(int, u_int32_t, u_int64_t, u_int32_t);
1.34 markus 71: int packet_get_ssh1_cipher(void);
72: void packet_set_iv(int, u_char *);
1.25 markus 73:
74: void packet_write_poll(void);
75: void packet_write_wait(void);
76: int packet_have_data_to_write(void);
77: int packet_not_very_much_data_to_write(void);
78:
79: int packet_connection_is_on_socket(void);
80: int packet_connection_is_ipv4(void);
81: int packet_remaining(void);
82: void packet_send_ignore(int);
1.26 markus 83: void packet_add_padding(u_char);
1.1 deraadt 84:
1.25 markus 85: void tty_make_modes(int, struct termios *);
86: void tty_parse_modes(int, int *);
1.1 deraadt 87:
1.40 markus 88: extern u_int max_packet_size;
1.41 deraadt 89: int packet_set_maxsize(u_int);
1.25 markus 90: #define packet_get_maxsize() max_packet_size
1.8 markus 91:
1.30 markus 92: /* don't allow remaining bytes after the end of the message */
93: #define packet_check_eom() \
1.14 markus 94: do { \
95: int _len = packet_remaining(); \
96: if (_len > 0) { \
1.39 itojun 97: logit("Packet integrity error (%d bytes remaining) at %s:%d", \
1.14 markus 98: _len ,__FILE__, __LINE__); \
99: packet_disconnect("Packet integrity error."); \
100: } \
101: } while (0)
1.38 markus 102:
103: int packet_need_rekeying(void);
104: void packet_set_rekey_limit(u_int32_t);
1.1 deraadt 105:
1.5 deraadt 106: #endif /* PACKET_H */