2022-08-28 11:21:57 +00:00
|
|
|
// Package dlnaflags provides utility functionality to DLNA.
|
2019-01-03 22:23:50 +00:00
|
|
|
package dlnaflags
|
|
|
|
|
|
|
|
import (
|
2022-10-01 09:18:50 +00:00
|
|
|
"time"
|
|
|
|
|
2024-07-03 17:14:48 +00:00
|
|
|
"github.com/rclone/rclone/fs"
|
2019-07-28 17:47:38 +00:00
|
|
|
"github.com/rclone/rclone/fs/config/flags"
|
2019-01-03 22:23:50 +00:00
|
|
|
"github.com/spf13/pflag"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Help contains the text for the command line help and manual.
|
2024-04-05 11:27:33 +00:00
|
|
|
var Help = `### Server options
|
2019-01-03 22:23:50 +00:00
|
|
|
|
2020-06-16 22:37:35 +00:00
|
|
|
Use ` + "`--addr`" + ` to specify which IP address and port the server should
|
2020-10-13 21:49:58 +00:00
|
|
|
listen on, e.g. ` + "`--addr 1.2.3.4:8000` or `--addr :8080`" + ` to listen to all
|
2019-01-03 22:23:50 +00:00
|
|
|
IPs.
|
|
|
|
|
2020-06-16 22:37:35 +00:00
|
|
|
Use ` + "`--name`" + ` to choose the friendly server name, which is by
|
2019-05-26 18:51:22 +00:00
|
|
|
default "rclone (hostname)".
|
|
|
|
|
2020-06-16 22:37:35 +00:00
|
|
|
Use ` + "`--log-trace` in conjunction with `-vv`" + ` to enable additional debug
|
2019-05-26 18:51:22 +00:00
|
|
|
logging of all UPNP traffic.
|
2024-04-05 11:27:33 +00:00
|
|
|
|
2019-01-03 22:23:50 +00:00
|
|
|
`
|
|
|
|
|
2024-07-03 17:14:48 +00:00
|
|
|
// OptionsInfo descripts the Options in use
|
|
|
|
var OptionsInfo = fs.Options{{
|
|
|
|
Name: "addr",
|
|
|
|
Default: ":7879",
|
|
|
|
Help: "The ip:port or :port to bind the DLNA http server to",
|
|
|
|
}, {
|
|
|
|
Name: "name",
|
|
|
|
Default: "",
|
|
|
|
Help: "Name of DLNA server",
|
|
|
|
}, {
|
|
|
|
Name: "log_trace",
|
|
|
|
Default: false,
|
|
|
|
Help: "Enable trace logging of SOAP traffic",
|
|
|
|
}, {
|
|
|
|
Name: "interface",
|
|
|
|
Default: []string{},
|
|
|
|
Help: "The interface to use for SSDP (repeat as necessary)",
|
|
|
|
}, {
|
|
|
|
Name: "announce_interval",
|
|
|
|
Default: fs.Duration(12 * time.Minute),
|
|
|
|
Help: "The interval between SSDP announcements",
|
|
|
|
}}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
fs.RegisterGlobalOptions(fs.OptionsInfo{Name: "dlna", Opt: &Opt, Options: OptionsInfo})
|
2019-01-03 22:23:50 +00:00
|
|
|
}
|
|
|
|
|
2024-07-03 17:14:48 +00:00
|
|
|
// Options is the type for DLNA serving options.
|
|
|
|
type Options struct {
|
|
|
|
ListenAddr string `config:"addr"`
|
|
|
|
FriendlyName string `config:"name"`
|
|
|
|
LogTrace bool `config:"log_trace"`
|
|
|
|
InterfaceNames []string `config:"interface"`
|
|
|
|
AnnounceInterval fs.Duration `config:"announce_interval"`
|
2019-01-03 22:23:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Opt contains the options for DLNA serving.
|
2024-07-03 17:14:48 +00:00
|
|
|
var Opt Options
|
2019-01-03 22:23:50 +00:00
|
|
|
|
|
|
|
// AddFlags add the command line flags for DLNA serving.
|
|
|
|
func AddFlags(flagSet *pflag.FlagSet) {
|
2024-07-03 17:14:48 +00:00
|
|
|
flags.AddFlagsFromOptions(flagSet, "", OptionsInfo)
|
2019-01-03 22:23:50 +00:00
|
|
|
}
|