Browse Source

Merge branch 'mutantmonkey-better_extension_handling'

pull/81/head v1.1.10
Andrei Marcu 9 years ago
parent
commit
1f3bc4bfea
  1. 18
      server_test.go
  2. 25
      upload.go

18
server_test.go

@ -887,6 +887,24 @@ func TestPutAndSpecificDelete(t *testing.T) {
} }
} }
func TestExtension(t *testing.T) {
barename, extension := barePlusExt("test.jpg.gz")
if barename != "testjpg" {
t.Fatal("Barename was not testjpg, but " + barename)
}
if extension != "gz" {
t.Fatal("Extension was not gz, but " + extension)
}
barename, extension = barePlusExt("test.tar.gz")
if barename != "test" {
t.Fatal("Barename was not test, but " + barename)
}
if extension != "tar.gz" {
t.Fatal("Extension was not tar.gz, but " + extension)
}
}
func TestShutdown(t *testing.T) { func TestShutdown(t *testing.T) {
os.RemoveAll(Config.filesDir) os.RemoveAll(Config.filesDir)
os.RemoveAll(Config.metaDir) os.RemoveAll(Config.metaDir)

25
upload.go

@ -322,20 +322,35 @@ func generateJSONresponse(upload Upload) []byte {
return js return js
} }
var barePlusRe = regexp.MustCompile(`[^A-Za-z0-9\-]`)
var bareRe = regexp.MustCompile(`[^A-Za-z0-9\-]`)
var extRe = regexp.MustCompile(`[^A-Za-z0-9\-\.]`)
var compressedExts = map[string]bool{
".bz2": true,
".gz": true,
".xz": true,
}
var archiveExts = map[string]bool{
".tar": true,
}
func barePlusExt(filename string) (barename, extension string) { func barePlusExt(filename string) (barename, extension string) {
filename = strings.TrimSpace(filename) filename = strings.TrimSpace(filename)
filename = strings.ToLower(filename) filename = strings.ToLower(filename)
extension = path.Ext(filename) extension = path.Ext(filename)
barename = filename[:len(filename)-len(extension)] barename = filename[:len(filename)-len(extension)]
if compressedExts[extension] {
ext2 := path.Ext(barename)
if archiveExts[ext2] {
barename = barename[:len(barename)-len(ext2)]
extension = ext2 + extension
}
}
extension = barePlusRe.ReplaceAllString(extension, "")
barename = barePlusRe.ReplaceAllString(barename, "")
extension = extRe.ReplaceAllString(extension, "")
barename = bareRe.ReplaceAllString(barename, "")
extension = strings.Trim(extension, "-")
extension = strings.Trim(extension, "-.")
barename = strings.Trim(barename, "-") barename = strings.Trim(barename, "-")
return return

Loading…
Cancel
Save