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
34 typedef struct runopts
{
36 #if defined(ENABLE_SVR_REMOTETCPFWD) || defined(ENABLE_CLI_LOCALTCPFWD)
39 unsigned int recv_window
;
40 time_t keepalive_secs
;
41 time_t idle_timeout_secs
;
44 /* TODO: add a commandline flag. Currently this is on by default if compression
45 * is compiled in, but disabled for a client's non-final multihop stages. (The
46 * intermediate stages are compressed streams, so are uncompressible. */
50 #ifdef ENABLE_USER_ALGO_LIST
59 int readhostkey(const char * filename
, sign_key
* hostkey
, int *type
);
61 typedef struct svr_runopts
{
70 /* ports is an array of the portcount listening ports */
71 char *ports
[DROPBEAR_MAX_PORTS
];
72 unsigned int portcount
;
73 char *addresses
[DROPBEAR_MAX_PORTS
];
77 /* Flags indicating whether to use ipv4 and ipv6 */
84 /* whether to print the MOTD */
94 #ifdef ENABLE_SVR_REMOTETCPFWD
97 #ifdef ENABLE_SVR_LOCALTCPFWD
107 extern svr_runopts svr_opts
;
109 void svr_getopts(int argc
, char ** argv
);
112 typedef struct cli_runopts
{
123 int always_accept_key
;
124 int no_hostkey_check
;
128 #ifdef ENABLE_CLI_PUBKEY_AUTH
129 m_list
*privkeys
; /* Keys to use for public-key auth */
131 #ifdef ENABLE_CLI_REMOTETCPFWD
134 #ifdef ENABLE_CLI_LOCALTCPFWD
137 #ifdef ENABLE_CLI_AGENTFWD
139 int agent_keys_loaded
; /* whether pubkeys has been populated with a
140 list of keys held by the agent */
141 int agent_fd
; /* The agent fd is only set during authentication. Forwarded
142 agent sessions have their own file descriptors */
145 #ifdef ENABLE_CLI_NETCAT
147 unsigned int netcat_port
;
149 #ifdef ENABLE_CLI_PROXYCMD
154 extern cli_runopts cli_opts
;
155 void cli_getopts(int argc
, char ** argv
);
157 #ifdef ENABLE_USER_ALGO_LIST
158 void parse_ciphers_macs();
161 #endif /* _RUNOPTS_H_ */