mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Fix compilation with NO_GSSAPI.
This is a fairly shallow patch, which removes the UI and interactions with external libraries. Some other machinery (which is dead code in this configuration) is left in place. Adapted by me from a patch by Jeroen Roovers.
This commit is contained in:
parent
fe408562fa
commit
7ad08649a2
4
config.c
4
config.c
@ -2442,10 +2442,12 @@ void setup_config_box(struct controlbox *b, bool midsession,
|
|||||||
HELPCTX(ssh_kexlist),
|
HELPCTX(ssh_kexlist),
|
||||||
kexlist_handler, P(NULL));
|
kexlist_handler, P(NULL));
|
||||||
c->listbox.height = KEX_MAX;
|
c->listbox.height = KEX_MAX;
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
ctrl_checkbox(s, "Attempt GSSAPI key exchange",
|
ctrl_checkbox(s, "Attempt GSSAPI key exchange",
|
||||||
'k', HELPCTX(ssh_gssapi),
|
'k', HELPCTX(ssh_gssapi),
|
||||||
conf_checkbox_handler,
|
conf_checkbox_handler,
|
||||||
I(CONF_try_gssapi_kex));
|
I(CONF_try_gssapi_kex));
|
||||||
|
#endif
|
||||||
|
|
||||||
s = ctrl_getset(b, "Connection/SSH/Kex", "repeat",
|
s = ctrl_getset(b, "Connection/SSH/Kex", "repeat",
|
||||||
"Options controlling key re-exchange");
|
"Options controlling key re-exchange");
|
||||||
@ -2455,11 +2457,13 @@ void setup_config_box(struct controlbox *b, bool midsession,
|
|||||||
conf_editbox_handler,
|
conf_editbox_handler,
|
||||||
I(CONF_ssh_rekey_time),
|
I(CONF_ssh_rekey_time),
|
||||||
I(-1));
|
I(-1));
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
ctrl_editbox(s, "Minutes between GSS checks (0 for never)", NO_SHORTCUT, 20,
|
ctrl_editbox(s, "Minutes between GSS checks (0 for never)", NO_SHORTCUT, 20,
|
||||||
HELPCTX(ssh_kex_repeat),
|
HELPCTX(ssh_kex_repeat),
|
||||||
conf_editbox_handler,
|
conf_editbox_handler,
|
||||||
I(CONF_gssapirekey),
|
I(CONF_gssapirekey),
|
||||||
I(-1));
|
I(-1));
|
||||||
|
#endif
|
||||||
ctrl_editbox(s, "Max data before rekey (0 for no limit)", 'x', 20,
|
ctrl_editbox(s, "Max data before rekey (0 for no limit)", 'x', 20,
|
||||||
HELPCTX(ssh_kex_repeat),
|
HELPCTX(ssh_kex_repeat),
|
||||||
conf_editbox_handler,
|
conf_editbox_handler,
|
||||||
|
12
settings.c
12
settings.c
@ -592,21 +592,25 @@ void save_open_settings(settings_w *sesskey, Conf *conf)
|
|||||||
write_setting_b(sesskey, "Compression", conf_get_bool(conf, CONF_compression));
|
write_setting_b(sesskey, "Compression", conf_get_bool(conf, CONF_compression));
|
||||||
write_setting_b(sesskey, "TryAgent", conf_get_bool(conf, CONF_tryagent));
|
write_setting_b(sesskey, "TryAgent", conf_get_bool(conf, CONF_tryagent));
|
||||||
write_setting_b(sesskey, "AgentFwd", conf_get_bool(conf, CONF_agentfwd));
|
write_setting_b(sesskey, "AgentFwd", conf_get_bool(conf, CONF_agentfwd));
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
write_setting_b(sesskey, "GssapiFwd", conf_get_bool(conf, CONF_gssapifwd));
|
write_setting_b(sesskey, "GssapiFwd", conf_get_bool(conf, CONF_gssapifwd));
|
||||||
|
#endif
|
||||||
write_setting_b(sesskey, "ChangeUsername", conf_get_bool(conf, CONF_change_username));
|
write_setting_b(sesskey, "ChangeUsername", conf_get_bool(conf, CONF_change_username));
|
||||||
wprefs(sesskey, "Cipher", ciphernames, CIPHER_MAX, conf, CONF_ssh_cipherlist);
|
wprefs(sesskey, "Cipher", ciphernames, CIPHER_MAX, conf, CONF_ssh_cipherlist);
|
||||||
wprefs(sesskey, "KEX", kexnames, KEX_MAX, conf, CONF_ssh_kexlist);
|
wprefs(sesskey, "KEX", kexnames, KEX_MAX, conf, CONF_ssh_kexlist);
|
||||||
wprefs(sesskey, "HostKey", hknames, HK_MAX, conf, CONF_ssh_hklist);
|
wprefs(sesskey, "HostKey", hknames, HK_MAX, conf, CONF_ssh_hklist);
|
||||||
write_setting_i(sesskey, "RekeyTime", conf_get_int(conf, CONF_ssh_rekey_time));
|
write_setting_i(sesskey, "RekeyTime", conf_get_int(conf, CONF_ssh_rekey_time));
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
write_setting_i(sesskey, "GssapiRekey", conf_get_int(conf, CONF_gssapirekey));
|
write_setting_i(sesskey, "GssapiRekey", conf_get_int(conf, CONF_gssapirekey));
|
||||||
|
#endif
|
||||||
write_setting_s(sesskey, "RekeyBytes", conf_get_str(conf, CONF_ssh_rekey_data));
|
write_setting_s(sesskey, "RekeyBytes", conf_get_str(conf, CONF_ssh_rekey_data));
|
||||||
write_setting_b(sesskey, "SshNoAuth", conf_get_bool(conf, CONF_ssh_no_userauth));
|
write_setting_b(sesskey, "SshNoAuth", conf_get_bool(conf, CONF_ssh_no_userauth));
|
||||||
write_setting_b(sesskey, "SshBanner", conf_get_bool(conf, CONF_ssh_show_banner));
|
write_setting_b(sesskey, "SshBanner", conf_get_bool(conf, CONF_ssh_show_banner));
|
||||||
write_setting_b(sesskey, "AuthTIS", conf_get_bool(conf, CONF_try_tis_auth));
|
write_setting_b(sesskey, "AuthTIS", conf_get_bool(conf, CONF_try_tis_auth));
|
||||||
write_setting_b(sesskey, "AuthKI", conf_get_bool(conf, CONF_try_ki_auth));
|
write_setting_b(sesskey, "AuthKI", conf_get_bool(conf, CONF_try_ki_auth));
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
write_setting_b(sesskey, "AuthGSSAPI", conf_get_bool(conf, CONF_try_gssapi_auth));
|
write_setting_b(sesskey, "AuthGSSAPI", conf_get_bool(conf, CONF_try_gssapi_auth));
|
||||||
write_setting_b(sesskey, "AuthGSSAPIKEX", conf_get_bool(conf, CONF_try_gssapi_kex));
|
write_setting_b(sesskey, "AuthGSSAPIKEX", conf_get_bool(conf, CONF_try_gssapi_kex));
|
||||||
#ifndef NO_GSSAPI
|
|
||||||
wprefs(sesskey, "GSSLibs", gsslibkeywords, ngsslibs, conf, CONF_ssh_gsslist);
|
wprefs(sesskey, "GSSLibs", gsslibkeywords, ngsslibs, conf, CONF_ssh_gsslist);
|
||||||
write_setting_filename(sesskey, "GSSCustom", conf_get_filename(conf, CONF_ssh_gss_custom));
|
write_setting_filename(sesskey, "GSSCustom", conf_get_filename(conf, CONF_ssh_gss_custom));
|
||||||
#endif
|
#endif
|
||||||
@ -937,7 +941,9 @@ void load_open_settings(settings_r *sesskey, Conf *conf)
|
|||||||
gppb(sesskey, "TryAgent", true, conf, CONF_tryagent);
|
gppb(sesskey, "TryAgent", true, conf, CONF_tryagent);
|
||||||
gppb(sesskey, "AgentFwd", false, conf, CONF_agentfwd);
|
gppb(sesskey, "AgentFwd", false, conf, CONF_agentfwd);
|
||||||
gppb(sesskey, "ChangeUsername", false, conf, CONF_change_username);
|
gppb(sesskey, "ChangeUsername", false, conf, CONF_change_username);
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
gppb(sesskey, "GssapiFwd", false, conf, CONF_gssapifwd);
|
gppb(sesskey, "GssapiFwd", false, conf, CONF_gssapifwd);
|
||||||
|
#endif
|
||||||
gprefs(sesskey, "Cipher", "\0",
|
gprefs(sesskey, "Cipher", "\0",
|
||||||
ciphernames, CIPHER_MAX, conf, CONF_ssh_cipherlist);
|
ciphernames, CIPHER_MAX, conf, CONF_ssh_cipherlist);
|
||||||
{
|
{
|
||||||
@ -990,7 +996,9 @@ void load_open_settings(settings_r *sesskey, Conf *conf)
|
|||||||
gprefs(sesskey, "HostKey", "ed25519,ecdsa,rsa,dsa,WARN",
|
gprefs(sesskey, "HostKey", "ed25519,ecdsa,rsa,dsa,WARN",
|
||||||
hknames, HK_MAX, conf, CONF_ssh_hklist);
|
hknames, HK_MAX, conf, CONF_ssh_hklist);
|
||||||
gppi(sesskey, "RekeyTime", 60, conf, CONF_ssh_rekey_time);
|
gppi(sesskey, "RekeyTime", 60, conf, CONF_ssh_rekey_time);
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
gppi(sesskey, "GssapiRekey", GSS_DEF_REKEY_MINS, conf, CONF_gssapirekey);
|
gppi(sesskey, "GssapiRekey", GSS_DEF_REKEY_MINS, conf, CONF_gssapirekey);
|
||||||
|
#endif
|
||||||
gpps(sesskey, "RekeyBytes", "1G", conf, CONF_ssh_rekey_data);
|
gpps(sesskey, "RekeyBytes", "1G", conf, CONF_ssh_rekey_data);
|
||||||
{
|
{
|
||||||
/* SSH-2 only by default */
|
/* SSH-2 only by default */
|
||||||
@ -1007,9 +1015,9 @@ void load_open_settings(settings_r *sesskey, Conf *conf)
|
|||||||
gppb(sesskey, "SshBanner", true, conf, CONF_ssh_show_banner);
|
gppb(sesskey, "SshBanner", true, conf, CONF_ssh_show_banner);
|
||||||
gppb(sesskey, "AuthTIS", false, conf, CONF_try_tis_auth);
|
gppb(sesskey, "AuthTIS", false, conf, CONF_try_tis_auth);
|
||||||
gppb(sesskey, "AuthKI", true, conf, CONF_try_ki_auth);
|
gppb(sesskey, "AuthKI", true, conf, CONF_try_ki_auth);
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
gppb(sesskey, "AuthGSSAPI", true, conf, CONF_try_gssapi_auth);
|
gppb(sesskey, "AuthGSSAPI", true, conf, CONF_try_gssapi_auth);
|
||||||
gppb(sesskey, "AuthGSSAPIKEX", true, conf, CONF_try_gssapi_kex);
|
gppb(sesskey, "AuthGSSAPIKEX", true, conf, CONF_try_gssapi_kex);
|
||||||
#ifndef NO_GSSAPI
|
|
||||||
gprefs(sesskey, "GSSLibs", "\0",
|
gprefs(sesskey, "GSSLibs", "\0",
|
||||||
gsslibkeywords, ngsslibs, conf, CONF_ssh_gsslist);
|
gsslibkeywords, ngsslibs, conf, CONF_ssh_gsslist);
|
||||||
gppfile(sesskey, "GSSCustom", conf, CONF_ssh_gss_custom);
|
gppfile(sesskey, "GSSCustom", conf, CONF_ssh_gss_custom);
|
||||||
|
16
ssh.c
16
ssh.c
@ -50,7 +50,9 @@ struct Ssh {
|
|||||||
ssh_sharing_state *connshare;
|
ssh_sharing_state *connshare;
|
||||||
bool attempting_connshare;
|
bool attempting_connshare;
|
||||||
|
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
struct ssh_connection_shared_gss_state gss_state;
|
struct ssh_connection_shared_gss_state gss_state;
|
||||||
|
#endif
|
||||||
|
|
||||||
char *savedhost;
|
char *savedhost;
|
||||||
int savedport;
|
int savedport;
|
||||||
@ -252,10 +254,18 @@ static void ssh_got_ssh_version(struct ssh_version_receiver *rcv,
|
|||||||
conf_get_bool(ssh->conf, CONF_tryagent), username,
|
conf_get_bool(ssh->conf, CONF_tryagent), username,
|
||||||
conf_get_bool(ssh->conf, CONF_change_username),
|
conf_get_bool(ssh->conf, CONF_change_username),
|
||||||
conf_get_bool(ssh->conf, CONF_try_ki_auth),
|
conf_get_bool(ssh->conf, CONF_try_ki_auth),
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
conf_get_bool(ssh->conf, CONF_try_gssapi_auth),
|
conf_get_bool(ssh->conf, CONF_try_gssapi_auth),
|
||||||
conf_get_bool(ssh->conf, CONF_try_gssapi_kex),
|
conf_get_bool(ssh->conf, CONF_try_gssapi_kex),
|
||||||
conf_get_bool(ssh->conf, CONF_gssapifwd),
|
conf_get_bool(ssh->conf, CONF_gssapifwd),
|
||||||
&ssh->gss_state);
|
&ssh->gss_state
|
||||||
|
#else
|
||||||
|
false,
|
||||||
|
false,
|
||||||
|
false,
|
||||||
|
NULL
|
||||||
|
#endif
|
||||||
|
);
|
||||||
ssh_connect_ppl(ssh, userauth_layer);
|
ssh_connect_ppl(ssh, userauth_layer);
|
||||||
transport_child_layer = userauth_layer;
|
transport_child_layer = userauth_layer;
|
||||||
|
|
||||||
@ -267,7 +277,11 @@ static void ssh_got_ssh_version(struct ssh_version_receiver *rcv,
|
|||||||
ssh->fullhostname,
|
ssh->fullhostname,
|
||||||
ssh_verstring_get_local(old_bpp),
|
ssh_verstring_get_local(old_bpp),
|
||||||
ssh_verstring_get_remote(old_bpp),
|
ssh_verstring_get_remote(old_bpp),
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
&ssh->gss_state,
|
&ssh->gss_state,
|
||||||
|
#else
|
||||||
|
NULL,
|
||||||
|
#endif
|
||||||
&ssh->stats, transport_child_layer, false);
|
&ssh->stats, transport_child_layer, false);
|
||||||
ssh_connect_ppl(ssh, ssh->base_layer);
|
ssh_connect_ppl(ssh, ssh->base_layer);
|
||||||
|
|
||||||
|
@ -1781,6 +1781,7 @@ static void ssh2_transport_gss_update(struct ssh2_transport_state *s,
|
|||||||
if (mins > 0 && s->gss_ctxt_lifetime <= mins * 60)
|
if (mins > 0 && s->gss_ctxt_lifetime <= mins * 60)
|
||||||
s->gss_status |= GSS_CTXT_EXPIRES;
|
s->gss_status |= GSS_CTXT_EXPIRES;
|
||||||
}
|
}
|
||||||
|
#endif /* NO_GSSAPI */
|
||||||
|
|
||||||
ptrlen ssh2_transport_get_session_id(PacketProtocolLayer *ppl)
|
ptrlen ssh2_transport_get_session_id(PacketProtocolLayer *ppl)
|
||||||
{
|
{
|
||||||
@ -1805,8 +1806,6 @@ void ssh2_transport_notify_auth_done(PacketProtocolLayer *ppl)
|
|||||||
queue_idempotent_callback(&s->ppl.ic_process_queue);
|
queue_idempotent_callback(&s->ppl.ic_process_queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* NO_GSSAPI */
|
|
||||||
|
|
||||||
static bool ssh2_transport_get_specials(
|
static bool ssh2_transport_get_specials(
|
||||||
PacketProtocolLayer *ppl, add_special_fn_t add_special, void *ctx)
|
PacketProtocolLayer *ppl, add_special_fn_t add_special, void *ctx)
|
||||||
{
|
{
|
||||||
|
@ -613,8 +613,10 @@ static void ssh2_userauth_process_queue(PacketProtocolLayer *ppl)
|
|||||||
* Scan it for method identifiers we know about.
|
* Scan it for method identifiers we know about.
|
||||||
*/
|
*/
|
||||||
bool srv_pubkey = false, srv_passwd = false;
|
bool srv_pubkey = false, srv_passwd = false;
|
||||||
bool srv_keyb_inter = false, srv_gssapi = false;
|
bool srv_keyb_inter = false;
|
||||||
bool srv_gssapi_keyex_auth = false;
|
#ifndef NO_GSSAPI
|
||||||
|
bool srv_gssapi = false, srv_gssapi_keyex_auth = false;
|
||||||
|
#endif
|
||||||
|
|
||||||
for (ptrlen method; get_commasep_word(&methods, &method) ;) {
|
for (ptrlen method; get_commasep_word(&methods, &method) ;) {
|
||||||
if (ptrlen_eq_string(method, "publickey"))
|
if (ptrlen_eq_string(method, "publickey"))
|
||||||
@ -623,10 +625,12 @@ static void ssh2_userauth_process_queue(PacketProtocolLayer *ppl)
|
|||||||
srv_passwd = true;
|
srv_passwd = true;
|
||||||
else if (ptrlen_eq_string(method, "keyboard-interactive"))
|
else if (ptrlen_eq_string(method, "keyboard-interactive"))
|
||||||
srv_keyb_inter = true;
|
srv_keyb_inter = true;
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
else if (ptrlen_eq_string(method, "gssapi-with-mic"))
|
else if (ptrlen_eq_string(method, "gssapi-with-mic"))
|
||||||
srv_gssapi = true;
|
srv_gssapi = true;
|
||||||
else if (ptrlen_eq_string(method, "gssapi-keyex"))
|
else if (ptrlen_eq_string(method, "gssapi-keyex"))
|
||||||
srv_gssapi_keyex_auth = true;
|
srv_gssapi_keyex_auth = true;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
13
sshserver.c
13
sshserver.c
@ -50,7 +50,9 @@ struct server {
|
|||||||
PacketProtocolLayer *base_layer;
|
PacketProtocolLayer *base_layer;
|
||||||
ConnectionLayer *cl;
|
ConnectionLayer *cl;
|
||||||
|
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
struct ssh_connection_shared_gss_state gss_state;
|
struct ssh_connection_shared_gss_state gss_state;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
static void ssh_server_free_callback(void *vsrv);
|
static void ssh_server_free_callback(void *vsrv);
|
||||||
@ -245,9 +247,11 @@ Plug *ssh_server_plug(
|
|||||||
bufchain_init(&srv->out_raw);
|
bufchain_init(&srv->out_raw);
|
||||||
bufchain_init(&srv->dummy_user_input);
|
bufchain_init(&srv->dummy_user_input);
|
||||||
|
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
/* FIXME: replace with sensible */
|
/* FIXME: replace with sensible */
|
||||||
srv->gss_state.libs = snew(struct ssh_gss_liblist);
|
srv->gss_state.libs = snew(struct ssh_gss_liblist);
|
||||||
srv->gss_state.libs->nlibraries = 0;
|
srv->gss_state.libs->nlibraries = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
return &srv->plug;
|
return &srv->plug;
|
||||||
}
|
}
|
||||||
@ -297,7 +301,9 @@ static void ssh_server_free_callback(void *vsrv)
|
|||||||
conf_free(srv->conf);
|
conf_free(srv->conf);
|
||||||
log_free(srv->logctx);
|
log_free(srv->logctx);
|
||||||
|
|
||||||
|
#ifndef NO_GSSAPI
|
||||||
sfree(srv->gss_state.libs); /* FIXME: replace with sensible */
|
sfree(srv->gss_state.libs); /* FIXME: replace with sensible */
|
||||||
|
#endif
|
||||||
|
|
||||||
sfree(srv);
|
sfree(srv);
|
||||||
|
|
||||||
@ -442,7 +448,12 @@ static void server_got_ssh_version(struct ssh_version_receiver *rcv,
|
|||||||
srv->conf, NULL, 0, NULL,
|
srv->conf, NULL, 0, NULL,
|
||||||
ssh_verstring_get_remote(old_bpp),
|
ssh_verstring_get_remote(old_bpp),
|
||||||
ssh_verstring_get_local(old_bpp),
|
ssh_verstring_get_local(old_bpp),
|
||||||
&srv->gss_state, &srv->stats, transport_child_layer, true);
|
#ifndef NO_GSSAPI
|
||||||
|
&srv->gss_state,
|
||||||
|
#else
|
||||||
|
NULL,
|
||||||
|
#endif
|
||||||
|
&srv->stats, transport_child_layer, true);
|
||||||
ssh2_transport_provide_hostkeys(
|
ssh2_transport_provide_hostkeys(
|
||||||
srv->base_layer, srv->hostkeys, srv->nhostkeys);
|
srv->base_layer, srv->hostkeys, srv->nhostkeys);
|
||||||
if (userauth_layer)
|
if (userauth_layer)
|
||||||
|
Loading…
Reference in New Issue
Block a user