Skip to content

Commit

Permalink
trust: don't create file names longer then 255
Browse files Browse the repository at this point in the history
Signed-off-by: Zoltan Fridrich <[email protected]>
  • Loading branch information
ZoltanFridrich committed Oct 3, 2024
1 parent 89d3a55 commit 961c39d
Showing 1 changed file with 15 additions and 3 deletions.
18 changes: 15 additions & 3 deletions trust/save.c
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,8 @@
#define O_DIRECTORY 0
#endif

#define MAX_FILE_NAME 255

struct _p11_save_file {
char *bare;
char *extension;
Expand Down Expand Up @@ -414,12 +416,22 @@ make_unique_name (const char *bare,
p11_buffer buf;
int ret;
int i;
size_t bare_len, ext_len;

assert (bare != NULL);
assert (check != NULL);

p11_buffer_init_null (&buf, 0);

/*
* Make sure the name will not be longer then MAX_FILE_NAME
*/
ext_len = strlen (extension);
bare_len = strlen (bare);
if (bare_len + ext_len + sizeof (unique) > MAX_FILE_NAME)
bare_len = MAX_FILE_NAME - ext_len - sizeof (unique);
return_val_if_fail (bare_len > 0, NULL);

for (i = 0; true; i++) {

p11_buffer_reset (&buf, 64);
Expand All @@ -431,7 +443,7 @@ make_unique_name (const char *bare,
* provided by the caller.
*/
case 0:
p11_buffer_add (&buf, bare, -1);
p11_buffer_add (&buf, bare, bare_len);
break;

/*
Expand All @@ -448,14 +460,14 @@ make_unique_name (const char *bare,
/* fall through */

default:
p11_buffer_add (&buf, bare, -1);
p11_buffer_add (&buf, bare, bare_len);
snprintf (unique, sizeof (unique), ".%d", i);
p11_buffer_add (&buf, unique, -1);
break;
}

if (extension)
p11_buffer_add (&buf, extension, -1);
p11_buffer_add (&buf, extension, ext_len);

return_val_if_fail (p11_buffer_ok (&buf), NULL);

Expand Down

0 comments on commit 961c39d

Please sign in to comment.