forked from TrueCloudLab/rclone
cache: add plex_insecure option to skip certificate validation
Fixes #2215
This commit is contained in:
parent
e5663de09e
commit
3c44ef788a
2 changed files with 29 additions and 8 deletions
9
backend/cache/cache.go
vendored
9
backend/cache/cache.go
vendored
|
@ -81,6 +81,10 @@ func init() {
|
||||||
Help: "The plex token for authentication - auto set normally",
|
Help: "The plex token for authentication - auto set normally",
|
||||||
Hide: fs.OptionHideBoth,
|
Hide: fs.OptionHideBoth,
|
||||||
Advanced: true,
|
Advanced: true,
|
||||||
|
}, {
|
||||||
|
Name: "plex_insecure",
|
||||||
|
Help: "Skip all certificate verifications when connecting to the Plex server",
|
||||||
|
Advanced: true,
|
||||||
}, {
|
}, {
|
||||||
Name: "chunk_size",
|
Name: "chunk_size",
|
||||||
Help: "The size of a chunk. Lower value good for slow connections but can affect seamless reading.",
|
Help: "The size of a chunk. Lower value good for slow connections but can affect seamless reading.",
|
||||||
|
@ -195,6 +199,7 @@ type Options struct {
|
||||||
PlexUsername string `config:"plex_username"`
|
PlexUsername string `config:"plex_username"`
|
||||||
PlexPassword string `config:"plex_password"`
|
PlexPassword string `config:"plex_password"`
|
||||||
PlexToken string `config:"plex_token"`
|
PlexToken string `config:"plex_token"`
|
||||||
|
PlexInsecure bool `config:"plex_insecure"`
|
||||||
ChunkSize fs.SizeSuffix `config:"chunk_size"`
|
ChunkSize fs.SizeSuffix `config:"chunk_size"`
|
||||||
InfoAge fs.Duration `config:"info_age"`
|
InfoAge fs.Duration `config:"info_age"`
|
||||||
ChunkTotalSize fs.SizeSuffix `config:"chunk_total_size"`
|
ChunkTotalSize fs.SizeSuffix `config:"chunk_total_size"`
|
||||||
|
@ -297,7 +302,7 @@ func NewFs(name, rootPath string, m configmap.Mapper) (fs.Fs, error) {
|
||||||
f.plexConnector = &plexConnector{}
|
f.plexConnector = &plexConnector{}
|
||||||
if opt.PlexURL != "" {
|
if opt.PlexURL != "" {
|
||||||
if opt.PlexToken != "" {
|
if opt.PlexToken != "" {
|
||||||
f.plexConnector, err = newPlexConnectorWithToken(f, opt.PlexURL, opt.PlexToken)
|
f.plexConnector, err = newPlexConnectorWithToken(f, opt.PlexURL, opt.PlexToken, opt.PlexInsecure)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Wrapf(err, "failed to connect to the Plex API %v", opt.PlexURL)
|
return nil, errors.Wrapf(err, "failed to connect to the Plex API %v", opt.PlexURL)
|
||||||
}
|
}
|
||||||
|
@ -307,7 +312,7 @@ func NewFs(name, rootPath string, m configmap.Mapper) (fs.Fs, error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
decPass = opt.PlexPassword
|
decPass = opt.PlexPassword
|
||||||
}
|
}
|
||||||
f.plexConnector, err = newPlexConnector(f, opt.PlexURL, opt.PlexUsername, decPass, func(token string) {
|
f.plexConnector, err = newPlexConnector(f, opt.PlexURL, opt.PlexUsername, decPass, opt.PlexInsecure, func(token string) {
|
||||||
m.Set("plex_token", token)
|
m.Set("plex_token", token)
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
28
backend/cache/plex.go
vendored
28
backend/cache/plex.go
vendored
|
@ -3,6 +3,7 @@
|
||||||
package cache
|
package cache
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"crypto/tls"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
@ -54,6 +55,7 @@ type plexConnector struct {
|
||||||
username string
|
username string
|
||||||
password string
|
password string
|
||||||
token string
|
token string
|
||||||
|
insecure bool
|
||||||
f *Fs
|
f *Fs
|
||||||
mu sync.Mutex
|
mu sync.Mutex
|
||||||
running bool
|
running bool
|
||||||
|
@ -63,7 +65,7 @@ type plexConnector struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// newPlexConnector connects to a Plex server and generates a token
|
// newPlexConnector connects to a Plex server and generates a token
|
||||||
func newPlexConnector(f *Fs, plexURL, username, password string, saveToken func(string)) (*plexConnector, error) {
|
func newPlexConnector(f *Fs, plexURL, username, password string, insecure bool, saveToken func(string)) (*plexConnector, error) {
|
||||||
u, err := url.ParseRequestURI(strings.TrimRight(plexURL, "/"))
|
u, err := url.ParseRequestURI(strings.TrimRight(plexURL, "/"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -75,6 +77,7 @@ func newPlexConnector(f *Fs, plexURL, username, password string, saveToken func(
|
||||||
username: username,
|
username: username,
|
||||||
password: password,
|
password: password,
|
||||||
token: "",
|
token: "",
|
||||||
|
insecure: insecure,
|
||||||
stateCache: cache.New(time.Hour, time.Minute),
|
stateCache: cache.New(time.Hour, time.Minute),
|
||||||
saveToken: saveToken,
|
saveToken: saveToken,
|
||||||
}
|
}
|
||||||
|
@ -83,7 +86,7 @@ func newPlexConnector(f *Fs, plexURL, username, password string, saveToken func(
|
||||||
}
|
}
|
||||||
|
|
||||||
// newPlexConnector connects to a Plex server and generates a token
|
// newPlexConnector connects to a Plex server and generates a token
|
||||||
func newPlexConnectorWithToken(f *Fs, plexURL, token string) (*plexConnector, error) {
|
func newPlexConnectorWithToken(f *Fs, plexURL, token string, insecure bool) (*plexConnector, error) {
|
||||||
u, err := url.ParseRequestURI(strings.TrimRight(plexURL, "/"))
|
u, err := url.ParseRequestURI(strings.TrimRight(plexURL, "/"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -93,6 +96,7 @@ func newPlexConnectorWithToken(f *Fs, plexURL, token string) (*plexConnector, er
|
||||||
f: f,
|
f: f,
|
||||||
url: u,
|
url: u,
|
||||||
token: token,
|
token: token,
|
||||||
|
insecure: insecure,
|
||||||
stateCache: cache.New(time.Hour, time.Minute),
|
stateCache: cache.New(time.Hour, time.Minute),
|
||||||
}
|
}
|
||||||
pc.listenWebsocket()
|
pc.listenWebsocket()
|
||||||
|
@ -107,14 +111,26 @@ func (p *plexConnector) closeWebsocket() {
|
||||||
p.running = false
|
p.running = false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p *plexConnector) websocketDial() (*websocket.Conn, error) {
|
||||||
|
u := strings.TrimRight(strings.Replace(strings.Replace(
|
||||||
|
p.url.String(), "http://", "ws://", 1), "https://", "wss://", 1), "/")
|
||||||
|
url := fmt.Sprintf(defPlexNotificationURL, u, p.token)
|
||||||
|
|
||||||
|
config, err := websocket.NewConfig(url, "http://localhost")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if p.insecure {
|
||||||
|
config.TlsConfig = &tls.Config{InsecureSkipVerify: true}
|
||||||
|
}
|
||||||
|
return websocket.DialConfig(config)
|
||||||
|
}
|
||||||
|
|
||||||
func (p *plexConnector) listenWebsocket() {
|
func (p *plexConnector) listenWebsocket() {
|
||||||
p.runningMu.Lock()
|
p.runningMu.Lock()
|
||||||
defer p.runningMu.Unlock()
|
defer p.runningMu.Unlock()
|
||||||
|
|
||||||
u := strings.Replace(p.url.String(), "http://", "ws://", 1)
|
conn, err := p.websocketDial()
|
||||||
u = strings.Replace(u, "https://", "wss://", 1)
|
|
||||||
conn, err := websocket.Dial(fmt.Sprintf(defPlexNotificationURL, strings.TrimRight(u, "/"), p.token),
|
|
||||||
"", "http://localhost")
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fs.Errorf("plex", "%v", err)
|
fs.Errorf("plex", "%v", err)
|
||||||
return
|
return
|
||||||
|
|
Loading…
Reference in a new issue