Merge branch 'mutantmonkey-better_extension_handling'
This commit is contained in:
commit
1f3bc4bfea
|
@ -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
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, "")
|
extension = extRe.ReplaceAllString(extension, "")
|
||||||
barename = barePlusRe.ReplaceAllString(barename, "")
|
barename = bareRe.ReplaceAllString(barename, "")
|
||||||
|
|
||||||
extension = strings.Trim(extension, "-")
|
extension = strings.Trim(extension, "-.")
|
||||||
barename = strings.Trim(barename, "-")
|
barename = strings.Trim(barename, "-")
|
||||||
|
|
||||||
return
|
return
|
||||||
|
|
Loading…
Reference in New Issue