mirror of
https://git.FreeBSD.org/ports.git
synced 2025-01-22 08:58:47 +00:00
Plug security hole.
Submitted by: simon
This commit is contained in:
parent
7f3e0d51d2
commit
da87ef0c61
Notes:
svn2git
2021-03-31 03:12:20 +00:00
svn path=/head/; revision=127298
@ -7,7 +7,7 @@
|
||||
|
||||
PORTNAME= yamt
|
||||
PORTVERSION= 0.5
|
||||
PORTREVISION= 1
|
||||
PORTREVISION= 2
|
||||
CATEGORIES= audio gnome
|
||||
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE} \
|
||||
ftp://ftp.gpad.ac.ru/pub/FreeBSD/distfiles/
|
||||
|
123
audio/yamt/files/patch-yamt-directory-traversal
Normal file
123
audio/yamt/files/patch-yamt-directory-traversal
Normal file
@ -0,0 +1,123 @@
|
||||
--- src/id3tag.c
|
||||
+++ src/id3tag.c
|
||||
@@ -389,12 +389,20 @@
|
||||
return(1);
|
||||
}
|
||||
|
||||
+static void id3tag_sanitize (char *string)
|
||||
+{
|
||||
+ while ((string = strchr (string, '/')))
|
||||
+ {
|
||||
+ *string = '_';
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
/* This function renames a file based on its tag in the given format */
|
||||
int id3tag_rename( char *filename, char *format )
|
||||
{
|
||||
struct id3tag tag;
|
||||
struct stat stbuf;
|
||||
- char target_filename[80]="";
|
||||
+ char target_filename[PATH_MAX]="";
|
||||
char buffer[10]="";
|
||||
char *tmp;
|
||||
int i;
|
||||
@@ -425,36 +433,42 @@
|
||||
{
|
||||
case 't':
|
||||
strcat( target_filename, tag.title);
|
||||
+ id3tag_sanitize (target_filename+i2);
|
||||
i2=i2+strlen(tag.title);
|
||||
i++;
|
||||
break;
|
||||
|
||||
case 'a':
|
||||
strcat( target_filename, tag.artist);
|
||||
+ id3tag_sanitize (target_filename+i2);
|
||||
i2=i2+strlen(tag.artist);
|
||||
i++;
|
||||
break;
|
||||
|
||||
case 'b':
|
||||
strcat( target_filename, tag.album);
|
||||
+ id3tag_sanitize (target_filename+i2);
|
||||
i2=i2+strlen(tag.album);
|
||||
i++;
|
||||
break;
|
||||
|
||||
case 'c':
|
||||
strcat( target_filename, tag.comment);
|
||||
+ id3tag_sanitize (target_filename+i2);
|
||||
i2=i2+strlen(tag.comment);
|
||||
i++;
|
||||
break;
|
||||
|
||||
case 'y':
|
||||
strcat( target_filename, tag.year);
|
||||
+ id3tag_sanitize (target_filename+i2);
|
||||
i2=i2+strlen(tag.year);
|
||||
i++;
|
||||
break;
|
||||
|
||||
case 'g':
|
||||
strcat( target_filename, id3tag_get_genre(tag.genre));
|
||||
+ id3tag_sanitize (target_filename+i2);
|
||||
i2=i2+strlen(id3tag_get_genre(tag.genre));
|
||||
i++;
|
||||
break;
|
||||
@@ -521,9 +535,9 @@
|
||||
int id3tag_sort( char *filename, char *rootdir, char *format_level1, char *format_level2 )
|
||||
{
|
||||
struct id3tag tag;
|
||||
- char *dir_level1=NULL;
|
||||
- char *dir_level2=NULL;
|
||||
- char target_filename[80];
|
||||
+ char *dir_level1=NULL, *dir_level1_sanitized;
|
||||
+ char *dir_level2=NULL, *dir_level2_sanitized;
|
||||
+ char source_filename[PATH_MAX], target_filename[PATH_MAX];
|
||||
char dir_cur[80];
|
||||
|
||||
|
||||
@@ -554,8 +568,10 @@
|
||||
chdir(rootdir);
|
||||
if( dir_level1[0] == '\0' )
|
||||
dir_level1 = "Unknown";
|
||||
- yamtlog("%s %s", "New directory: ", dir_level1);
|
||||
- mkdir( dir_level1, S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH );
|
||||
+ dir_level1_sanitized = strdup (dir_level1);
|
||||
+ id3tag_sanitize (dir_level1_sanitized);
|
||||
+ yamtlog("%s %s", "New directory: ", dir_level1_sanitized);
|
||||
+ mkdir( dir_level1_sanitized, S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH );
|
||||
|
||||
/* Level 2 */
|
||||
if( strcmp( format_level2, "Album") == 0 )
|
||||
@@ -573,18 +589,24 @@
|
||||
|
||||
if( dir_level2[0] == '\0' )
|
||||
dir_level2 = "Unknown";
|
||||
- yamtlog("%s %s", "New directory: ", dir_level2);
|
||||
+ dir_level2_sanitized = strdup (dir_level2);
|
||||
+ id3tag_sanitize (dir_level2_sanitized);
|
||||
+ yamtlog("%s %s", "New directory: ", dir_level2_sanitized);
|
||||
|
||||
/* Go into the previously created directory */
|
||||
- chdir( dir_level1 );
|
||||
- mkdir( dir_level2, S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH );
|
||||
+ chdir( dir_level1_sanitized );
|
||||
+ mkdir( dir_level2_sanitized, S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH );
|
||||
/* Move the file into the new (?) directory */
|
||||
|
||||
- sprintf( target_filename, "mv \"%s/%s\" \"%s%s/%s/%s\"", dir_cur, filename, rootdir, dir_level1, dir_level2, filename );
|
||||
+ snprintf( source_filename, PATH_MAX, "%s/%s", dir_cur, filename );
|
||||
+ snprintf( target_filename, PATH_MAX, "%s%s/%s/%s", rootdir, dir_level1_sanitized, dir_level2_sanitized, filename );
|
||||
+
|
||||
+ free (dir_level1_sanitized);
|
||||
+ free (dir_level2_sanitized);
|
||||
|
||||
yamtlog("%s %s", "Sorted ", filename );
|
||||
|
||||
- system( target_filename );
|
||||
+ rename( source_filename, target_filename );
|
||||
|
||||
/* if( (rename( filename, target_filename )) ) */
|
||||
/* { */
|
Loading…
Reference in New Issue
Block a user