Merge pull request #1245 from syncthing/indexclean-v2

Also filter out some other obviously invalid filenames (ref #1243)
This commit is contained in:
Audrius Butkevicius 2015-01-13 11:35:04 +00:00
commit 48382c4b59
2 changed files with 10 additions and 6 deletions

View File

@ -587,8 +587,9 @@ func ldbWithAllFolderTruncated(db *leveldb.DB, folder []byte, fn func(device []b
panic(err)
}
if f.Name == "" {
l.Infoln("Dropping invalid nil filename from database")
switch f.Name {
case "", ".", "..", "/": // A few obviously invalid filenames
l.Infof("Dropping invalid filename %q from database", f.Name)
batch := new(leveldb.Batch)
ldbRemoveFromGlobal(db, batch, folder, device, nil)
batch.Delete(dbi.Key())

View File

@ -490,8 +490,9 @@ func (c *rawConnection) handleIndexUpdate(im IndexMessage) {
func filterIndexMessageFiles(fs []FileInfo) []FileInfo {
var out []FileInfo
for i, f := range fs {
if f.Name == "" {
l.Infoln("Dropping nil filename from incoming index")
switch f.Name {
case "", ".", "..", "/": // A few obviously invalid filenames
l.Infof("Dropping invalid filename %q from incoming index", f.Name)
if out == nil {
// Most incoming updates won't contain anything invalid, so we
// delay the allocation and copy to output slice until we
@ -500,10 +501,12 @@ func filterIndexMessageFiles(fs []FileInfo) []FileInfo {
out = make([]FileInfo, i, len(fs)-1)
copy(out, fs)
}
} else if out != nil {
default:
if out != nil {
out = append(out, f)
}
}
}
if out != nil {
return out
}