mirror of
https://github.com/openssl/openssl.git
synced 2025-03-31 20:10:45 +08:00
ossl_property_list_to_string: handle quoted strings
ossl_property_list_to_string() didn't quote strings correctly which could result in a generated property string being unparsable. Reviewed-by: Tomas Mraz <tomas@openssl.org> Reviewed-by: Matt Caswell <matt@openssl.org> (Merged from https://github.com/openssl/openssl/pull/22182)
This commit is contained in:
parent
456e6ca5d7
commit
fb20e66c6b
@ -588,15 +588,38 @@ static void put_char(char ch, char **buf, size_t *remain, size_t *needed)
|
||||
|
||||
static void put_str(const char *str, char **buf, size_t *remain, size_t *needed)
|
||||
{
|
||||
size_t olen, len;
|
||||
size_t olen, len, i;
|
||||
char quote = '\0';
|
||||
int quotes;
|
||||
|
||||
len = olen = strlen(str);
|
||||
*needed += len;
|
||||
|
||||
if (*remain == 0)
|
||||
return;
|
||||
/*
|
||||
* Check to see if we need quotes or not.
|
||||
* Characters that are legal in a PropertyName don't need quoting.
|
||||
* We simply assume all others require quotes.
|
||||
*/
|
||||
for (i = 0; i < len; i++)
|
||||
if (!ossl_isalnum(str[i]) && str[i] != '.' && str[i] != '_') {
|
||||
/* Default to single quotes ... */
|
||||
if (quote == '\0')
|
||||
quote = '\'';
|
||||
/* ... but use double quotes if a single is present */
|
||||
if (str[i] == '\'')
|
||||
quote = '"';
|
||||
}
|
||||
|
||||
if (*remain < len + 1)
|
||||
quotes = quote != '\0';
|
||||
if (*remain == 0) {
|
||||
*needed += 2 * quotes;
|
||||
return;
|
||||
}
|
||||
|
||||
if (quotes)
|
||||
put_char(quote, buf, remain, needed);
|
||||
|
||||
if (*remain < len + 1 + quotes)
|
||||
len = *remain - 1;
|
||||
|
||||
if (len > 0) {
|
||||
@ -605,6 +628,9 @@ static void put_str(const char *str, char **buf, size_t *remain, size_t *needed)
|
||||
*remain -= len;
|
||||
}
|
||||
|
||||
if (quotes)
|
||||
put_char(quote, buf, remain, needed);
|
||||
|
||||
if (len < olen && *remain == 1) {
|
||||
**buf = '\0';
|
||||
++*buf;
|
||||
|
@ -645,6 +645,9 @@ static struct {
|
||||
{ "", "" },
|
||||
{ "fips=3", "fips=3" },
|
||||
{ "fips=-3", "fips=-3" },
|
||||
{ "provider='foo bar'", "provider='foo bar'" },
|
||||
{ "provider=\"foo bar'\"", "provider=\"foo bar'\"" },
|
||||
{ "provider=abc***", "provider='abc***'" },
|
||||
{ NULL, "" }
|
||||
};
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user