2 * Dropbear - a SSH2 server
4 * Copyright (c) 2002,2003 Matt Johnston
7 * Permission is hereby granted, free of charge, to any person obtaining a copy
8 * of this software and associated documentation files (the "Software"), to deal
9 * in the Software without restriction, including without limitation the rights
10 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11 * copies of the Software, and to permit persons to whom the Software is
12 * furnished to do so, subject to the following conditions:
14 * The above copyright notice and this permission notice shall be included in
15 * all copies or substantial portions of the Software.
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30 #include "circbuffer.h"
32 /* channel->type values */
33 #define CHANNEL_ID_NONE 0
34 #define CHANNEL_ID_SESSION 1
35 #define CHANNEL_ID_X11 2
36 #define CHANNEL_ID_AGENT 3
37 #define CHANNEL_ID_TCPDIRECT 4
38 #define CHANNEL_ID_TCPFORWARDED 5
40 #define SSH_OPEN_ADMINISTRATIVELY_PROHIBITED 1
41 #define SSH_OPEN_CONNECT_FAILED 2
42 #define SSH_OPEN_UNKNOWN_CHANNEL_TYPE 3
43 #define SSH_OPEN_RESOURCE_SHORTAGE 4
46 #define SSH_OPEN_IN_PROGRESS 99
48 #define CHAN_EXTEND_SIZE 3 /* how many extra slots to add when we need more */
54 unsigned int index
; /* the local channel index */
55 unsigned int remotechan
;
56 unsigned int recvwindow
, transwindow
;
57 unsigned int recvdonelen
;
58 unsigned int recvmaxpacket
, transmaxpacket
;
59 void* typedata
; /* a pointer to type specific data */
60 int writefd
; /* read from wire, written to insecure side */
61 int readfd
; /* read from insecure side, written to wire */
62 int errfd
; /* used like writefd or readfd, depending if it's client or server.
63 Doesn't exactly belong here, but is cleaner here */
64 circbuffer
*writebuf
; /* data from the wire, for local consumption */
65 circbuffer
*extrabuf
; /* extended-data for the program - used like writebuf
68 /* whether close/eof messages have been exchanged */
69 int sent_close
, recv_close
;
70 int recv_eof
, sent_eof
;
72 /* Set after running the ChanType-specific close hander
73 * to ensure we don't run it twice (nor type->checkclose()). */
74 int close_handler_done
;
76 int initconn
; /* used for TCP forwarding, whether the channel has been
79 int await_open
; /* flag indicating whether we've sent an open request
80 for this channel (and are awaiting a confirmation
85 const struct ChanType
* type
;
91 int sepfds
; /* Whether this channel has seperate pipes for in/out or not */
93 int (*inithandler
)(struct Channel
*);
94 int (*check_close
)(struct Channel
*);
95 void (*reqhandler
)(struct Channel
*);
96 void (*closehandler
)(struct Channel
*);
100 void chaninitialise(const struct ChanType
*chantypes
[]);
102 void setchannelfds(fd_set
*readfd
, fd_set
*writefd
);
103 void channelio(fd_set
*readfd
, fd_set
*writefd
);
104 struct Channel
* getchannel();
105 struct Channel
* newchannel(unsigned int remotechan
,
106 const struct ChanType
*type
,
107 unsigned int transwindow
, unsigned int transmaxpacket
);
109 void recv_msg_channel_open();
110 void recv_msg_channel_request();
111 void send_msg_channel_failure(struct Channel
*channel
);
112 void send_msg_channel_success(struct Channel
*channel
);
113 void recv_msg_channel_data();
114 void recv_msg_channel_extended_data();
115 void recv_msg_channel_window_adjust();
116 void recv_msg_channel_close();
117 void recv_msg_channel_eof();
119 void common_recv_msg_channel_data(struct Channel
*channel
, int fd
,
122 #ifdef DROPBEAR_CLIENT
123 extern const struct ChanType clichansess
;
126 #if defined(USING_LISTENERS) || defined(DROPBEAR_CLIENT)
127 int send_msg_channel_open_init(int fd
, const struct ChanType
*type
);
128 void recv_msg_channel_open_confirmation();
129 void recv_msg_channel_open_failure();
132 #endif /* _CHANNEL_H_ */