2022-08-28 11:21:57 +00:00
|
|
|
// Package rcat provides the rcat command.
|
2017-08-03 19:42:35 +00:00
|
|
|
package rcat
|
|
|
|
|
|
|
|
import (
|
2019-06-17 08:34:30 +00:00
|
|
|
"context"
|
2017-08-03 19:42:35 +00:00
|
|
|
"os"
|
|
|
|
"time"
|
|
|
|
|
2019-07-28 17:47:38 +00:00
|
|
|
"github.com/rclone/rclone/cmd"
|
2024-08-18 14:58:35 +00:00
|
|
|
"github.com/rclone/rclone/fs"
|
2021-04-13 11:25:47 +00:00
|
|
|
"github.com/rclone/rclone/fs/config/flags"
|
2019-07-28 17:47:38 +00:00
|
|
|
"github.com/rclone/rclone/fs/operations"
|
2017-08-03 19:42:35 +00:00
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
2021-04-13 11:25:47 +00:00
|
|
|
var (
|
|
|
|
size = int64(-1)
|
|
|
|
)
|
|
|
|
|
2017-08-03 19:42:35 +00:00
|
|
|
func init() {
|
2019-10-11 15:58:11 +00:00
|
|
|
cmd.Root.AddCommand(commandDefinition)
|
2021-04-13 11:25:47 +00:00
|
|
|
cmdFlags := commandDefinition.Flags()
|
2023-07-10 17:34:10 +00:00
|
|
|
flags.Int64VarP(cmdFlags, &size, "size", "", size, "File size hint to preallocate", "")
|
2017-08-03 19:42:35 +00:00
|
|
|
}
|
|
|
|
|
2019-10-11 15:58:11 +00:00
|
|
|
var commandDefinition = &cobra.Command{
|
2017-08-03 19:42:35 +00:00
|
|
|
Use: "rcat remote:path",
|
|
|
|
Short: `Copies standard input to file on remote.`,
|
2024-08-12 16:17:46 +00:00
|
|
|
Long: `Reads from standard input (stdin) and copies it to a single remote file.
|
2017-08-03 19:42:35 +00:00
|
|
|
|
|
|
|
echo "hello world" | rclone rcat remote:path/to/file
|
2018-06-14 10:29:53 +00:00
|
|
|
ffmpeg - | rclone rcat remote:path/to/file
|
2017-09-11 06:26:53 +00:00
|
|
|
|
|
|
|
If the remote file already exists, it will be overwritten.
|
|
|
|
|
|
|
|
rcat will try to upload small files in a single request, which is
|
|
|
|
usually more efficient than the streaming/chunked upload endpoints,
|
|
|
|
which use multiple requests. Exact behaviour depends on the remote.
|
|
|
|
What is considered a small file may be set through
|
|
|
|
` + "`--streaming-upload-cutoff`" + `. Uploading only starts after
|
|
|
|
the cutoff is reached or if the file ends before that. The data
|
|
|
|
must fit into RAM. The cutoff needs to be small enough to adhere
|
|
|
|
the limits of your remote, please see there. Generally speaking,
|
|
|
|
setting this cutoff too high will decrease your performance.
|
|
|
|
|
2022-06-19 17:55:37 +00:00
|
|
|
Use the ` + "`--size`" + ` flag to preallocate the file in advance at the remote end
|
2021-04-13 11:25:47 +00:00
|
|
|
and actually stream it, even if remote backend doesn't support streaming.
|
|
|
|
|
2022-06-19 17:55:37 +00:00
|
|
|
` + "`--size`" + ` should be the exact size of the input stream in bytes. If the
|
|
|
|
size of the stream is different in length to the ` + "`--size`" + ` passed in
|
2021-04-13 11:25:47 +00:00
|
|
|
then the transfer will likely fail.
|
|
|
|
|
2023-03-17 10:51:19 +00:00
|
|
|
Note that the upload cannot be retried because the data is not stored.
|
|
|
|
If the backend supports multipart uploading then individual chunks can
|
|
|
|
be retried. If you need to transfer a lot of data, you may be better
|
|
|
|
off caching it locally and then ` + "`rclone move`" + ` it to the
|
|
|
|
destination which can use retries.`,
|
2022-11-26 22:40:49 +00:00
|
|
|
Annotations: map[string]string{
|
|
|
|
"versionIntroduced": "v1.38",
|
2023-07-10 17:34:10 +00:00
|
|
|
"groups": "Important",
|
2022-11-26 22:40:49 +00:00
|
|
|
},
|
2017-08-03 19:42:35 +00:00
|
|
|
Run: func(command *cobra.Command, args []string) {
|
|
|
|
cmd.CheckArgs(1, 1, command, args)
|
|
|
|
|
|
|
|
stat, _ := os.Stdin.Stat()
|
|
|
|
if (stat.Mode() & os.ModeCharDevice) != 0 {
|
2024-08-18 14:58:35 +00:00
|
|
|
fs.Fatalf(nil, "nothing to read from standard input (stdin).")
|
2017-08-03 19:42:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fdst, dstFileName := cmd.NewFsDstFile(args)
|
|
|
|
cmd.Run(false, false, command, func() error {
|
2022-11-08 17:42:18 +00:00
|
|
|
_, err := operations.RcatSize(context.Background(), fdst, dstFileName, os.Stdin, size, time.Now(), nil)
|
2017-09-16 20:49:08 +00:00
|
|
|
return err
|
2017-08-03 19:42:35 +00:00
|
|
|
})
|
|
|
|
},
|
|
|
|
}
|