mirror of https://github.com/apache/archiva.git
Adding additional verifications for upload
(cherry picked from commit c5bcbaabed
)
This commit is contained in:
parent
0102f34cfe
commit
747cc55b24
|
@ -184,21 +184,22 @@ public class DefaultFileUploadService
|
||||||
public Boolean deleteFile( String fileName )
|
public Boolean deleteFile( String fileName )
|
||||||
throws ArchivaRestServiceException
|
throws ArchivaRestServiceException
|
||||||
{
|
{
|
||||||
Path file = SystemUtils.getJavaIoTmpDir().toPath().resolve( fileName );
|
// we make sure, that there are no other path components in the filename:
|
||||||
|
String checkedFileName = Paths.get(fileName).getFileName().toString();
|
||||||
|
Path file = SystemUtils.getJavaIoTmpDir().toPath().resolve( checkedFileName );
|
||||||
log.debug( "delete file:{},exists:{}", file, Files.exists(file) );
|
log.debug( "delete file:{},exists:{}", file, Files.exists(file) );
|
||||||
boolean removed = getSessionFileMetadatas().remove( new FileMetadata( fileName ) );
|
boolean removed = getSessionFileMetadatas().remove( new FileMetadata( fileName ) );
|
||||||
// try with full name as ui only know the file name
|
// try with full name as ui only know the file name
|
||||||
if ( !removed )
|
if ( !removed ) {
|
||||||
{
|
removed = getSessionFileMetadatas().remove(new FileMetadata(file.toString()));
|
||||||
/* unused */ getSessionFileMetadatas().remove( new FileMetadata( file.toString() ) );
|
|
||||||
}
|
}
|
||||||
try
|
if (removed) {
|
||||||
{
|
try {
|
||||||
Files.deleteIfExists( file );
|
Files.deleteIfExists(file);
|
||||||
}
|
return Boolean.TRUE;
|
||||||
catch ( IOException e )
|
} catch (IOException e) {
|
||||||
{
|
log.error("Could not delete file {}: {}", file, e.getMessage(), e);
|
||||||
log.error("Could not delete file {}: {}", file, e.getMessage(), e);
|
}
|
||||||
}
|
}
|
||||||
return Boolean.FALSE;
|
return Boolean.FALSE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue