archiver: improve error message for irregular files

Since Go 1.21, most reparse points are considered as irregular files.
Depending on the underlying driver these can exhibit nearly arbitrary
behavior. When encountering such a file, restic returned an
indecipherable error message: `error: invalid node type ""`.

Add the filepath to the error message and state that the file type is
not supported.
This commit is contained in:
Michael Eischer 2024-01-06 19:03:11 +01:00
parent 0018bb7854
commit 6b79834cc8
2 changed files with 8 additions and 2 deletions

View file

@ -2,6 +2,7 @@ package archiver
import ( import (
"context" "context"
"fmt"
"os" "os"
"path" "path"
"runtime" "runtime"
@ -183,7 +184,10 @@ func (arch *Archiver) nodeFromFileInfo(snPath, filename string, fi os.FileInfo)
} }
// overwrite name to match that within the snapshot // overwrite name to match that within the snapshot
node.Name = path.Base(snPath) node.Name = path.Base(snPath)
return node, errors.WithStack(err) if err != nil {
return node, fmt.Errorf("nodeFromFileInfo %v: %w", filename, err)
}
return node, err
} }
// loadSubtree tries to load the subtree referenced by node. In case of an error, nil is returned. // loadSubtree tries to load the subtree referenced by node. In case of an error, nil is returned.

View file

@ -124,6 +124,8 @@ func nodeTypeFromFileInfo(fi os.FileInfo) string {
return "fifo" return "fifo"
case os.ModeSocket: case os.ModeSocket:
return "socket" return "socket"
case os.ModeIrregular:
return "irregular"
} }
return "" return ""
@ -622,7 +624,7 @@ func (node *Node) fillExtra(path string, fi os.FileInfo) error {
case "fifo": case "fifo":
case "socket": case "socket":
default: default:
return errors.Errorf("invalid node type %q", node.Type) return errors.Errorf("unsupported file type %q", node.Type)
} }
return node.fillExtendedAttributes(path) return node.fillExtendedAttributes(path)