| 
									
										
										
										
											2022-10-15 16:23:39 +02:00
										 |  |  | package layout | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-02 15:29:54 +02:00
										 |  |  | import ( | 
					
						
							|  |  |  | 	"encoding/hex" | 
					
						
							| 
									
										
										
										
											2017-07-23 14:21:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-01 11:40:12 +02:00
										 |  |  | 	"github.com/restic/restic/internal/backend" | 
					
						
							| 
									
										
										
										
											2017-07-02 15:29:54 +02:00
										 |  |  | ) | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | // DefaultLayout implements the default layout for local and sftp backends, as | 
					
						
							|  |  |  | // described in the Design document. The `data` directory has one level of | 
					
						
							|  |  |  | // subdirs, two characters each (taken from the first two characters of the | 
					
						
							|  |  |  | // file name). | 
					
						
							|  |  |  | type DefaultLayout struct { | 
					
						
							|  |  |  | 	Path string | 
					
						
							|  |  |  | 	Join func(...string) string | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-01 11:40:12 +02:00
										 |  |  | var defaultLayoutPaths = map[backend.FileType]string{ | 
					
						
							|  |  |  | 	backend.PackFile:     "data", | 
					
						
							|  |  |  | 	backend.SnapshotFile: "snapshots", | 
					
						
							|  |  |  | 	backend.IndexFile:    "index", | 
					
						
							|  |  |  | 	backend.LockFile:     "locks", | 
					
						
							|  |  |  | 	backend.KeyFile:      "keys", | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-26 20:28:39 +02:00
										 |  |  | func NewDefaultLayout(path string, join func(...string) string) *DefaultLayout { | 
					
						
							|  |  |  | 	return &DefaultLayout{ | 
					
						
							|  |  |  | 		Path: path, | 
					
						
							|  |  |  | 		Join: join, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-07 21:59:41 +02:00
										 |  |  | func (l *DefaultLayout) String() string { | 
					
						
							|  |  |  | 	return "<DefaultLayout>" | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Name returns the name for this layout. | 
					
						
							|  |  |  | func (l *DefaultLayout) Name() string { | 
					
						
							|  |  |  | 	return "default" | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | // Dirname returns the directory path for a given file type and name. | 
					
						
							| 
									
										
										
										
											2023-10-01 11:40:12 +02:00
										 |  |  | func (l *DefaultLayout) Dirname(h backend.Handle) string { | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | 	p := defaultLayoutPaths[h.Type] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-01 11:40:12 +02:00
										 |  |  | 	if h.Type == backend.PackFile && len(h.Name) > 2 { | 
					
						
							| 
									
										
										
										
											2017-05-15 23:35:52 +02:00
										 |  |  | 		p = l.Join(p, h.Name[:2]) + "/" | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-15 23:35:52 +02:00
										 |  |  | 	return l.Join(l.Path, p) + "/" | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Filename returns a path to a file, including its name. | 
					
						
							| 
									
										
										
										
											2023-10-01 11:40:12 +02:00
										 |  |  | func (l *DefaultLayout) Filename(h backend.Handle) string { | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | 	name := h.Name | 
					
						
							| 
									
										
										
										
											2023-10-01 11:40:12 +02:00
										 |  |  | 	if h.Type == backend.ConfigFile { | 
					
						
							| 
									
										
										
										
											2017-05-28 11:06:48 +02:00
										 |  |  | 		return l.Join(l.Path, "config") | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return l.Join(l.Dirname(h), name) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-02 15:29:54 +02:00
										 |  |  | // Paths returns all directory names needed for a repo. | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | func (l *DefaultLayout) Paths() (dirs []string) { | 
					
						
							|  |  |  | 	for _, p := range defaultLayoutPaths { | 
					
						
							|  |  |  | 		dirs = append(dirs, l.Join(l.Path, p)) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-07-02 15:29:54 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// also add subdirs | 
					
						
							|  |  |  | 	for i := 0; i < 256; i++ { | 
					
						
							|  |  |  | 		subdir := hex.EncodeToString([]byte{byte(i)}) | 
					
						
							| 
									
										
										
										
											2023-10-01 11:40:12 +02:00
										 |  |  | 		dirs = append(dirs, l.Join(l.Path, defaultLayoutPaths[backend.PackFile], subdir)) | 
					
						
							| 
									
										
										
										
											2017-07-02 15:29:54 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-26 22:20:10 +02:00
										 |  |  | 	return dirs | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2017-04-10 23:21:23 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Basedir returns the base dir name for type t. | 
					
						
							| 
									
										
										
										
											2023-10-01 11:40:12 +02:00
										 |  |  | func (l *DefaultLayout) Basedir(t backend.FileType) (dirname string, subdirs bool) { | 
					
						
							|  |  |  | 	if t == backend.PackFile { | 
					
						
							| 
									
										
										
										
											2017-12-14 19:13:01 +01:00
										 |  |  | 		subdirs = true | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	dirname = l.Join(l.Path, defaultLayoutPaths[t]) | 
					
						
							|  |  |  | 	return | 
					
						
							| 
									
										
										
										
											2017-04-10 23:21:23 +02:00
										 |  |  | } |