1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Sanitise bad characters in log file names.

On Windows, colons are illegal in filenames, because they're part of
the path syntax. But colons can appear in automatically constructed
log file names, if an IPv6 address is expanded from the &H placeholder.

Now we coerce any such illegal characters to '.', which is a bit of a
bodge but should at least cause a log file to be generated.
This commit is contained in:
Simon Tatham 2015-09-25 09:23:26 +01:00
parent e162810516
commit 64ec5e03d5
4 changed files with 28 additions and 2 deletions

View File

@ -446,6 +446,7 @@ static Filename *xlatlognam(Filename *src, char *hostname, int port,
s = filename_to_str(src); s = filename_to_str(src);
while (*s) { while (*s) {
int sanitise = FALSE;
/* Let (bufp, len) be the string to append. */ /* Let (bufp, len) be the string to append. */
bufp = buf; /* don't usually override this */ bufp = buf; /* don't usually override this */
if (*s == '&') { if (*s == '&') {
@ -478,6 +479,12 @@ static Filename *xlatlognam(Filename *src, char *hostname, int port,
if (c != '&') if (c != '&')
buf[size++] = c; buf[size++] = c;
} }
/* Never allow path separators - or any other illegal
* filename character - to come out of any of these
* auto-format directives. E.g. 'hostname' can contain
* colons, if it's an IPv6 address, and colons aren't
* legal in filenames on Windows. */
sanitise = TRUE;
} else { } else {
buf[0] = *s++; buf[0] = *s++;
size = 1; size = 1;
@ -486,8 +493,12 @@ static Filename *xlatlognam(Filename *src, char *hostname, int port,
bufsize = (buflen + size) * 5 / 4 + 512; bufsize = (buflen + size) * 5 / 4 + 512;
buffer = sresize(buffer, bufsize, char); buffer = sresize(buffer, bufsize, char);
} }
memcpy(buffer + buflen, bufp, size); while (size-- > 0) {
buflen += size; char c = *bufp++;
if (sanitise)
c = filename_char_sanitise(c);
buffer[buflen++] = c;
}
} }
buffer[buflen] = '\0'; buffer[buflen] = '\0';

View File

@ -1322,6 +1322,7 @@ int filename_serialise(const Filename *f, void *data);
Filename *filename_deserialise(void *data, int maxsize, int *used); Filename *filename_deserialise(void *data, int maxsize, int *used);
char *get_username(void); /* return value needs freeing */ char *get_username(void); /* return value needs freeing */
char *get_random_data(int bytes); /* used in cmdgen.c */ char *get_random_data(int bytes); /* used in cmdgen.c */
char filename_char_sanitise(char c); /* rewrite special pathname chars */
/* /*
* Exports and imports from timing.c. * Exports and imports from timing.c.

View File

@ -95,6 +95,13 @@ Filename *filename_deserialise(void *vdata, int maxsize, int *used)
return filename_from_str(data); return filename_from_str(data);
} }
char filename_char_sanitise(char c)
{
if (c == '/')
return '.';
return c;
}
#ifdef DEBUG #ifdef DEBUG
static FILE *debug_fp = NULL; static FILE *debug_fp = NULL;

View File

@ -71,6 +71,13 @@ Filename *filename_deserialise(void *vdata, int maxsize, int *used)
return filename_from_str(data); return filename_from_str(data);
} }
char filename_char_sanitise(char c)
{
if (strchr("<>:\"/\\|?*", c))
return '.';
return c;
}
#ifndef NO_SECUREZEROMEMORY #ifndef NO_SECUREZEROMEMORY
/* /*
* Windows implementation of smemclr (see misc.c) using SecureZeroMemory. * Windows implementation of smemclr (see misc.c) using SecureZeroMemory.