forked from TrueCloudLab/restic
Allow --files-from to take a dash for stdin (fixes #769)
This commit is contained in:
parent
ec45cdba84
commit
24acb09a2a
1 changed files with 20 additions and 6 deletions
|
@ -3,6 +3,7 @@ package main
|
||||||
import (
|
import (
|
||||||
"bufio"
|
"bufio"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"restic"
|
"restic"
|
||||||
|
@ -28,6 +29,10 @@ The "backup" command creates a new snapshot and saves the files and directories
|
||||||
given as the arguments.
|
given as the arguments.
|
||||||
`,
|
`,
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
if backupOptions.Stdin && backupOptions.FilesFrom == "-" {
|
||||||
|
return errors.Fatal("cannot use both `--stdin` and `--files-from -`")
|
||||||
|
}
|
||||||
|
|
||||||
if backupOptions.Stdin {
|
if backupOptions.Stdin {
|
||||||
return readBackupFromStdin(backupOptions, globalOptions, args)
|
return readBackupFromStdin(backupOptions, globalOptions, args)
|
||||||
}
|
}
|
||||||
|
@ -266,21 +271,26 @@ func readBackupFromStdin(opts BackupOptions, gopts GlobalOptions, args []string)
|
||||||
|
|
||||||
// readFromFile will read all lines from the given filename and write them to a
|
// readFromFile will read all lines from the given filename and write them to a
|
||||||
// string array, if filename is empty readFromFile returns and empty string
|
// string array, if filename is empty readFromFile returns and empty string
|
||||||
// array
|
// array. If filename is a dash (-), readFromFile will read the lines from
|
||||||
|
// the standard input.
|
||||||
func readLinesFromFile(filename string) ([]string, error) {
|
func readLinesFromFile(filename string) ([]string, error) {
|
||||||
if filename == "" {
|
if filename == "" {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
file, err := os.Open(filename)
|
var r io.Reader = os.Stdin
|
||||||
|
if filename != "-" {
|
||||||
|
f, err := os.Open(filename)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
defer file.Close()
|
defer f.Close()
|
||||||
|
r = f
|
||||||
|
}
|
||||||
|
|
||||||
var lines []string
|
var lines []string
|
||||||
|
|
||||||
scanner := bufio.NewScanner(file)
|
scanner := bufio.NewScanner(r)
|
||||||
for scanner.Scan() {
|
for scanner.Scan() {
|
||||||
lines = append(lines, scanner.Text())
|
lines = append(lines, scanner.Text())
|
||||||
}
|
}
|
||||||
|
@ -293,6 +303,10 @@ func readLinesFromFile(filename string) ([]string, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func runBackup(opts BackupOptions, gopts GlobalOptions, args []string) error {
|
func runBackup(opts BackupOptions, gopts GlobalOptions, args []string) error {
|
||||||
|
if opts.FilesFrom == "-" && gopts.password == "" && gopts.PasswordFile == "" {
|
||||||
|
return errors.Fatal("no password; either use `--password-file` option or put the password into the RESTIC_PASSWORD environment variable")
|
||||||
|
}
|
||||||
|
|
||||||
fromfile, err := readLinesFromFile(opts.FilesFrom)
|
fromfile, err := readLinesFromFile(opts.FilesFrom)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
|
Loading…
Reference in a new issue