2016-08-05 16:12:27 +00:00
|
|
|
package check
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ncw/rclone/cmd"
|
|
|
|
"github.com/ncw/rclone/fs"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
2017-02-13 10:48:26 +00:00
|
|
|
// Globals
|
|
|
|
var (
|
|
|
|
download = false
|
|
|
|
)
|
|
|
|
|
2016-08-05 16:12:27 +00:00
|
|
|
func init() {
|
2016-10-22 11:05:45 +00:00
|
|
|
cmd.Root.AddCommand(commandDefintion)
|
2017-02-13 10:48:26 +00:00
|
|
|
commandDefintion.Flags().BoolVarP(&download, "download", "", download, "Check by downloading rather than with hash.")
|
2016-08-05 16:12:27 +00:00
|
|
|
}
|
|
|
|
|
2016-10-22 11:05:45 +00:00
|
|
|
var commandDefintion = &cobra.Command{
|
2016-08-05 16:12:27 +00:00
|
|
|
Use: "check source:path dest:path",
|
|
|
|
Short: `Checks the files in the source and destination match.`,
|
|
|
|
Long: `
|
2017-02-13 10:48:26 +00:00
|
|
|
Checks the files in the source and destination match. It compares
|
|
|
|
sizes and hashes (MD5 or SHA1) and logs a report of files which don't
|
|
|
|
match. It doesn't alter the source or destination.
|
|
|
|
|
|
|
|
If you supply the --size-only flag, it will only compare the sizes not
|
|
|
|
the hashes as well. Use this for a quick check.
|
2016-08-05 16:12:27 +00:00
|
|
|
|
2017-02-13 10:48:26 +00:00
|
|
|
If you supply the --download flag, it will download the data from
|
|
|
|
both remotes and check them against each other on the fly. This can
|
|
|
|
be useful for remotes that don't support hashes or if you really want
|
|
|
|
to check all the data.
|
2016-08-05 16:12:27 +00:00
|
|
|
`,
|
|
|
|
Run: func(command *cobra.Command, args []string) {
|
|
|
|
cmd.CheckArgs(2, 2, command, args)
|
|
|
|
fsrc, fdst := cmd.NewFsSrcDst(args)
|
2016-12-04 16:52:24 +00:00
|
|
|
cmd.Run(false, false, command, func() error {
|
2017-02-13 10:48:26 +00:00
|
|
|
if download {
|
|
|
|
return fs.CheckDownload(fdst, fsrc)
|
|
|
|
}
|
2016-08-05 16:12:27 +00:00
|
|
|
return fs.Check(fdst, fsrc)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
}
|