mirror of
https://github.com/samba-team/samba.git
synced 2025-01-06 13:18:07 +03:00
3b85345c4c
A signed char, passed to snprintf(), will be promoted to an ‘int’, and then interpreted (according to the format string) as an ‘unsigned int’. Any negative values passed in will thus be interpreted as large unsigned values, too large to be represented in the two characters allocated for them. In practice, they will always be represented as ‘\xFF’. Cast these characters to ‘unsigned char’, and use the appropriate length modifier for that type. Signed-off-by: Jo Sutton <josutton@catalyst.net.nz> Reviewed-by: Andrew Bartlett <abartlet@samba.org>
128 lines
2.5 KiB
C
128 lines
2.5 KiB
C
/*
|
|
Samba string escaping routines
|
|
|
|
Copyright (C) Andrew Bartlett <abartlet@samba.org> 2017
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "replace.h"
|
|
#include "lib/util/debug.h"
|
|
#include "lib/util/util_str_escape.h"
|
|
|
|
|
|
/*
|
|
* Calculate the encoded length of a character for log_escape
|
|
*
|
|
*/
|
|
static size_t encoded_length(unsigned char c)
|
|
{
|
|
if (c != '\\' && c > 0x1F) {
|
|
return 1;
|
|
} else {
|
|
switch (c) {
|
|
case '\a':
|
|
case '\b':
|
|
case '\f':
|
|
case '\n':
|
|
case '\r':
|
|
case '\t':
|
|
case '\v':
|
|
case '\\':
|
|
return 2; /* C escape sequence */
|
|
default:
|
|
return 4; /* hex escape \xhh */
|
|
}
|
|
}
|
|
}
|
|
|
|
/*
|
|
* Escape any control characters in the inputs to prevent them from
|
|
* interfering with the log output.
|
|
*/
|
|
char *log_escape(TALLOC_CTX *frame, const char *in)
|
|
{
|
|
size_t size = 0; /* Space to allocate for the escaped data */
|
|
char *encoded = NULL; /* The encoded string */
|
|
const char *c;
|
|
char *e;
|
|
|
|
if (in == NULL) {
|
|
return NULL;
|
|
}
|
|
|
|
/* Calculate the size required for the escaped array */
|
|
c = in;
|
|
while (*c) {
|
|
size += encoded_length( *c);
|
|
c++;
|
|
}
|
|
size++;
|
|
|
|
encoded = talloc_array( frame, char, size);
|
|
if (encoded == NULL) {
|
|
DBG_ERR( "Out of memory allocating encoded string\n");
|
|
return NULL;
|
|
}
|
|
|
|
c = in;
|
|
e = encoded;
|
|
while (*c) {
|
|
if (*c != '\\' && (unsigned char)(*c) > 0x1F) {
|
|
*e++ = *c++;
|
|
} else {
|
|
switch (*c) {
|
|
case '\a':
|
|
*e++ = '\\';
|
|
*e++ = 'a';
|
|
break;
|
|
case '\b':
|
|
*e++ = '\\';
|
|
*e++ = 'b';
|
|
break;
|
|
case '\f':
|
|
*e++ = '\\';
|
|
*e++ = 'f';
|
|
break;
|
|
case '\n':
|
|
*e++ = '\\';
|
|
*e++ = 'n';
|
|
break;
|
|
case '\r':
|
|
*e++ = '\\';
|
|
*e++ = 'r';
|
|
break;
|
|
case '\t':
|
|
*e++ = '\\';
|
|
*e++ = 't';
|
|
break;
|
|
case '\v':
|
|
*e++ = '\\';
|
|
*e++ = 'v';
|
|
break;
|
|
case '\\':
|
|
*e++ = '\\';
|
|
*e++ = '\\';
|
|
break;
|
|
default:
|
|
snprintf(e, 5, "\\x%02hhX", (unsigned char)(*c));
|
|
e += 4;
|
|
}
|
|
c++;
|
|
}
|
|
}
|
|
*e = '\0';
|
|
return encoded;
|
|
}
|