mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Fix another giant batch of resource leaks. (Mostly memory, but there's
one missing fclose too.) [originally from svn r9919]
This commit is contained in:
parent
896bb7c74d
commit
ea301bdd9b
24
import.c
24
import.c
@ -370,8 +370,10 @@ static struct openssh_key *load_openssh_key(const Filename *filename,
|
|||||||
}
|
}
|
||||||
strip_crlf(line);
|
strip_crlf(line);
|
||||||
if (0 == strncmp(line, "-----END ", 9) &&
|
if (0 == strncmp(line, "-----END ", 9) &&
|
||||||
0 == strcmp(line+strlen(line)-16, "PRIVATE KEY-----"))
|
0 == strcmp(line+strlen(line)-16, "PRIVATE KEY-----")) {
|
||||||
|
sfree(line);
|
||||||
break; /* done */
|
break; /* done */
|
||||||
|
}
|
||||||
if ((p = strchr(line, ':')) != NULL) {
|
if ((p = strchr(line, ':')) != NULL) {
|
||||||
if (headers_done) {
|
if (headers_done) {
|
||||||
errmsg = "header found in body of key data";
|
errmsg = "header found in body of key data";
|
||||||
@ -1091,8 +1093,10 @@ static struct sshcom_key *load_sshcom_key(const Filename *filename,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
strip_crlf(line);
|
strip_crlf(line);
|
||||||
if (!strcmp(line, "---- END SSH2 ENCRYPTED PRIVATE KEY ----"))
|
if (!strcmp(line, "---- END SSH2 ENCRYPTED PRIVATE KEY ----")) {
|
||||||
|
sfree(line);
|
||||||
break; /* done */
|
break; /* done */
|
||||||
|
}
|
||||||
if ((p = strchr(line, ':')) != NULL) {
|
if ((p = strchr(line, ':')) != NULL) {
|
||||||
if (headers_done) {
|
if (headers_done) {
|
||||||
errmsg = "header found in body of key data";
|
errmsg = "header found in body of key data";
|
||||||
@ -1181,10 +1185,14 @@ static struct sshcom_key *load_sshcom_key(const Filename *filename,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fclose(fp);
|
||||||
if (errmsg_p) *errmsg_p = NULL;
|
if (errmsg_p) *errmsg_p = NULL;
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
|
if (fp)
|
||||||
|
fclose(fp);
|
||||||
|
|
||||||
if (line) {
|
if (line) {
|
||||||
smemclr(line, strlen(line));
|
smemclr(line, strlen(line));
|
||||||
sfree(line);
|
sfree(line);
|
||||||
@ -1207,20 +1215,22 @@ int sshcom_encrypted(const Filename *filename, char **comment)
|
|||||||
struct sshcom_key *key = load_sshcom_key(filename, NULL);
|
struct sshcom_key *key = load_sshcom_key(filename, NULL);
|
||||||
int pos, len, answer;
|
int pos, len, answer;
|
||||||
|
|
||||||
|
answer = 0;
|
||||||
|
|
||||||
*comment = NULL;
|
*comment = NULL;
|
||||||
if (!key)
|
if (!key)
|
||||||
return 0;
|
goto done;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check magic number.
|
* Check magic number.
|
||||||
*/
|
*/
|
||||||
if (GET_32BIT(key->keyblob) != 0x3f6ff9eb)
|
if (GET_32BIT(key->keyblob) != 0x3f6ff9eb) {
|
||||||
return 0; /* key is invalid */
|
goto done; /* key is invalid */
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Find the cipher-type string.
|
* Find the cipher-type string.
|
||||||
*/
|
*/
|
||||||
answer = 0;
|
|
||||||
pos = 8;
|
pos = 8;
|
||||||
if (key->keyblob_len < pos+4)
|
if (key->keyblob_len < pos+4)
|
||||||
goto done; /* key is far too short */
|
goto done; /* key is far too short */
|
||||||
@ -1235,7 +1245,7 @@ int sshcom_encrypted(const Filename *filename, char **comment)
|
|||||||
answer = 1;
|
answer = 1;
|
||||||
|
|
||||||
done:
|
done:
|
||||||
*comment = dupstr(key->comment);
|
*comment = dupstr(key ? key->comment : "");
|
||||||
smemclr(key->keyblob, key->keyblob_size);
|
smemclr(key->keyblob, key->keyblob_size);
|
||||||
sfree(key->keyblob);
|
sfree(key->keyblob);
|
||||||
smemclr(key, sizeof(*key));
|
smemclr(key, sizeof(*key));
|
||||||
|
@ -386,6 +386,7 @@ const char *pfd_newconnect(Socket *s, char *hostname, int port,
|
|||||||
|
|
||||||
pr->s = *s = new_connection(addr, dummy_realhost, port,
|
pr->s = *s = new_connection(addr, dummy_realhost, port,
|
||||||
0, 1, 0, 0, (Plug) pr, conf);
|
0, 1, 0, 0, (Plug) pr, conf);
|
||||||
|
sfree(dummy_realhost);
|
||||||
if ((err = sk_socket_error(*s)) != NULL) {
|
if ((err = sk_socket_error(*s)) != NULL) {
|
||||||
free_portfwd_private(pr);
|
free_portfwd_private(pr);
|
||||||
return err;
|
return err;
|
||||||
|
1
proxy.c
1
proxy.c
@ -473,6 +473,7 @@ Socket new_connection(SockAddr addr, char *hostname,
|
|||||||
conf_get_int(conf, CONF_addressfamily));
|
conf_get_int(conf, CONF_addressfamily));
|
||||||
if (sk_addr_error(proxy_addr) != NULL) {
|
if (sk_addr_error(proxy_addr) != NULL) {
|
||||||
ret->error = "Proxy error: Unable to resolve proxy host name";
|
ret->error = "Proxy error: Unable to resolve proxy host name";
|
||||||
|
sfree(pplug);
|
||||||
return (Socket)ret;
|
return (Socket)ret;
|
||||||
}
|
}
|
||||||
sfree(proxy_canonical_name);
|
sfree(proxy_canonical_name);
|
||||||
|
11
pscp.c
11
pscp.c
@ -1118,6 +1118,9 @@ int scp_sink_setup(char *source, int preserve, int recursive)
|
|||||||
if (!wc_unescape(newsource, source)) {
|
if (!wc_unescape(newsource, source)) {
|
||||||
/* Yes, here we go; it's a wildcard. Bah. */
|
/* Yes, here we go; it's a wildcard. Bah. */
|
||||||
char *dupsource, *lastpart, *dirpart, *wildcard;
|
char *dupsource, *lastpart, *dirpart, *wildcard;
|
||||||
|
|
||||||
|
sfree(newsource);
|
||||||
|
|
||||||
dupsource = dupstr(source);
|
dupsource = dupstr(source);
|
||||||
lastpart = stripslashes(dupsource, 0);
|
lastpart = stripslashes(dupsource, 0);
|
||||||
wildcard = dupstr(lastpart);
|
wildcard = dupstr(lastpart);
|
||||||
@ -1722,17 +1725,21 @@ static void source(char *src)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (preserve) {
|
if (preserve) {
|
||||||
if (scp_send_filetimes(mtime, atime))
|
if (scp_send_filetimes(mtime, atime)) {
|
||||||
|
close_rfile(f);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
char sizestr[40];
|
char sizestr[40];
|
||||||
uint64_decimal(size, sizestr);
|
uint64_decimal(size, sizestr);
|
||||||
tell_user(stderr, "Sending file %s, size=%s", last, sizestr);
|
tell_user(stderr, "Sending file %s, size=%s", last, sizestr);
|
||||||
}
|
}
|
||||||
if (scp_send_filename(last, size, permissions))
|
if (scp_send_filename(last, size, permissions)) {
|
||||||
|
close_rfile(f);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
stat_bytes = uint64_make(0,0);
|
stat_bytes = uint64_make(0,0);
|
||||||
stat_starttime = time(NULL);
|
stat_starttime = time(NULL);
|
||||||
|
2
psftp.c
2
psftp.c
@ -1035,6 +1035,7 @@ int sftp_cmd_ls(struct sftp_command *cmd)
|
|||||||
char *tmpdir;
|
char *tmpdir;
|
||||||
int len, check;
|
int len, check;
|
||||||
|
|
||||||
|
sfree(unwcdir);
|
||||||
wildcard = stripslashes(dir, 0);
|
wildcard = stripslashes(dir, 0);
|
||||||
unwcdir = dupstr(dir);
|
unwcdir = dupstr(dir);
|
||||||
len = wildcard - dir;
|
len = wildcard - dir;
|
||||||
@ -2233,6 +2234,7 @@ struct sftp_command *sftp_getcmd(FILE *fp, int mode, int modeflags)
|
|||||||
cmd->obey = sftp_cmd_quit;
|
cmd->obey = sftp_cmd_quit;
|
||||||
if ((mode == 0) || (modeflags & 1))
|
if ((mode == 0) || (modeflags & 1))
|
||||||
printf("quit\n");
|
printf("quit\n");
|
||||||
|
sfree(line);
|
||||||
return cmd; /* eof */
|
return cmd; /* eof */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
1
raw.c
1
raw.c
@ -50,6 +50,7 @@ static void raw_log(Plug plug, int type, SockAddr addr, int port,
|
|||||||
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
|
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
|
||||||
|
|
||||||
logevent(raw->frontend, msg);
|
logevent(raw->frontend, msg);
|
||||||
|
sfree(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void raw_check_close(Raw raw)
|
static void raw_check_close(Raw raw)
|
||||||
|
1
rlogin.c
1
rlogin.c
@ -58,6 +58,7 @@ static void rlogin_log(Plug plug, int type, SockAddr addr, int port,
|
|||||||
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
|
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
|
||||||
|
|
||||||
logevent(rlogin->frontend, msg);
|
logevent(rlogin->frontend, msg);
|
||||||
|
sfree(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rlogin_closing(Plug plug, const char *error_msg, int error_code,
|
static int rlogin_closing(Plug plug, const char *error_msg, int error_code,
|
||||||
|
6
ssh.c
6
ssh.c
@ -4869,14 +4869,11 @@ static void ssh1_msg_port_open(Ssh ssh, struct Packet *pktin)
|
|||||||
{
|
{
|
||||||
/* Remote side is trying to open a channel to talk to a
|
/* Remote side is trying to open a channel to talk to a
|
||||||
* forwarded port. Give them back a local channel number. */
|
* forwarded port. Give them back a local channel number. */
|
||||||
struct ssh_channel *c;
|
|
||||||
struct ssh_rportfwd pf, *pfp;
|
struct ssh_rportfwd pf, *pfp;
|
||||||
int remoteid;
|
int remoteid;
|
||||||
int hostsize, port;
|
int hostsize, port;
|
||||||
char *host;
|
char *host;
|
||||||
const char *e;
|
const char *e;
|
||||||
c = snew(struct ssh_channel);
|
|
||||||
c->ssh = ssh;
|
|
||||||
|
|
||||||
remoteid = ssh_pkt_getuint32(pktin);
|
remoteid = ssh_pkt_getuint32(pktin);
|
||||||
ssh_pkt_getstring(pktin, &host, &hostsize);
|
ssh_pkt_getstring(pktin, &host, &hostsize);
|
||||||
@ -4895,6 +4892,9 @@ static void ssh1_msg_port_open(Ssh ssh, struct Packet *pktin)
|
|||||||
send_packet(ssh, SSH1_MSG_CHANNEL_OPEN_FAILURE,
|
send_packet(ssh, SSH1_MSG_CHANNEL_OPEN_FAILURE,
|
||||||
PKT_INT, remoteid, PKT_END);
|
PKT_INT, remoteid, PKT_END);
|
||||||
} else {
|
} else {
|
||||||
|
struct ssh_channel *c = snew(struct ssh_channel);
|
||||||
|
c->ssh = ssh;
|
||||||
|
|
||||||
logeventf(ssh, "Received remote port open request for %s:%d",
|
logeventf(ssh, "Received remote port open request for %s:%d",
|
||||||
pf.dhost, port);
|
pf.dhost, port);
|
||||||
e = pfd_newconnect(&c->u.pfd.s, pf.dhost, port,
|
e = pfd_newconnect(&c->u.pfd.s, pf.dhost, port,
|
||||||
|
3
sshdss.c
3
sshdss.c
@ -289,6 +289,8 @@ static int dss_verifysig(void *key, char *sig, int siglen,
|
|||||||
|
|
||||||
freebn(w);
|
freebn(w);
|
||||||
freebn(sha);
|
freebn(sha);
|
||||||
|
freebn(u1);
|
||||||
|
freebn(u2);
|
||||||
freebn(gu1p);
|
freebn(gu1p);
|
||||||
freebn(yu2p);
|
freebn(yu2p);
|
||||||
freebn(gu1yu2p);
|
freebn(gu1yu2p);
|
||||||
@ -404,6 +406,7 @@ static void *dss_createkey(unsigned char *pub_blob, int pub_len,
|
|||||||
ytest = modpow(dss->g, dss->x, dss->p);
|
ytest = modpow(dss->g, dss->x, dss->p);
|
||||||
if (0 != bignum_cmp(ytest, dss->y)) {
|
if (0 != bignum_cmp(ytest, dss->y)) {
|
||||||
dss_freekey(dss);
|
dss_freekey(dss);
|
||||||
|
freebn(ytest);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
freebn(ytest);
|
freebn(ytest);
|
||||||
|
@ -1008,6 +1008,8 @@ int ssh2_userkey_encrypted(const Filename *filename, char **commentptr)
|
|||||||
|
|
||||||
if (commentptr)
|
if (commentptr)
|
||||||
*commentptr = comment;
|
*commentptr = comment;
|
||||||
|
else
|
||||||
|
sfree(comment);
|
||||||
|
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
if (!strcmp(b, "aes256-cbc"))
|
if (!strcmp(b, "aes256-cbc"))
|
||||||
|
2
sshrsa.c
2
sshrsa.c
@ -413,6 +413,7 @@ int rsa_verify(struct RSAKey *key)
|
|||||||
pm1 = copybn(key->p);
|
pm1 = copybn(key->p);
|
||||||
decbn(pm1);
|
decbn(pm1);
|
||||||
ed = modmul(key->exponent, key->private_exponent, pm1);
|
ed = modmul(key->exponent, key->private_exponent, pm1);
|
||||||
|
freebn(pm1);
|
||||||
cmp = bignum_cmp(ed, One);
|
cmp = bignum_cmp(ed, One);
|
||||||
sfree(ed);
|
sfree(ed);
|
||||||
if (cmp != 0)
|
if (cmp != 0)
|
||||||
@ -421,6 +422,7 @@ int rsa_verify(struct RSAKey *key)
|
|||||||
qm1 = copybn(key->q);
|
qm1 = copybn(key->q);
|
||||||
decbn(qm1);
|
decbn(qm1);
|
||||||
ed = modmul(key->exponent, key->private_exponent, qm1);
|
ed = modmul(key->exponent, key->private_exponent, qm1);
|
||||||
|
freebn(qm1);
|
||||||
cmp = bignum_cmp(ed, One);
|
cmp = bignum_cmp(ed, One);
|
||||||
sfree(ed);
|
sfree(ed);
|
||||||
if (cmp != 0)
|
if (cmp != 0)
|
||||||
|
1
telnet.c
1
telnet.c
@ -662,6 +662,7 @@ static void telnet_log(Plug plug, int type, SockAddr addr, int port,
|
|||||||
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
|
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
|
||||||
|
|
||||||
logevent(telnet->frontend, msg);
|
logevent(telnet->frontend, msg);
|
||||||
|
sfree(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int telnet_closing(Plug plug, const char *error_msg, int error_code,
|
static int telnet_closing(Plug plug, const char *error_msg, int error_code,
|
||||||
|
@ -191,8 +191,10 @@ static char *x11_guess_derived_font_name(XFontStruct *xfs, int bold, int wide)
|
|||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nstr < lenof(strings))
|
if (nstr < lenof(strings)) {
|
||||||
|
sfree(dupname);
|
||||||
return NULL; /* XLFD was malformed */
|
return NULL; /* XLFD was malformed */
|
||||||
|
}
|
||||||
|
|
||||||
if (bold)
|
if (bold)
|
||||||
strings[2] = "bold";
|
strings[2] = "bold";
|
||||||
|
@ -3009,7 +3009,7 @@ void change_settings_menuitem(GtkMenuItem *item, gpointer data)
|
|||||||
4, 12, 5, 13, 6, 14, 7, 15
|
4, 12, 5, 13, 6, 14, 7, 15
|
||||||
};
|
};
|
||||||
struct gui_data *inst = (struct gui_data *)data;
|
struct gui_data *inst = (struct gui_data *)data;
|
||||||
char *title = dupcat(appname, " Reconfiguration", NULL);
|
char *title;
|
||||||
Conf *oldconf, *newconf;
|
Conf *oldconf, *newconf;
|
||||||
int i, j, need_size;
|
int i, j, need_size;
|
||||||
|
|
||||||
@ -3020,6 +3020,8 @@ void change_settings_menuitem(GtkMenuItem *item, gpointer data)
|
|||||||
else
|
else
|
||||||
inst->reconfiguring = TRUE;
|
inst->reconfiguring = TRUE;
|
||||||
|
|
||||||
|
title = dupcat(appname, " Reconfiguration", NULL);
|
||||||
|
|
||||||
oldconf = inst->conf;
|
oldconf = inst->conf;
|
||||||
newconf = conf_copy(inst->conf);
|
newconf = conf_copy(inst->conf);
|
||||||
|
|
||||||
@ -3134,6 +3136,7 @@ void change_settings_menuitem(GtkMenuItem *item, gpointer data)
|
|||||||
string_width("Could not change fonts in terminal window:"),
|
string_width("Could not change fonts in terminal window:"),
|
||||||
"OK", 'o', +1, 1,
|
"OK", 'o', +1, 1,
|
||||||
NULL);
|
NULL);
|
||||||
|
sfree(msgboxtext);
|
||||||
sfree(errmsg);
|
sfree(errmsg);
|
||||||
} else {
|
} else {
|
||||||
need_size = TRUE;
|
need_size = TRUE;
|
||||||
@ -3228,6 +3231,7 @@ void fork_and_exec_self(struct gui_data *inst, int fd_to_close, ...)
|
|||||||
pid = fork();
|
pid = fork();
|
||||||
if (pid < 0) {
|
if (pid < 0) {
|
||||||
perror("fork");
|
perror("fork");
|
||||||
|
sfree(args);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3261,6 +3265,7 @@ void fork_and_exec_self(struct gui_data *inst, int fd_to_close, ...)
|
|||||||
|
|
||||||
} else {
|
} else {
|
||||||
int status;
|
int status;
|
||||||
|
sfree(args);
|
||||||
waitpid(pid, &status, 0);
|
waitpid(pid, &status, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3339,6 +3344,7 @@ int read_dupsession_data(struct gui_data *inst, Conf *conf, char *arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
size_used = conf_deserialise(conf, data, size);
|
size_used = conf_deserialise(conf, data, size);
|
||||||
|
sfree(data);
|
||||||
if (use_pty_argv && size > size_used) {
|
if (use_pty_argv && size > size_used) {
|
||||||
int n = 0;
|
int n = 0;
|
||||||
i = size_used;
|
i = size_used;
|
||||||
|
@ -26,6 +26,7 @@ char *get_random_data(int len)
|
|||||||
ret = read(fd, buf+ngot, len-ngot);
|
ret = read(fd, buf+ngot, len-ngot);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
close(fd);
|
close(fd);
|
||||||
|
sfree(buf);
|
||||||
perror("puttygen: unable to read /dev/random");
|
perror("puttygen: unable to read /dev/random");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -297,6 +297,7 @@ Socket platform_new_connection(SockAddr addr, char *hostname,
|
|||||||
|
|
||||||
if (pid < 0) {
|
if (pid < 0) {
|
||||||
ret->error = dupprintf("fork: %s", strerror(errno));
|
ret->error = dupprintf("fork: %s", strerror(errno));
|
||||||
|
sfree(cmd);
|
||||||
return (Socket)ret;
|
return (Socket)ret;
|
||||||
} else if (pid == 0) {
|
} else if (pid == 0) {
|
||||||
close(0);
|
close(0);
|
||||||
|
@ -308,6 +308,7 @@ static const char *serial_init(void *frontend_handle, void **backend_handle,
|
|||||||
{
|
{
|
||||||
char *msg = dupprintf("Opening serial device %s", line);
|
char *msg = dupprintf("Opening serial device %s", line);
|
||||||
logevent(serial->frontend, msg);
|
logevent(serial->frontend, msg);
|
||||||
|
sfree(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
serial->fd = open(line, O_RDWR | O_NOCTTY | O_NDELAY | O_NONBLOCK);
|
serial->fd = open(line, O_RDWR | O_NOCTTY | O_NDELAY | O_NONBLOCK);
|
||||||
|
@ -565,6 +565,7 @@ char *ssh_sftp_get_cmdline(char *prompt, int no_fds_ok)
|
|||||||
ret = ssh_sftp_do_select(TRUE, no_fds_ok);
|
ret = ssh_sftp_do_select(TRUE, no_fds_ok);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
printf("connection died\n");
|
printf("connection died\n");
|
||||||
|
sfree(buf);
|
||||||
return NULL; /* woop woop */
|
return NULL; /* woop woop */
|
||||||
}
|
}
|
||||||
if (ret > 0) {
|
if (ret > 0) {
|
||||||
@ -575,10 +576,12 @@ char *ssh_sftp_get_cmdline(char *prompt, int no_fds_ok)
|
|||||||
ret = read(0, buf+buflen, 1);
|
ret = read(0, buf+buflen, 1);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
perror("read");
|
perror("read");
|
||||||
|
sfree(buf);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
/* eof on stdin; no error, but no answer either */
|
/* eof on stdin; no error, but no answer either */
|
||||||
|
sfree(buf);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -299,8 +299,10 @@ void *open_settings_r(const char *sessionname)
|
|||||||
char *value = strchr(line, '=');
|
char *value = strchr(line, '=');
|
||||||
struct skeyval *kv;
|
struct skeyval *kv;
|
||||||
|
|
||||||
if (!value)
|
if (!value) {
|
||||||
|
sfree(line);
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
*value++ = '\0';
|
*value++ = '\0';
|
||||||
value[strcspn(value, "\r\n")] = '\0'; /* trim trailing NL */
|
value[strcspn(value, "\r\n")] = '\0'; /* trim trailing NL */
|
||||||
|
|
||||||
@ -589,9 +591,6 @@ void store_host_key(const char *hostname, int port,
|
|||||||
int headerlen;
|
int headerlen;
|
||||||
char *filename, *tmpfilename;
|
char *filename, *tmpfilename;
|
||||||
|
|
||||||
newtext = dupprintf("%s@%d:%s %s\n", keytype, port, hostname, key);
|
|
||||||
headerlen = 1 + strcspn(newtext, " "); /* count the space too */
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Open both the old file and a new file.
|
* Open both the old file and a new file.
|
||||||
*/
|
*/
|
||||||
@ -613,6 +612,9 @@ void store_host_key(const char *hostname, int port,
|
|||||||
filename = make_filename(INDEX_HOSTKEYS, NULL);
|
filename = make_filename(INDEX_HOSTKEYS, NULL);
|
||||||
rfp = fopen(filename, "r");
|
rfp = fopen(filename, "r");
|
||||||
|
|
||||||
|
newtext = dupprintf("%s@%d:%s %s\n", keytype, port, hostname, key);
|
||||||
|
headerlen = 1 + strcspn(newtext, " "); /* count the space too */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copy all lines from the old file to the new one that _don't_
|
* Copy all lines from the old file to the new one that _don't_
|
||||||
* involve the same host key identifier as the one we're adding.
|
* involve the same host key identifier as the one we're adding.
|
||||||
@ -621,6 +623,7 @@ void store_host_key(const char *hostname, int port,
|
|||||||
while ( (line = fgetline(rfp)) ) {
|
while ( (line = fgetline(rfp)) ) {
|
||||||
if (strncmp(line, newtext, headerlen))
|
if (strncmp(line, newtext, headerlen))
|
||||||
fputs(line, wfp);
|
fputs(line, wfp);
|
||||||
|
sfree(line);
|
||||||
}
|
}
|
||||||
fclose(rfp);
|
fclose(rfp);
|
||||||
}
|
}
|
||||||
|
5
x11fwd.c
5
x11fwd.c
@ -171,6 +171,7 @@ struct X11Display *x11_setup_display(char *display, int authtype, Conf *conf)
|
|||||||
sk_addr_free(disp->addr);
|
sk_addr_free(disp->addr);
|
||||||
sfree(disp->hostname);
|
sfree(disp->hostname);
|
||||||
sfree(disp->unixsocketpath);
|
sfree(disp->unixsocketpath);
|
||||||
|
sfree(disp);
|
||||||
return NULL; /* FIXME: report an error */
|
return NULL; /* FIXME: report an error */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -343,7 +344,7 @@ void x11_get_auth_from_authfile(struct X11Display *disp,
|
|||||||
int len[4];
|
int len[4];
|
||||||
int family, protocol;
|
int family, protocol;
|
||||||
int ideal_match = FALSE;
|
int ideal_match = FALSE;
|
||||||
char *ourhostname = get_hostname();
|
char *ourhostname;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Normally we should look for precisely the details specified in
|
* Normally we should look for precisely the details specified in
|
||||||
@ -372,6 +373,8 @@ void x11_get_auth_from_authfile(struct X11Display *disp,
|
|||||||
if (!authfp)
|
if (!authfp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
ourhostname = get_hostname();
|
||||||
|
|
||||||
/* Records in .Xauthority contain four strings of up to 64K each */
|
/* Records in .Xauthority contain four strings of up to 64K each */
|
||||||
buf = snewn(65537 * 4, char);
|
buf = snewn(65537 * 4, char);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user