mirror of
https://github.com/rclone/rclone.git
synced 2025-01-12 17:28:46 +01:00
44 lines
1.0 KiB
Go
44 lines
1.0 KiB
Go
package link
|
||
|
||
import (
|
||
"fmt"
|
||
|
||
"github.com/ncw/rclone/cmd"
|
||
"github.com/ncw/rclone/fs/operations"
|
||
"github.com/spf13/cobra"
|
||
)
|
||
|
||
func init() {
|
||
cmd.Root.AddCommand(commandDefintion)
|
||
}
|
||
|
||
var commandDefintion = &cobra.Command{
|
||
Use: "link remote:path",
|
||
Short: `Generate public link to file/folder.`,
|
||
Long: `
|
||
rclone link will create or retrieve a public link to the given file or folder.
|
||
|
||
rclone link remote:path/to/file
|
||
rclone link remote:path/to/folder/
|
||
|
||
If successful, the last line of the output will contain the link. Exact
|
||
capabilities depend on the remote, but the link will always be created with
|
||
the least constraints – e.g. no expiry, no password protection, accessible
|
||
without account.
|
||
`,
|
||
Run: func(command *cobra.Command, args []string) {
|
||
cmd.CheckArgs(1, 1, command, args)
|
||
fsrc, remote := cmd.NewFsFile(args[0])
|
||
cmd.Run(false, false, command, func() error {
|
||
link, err := operations.PublicLink(fsrc, remote)
|
||
if err != nil {
|
||
return err
|
||
}
|
||
if link != "" {
|
||
fmt.Println(link)
|
||
}
|
||
return nil
|
||
})
|
||
},
|
||
}
|