1
0
Fork 0
mirror of https://github.com/restic/restic.git synced 2024-12-31 20:26:28 +00:00
restic/internal/backend/file.go

80 lines
1.3 KiB
Go
Raw Permalink Normal View History

package backend
import (
"fmt"
2017-07-23 12:21:03 +00:00
"github.com/restic/restic/internal/errors"
)
2016-08-31 18:29:54 +00:00
// FileType is the type of a file in the backend.
type FileType uint8
2016-08-31 18:29:54 +00:00
// These are the different data types a backend can store.
const (
PackFile FileType = 1 + iota
KeyFile
LockFile
SnapshotFile
IndexFile
ConfigFile
2016-08-31 18:29:54 +00:00
)
func (t FileType) String() string {
s := "invalid"
switch t {
case PackFile:
// Spelled "data" instead of "pack" for historical reasons.
s = "data"
case KeyFile:
s = "key"
case LockFile:
s = "lock"
case SnapshotFile:
s = "snapshot"
case IndexFile:
s = "index"
case ConfigFile:
s = "config"
}
return s
}
// Handle is used to store and access data in a backend.
type Handle struct {
2023-10-01 08:52:57 +00:00
Type FileType
IsMetadata bool
Name string
}
func (h Handle) String() string {
name := h.Name
if len(name) > 10 {
name = name[:10]
}
2016-09-01 19:19:30 +00:00
return fmt.Sprintf("<%s/%s>", h.Type, name)
}
// Valid returns an error if h is not valid.
func (h Handle) Valid() error {
2016-09-01 19:19:30 +00:00
switch h.Type {
case PackFile:
case KeyFile:
case LockFile:
case SnapshotFile:
case IndexFile:
case ConfigFile:
default:
return errors.Errorf("invalid Type %d", h.Type)
}
2016-09-01 19:19:30 +00:00
if h.Type == ConfigFile {
return nil
}
if h.Name == "" {
return errors.New("invalid Name")
}
return nil
}