Fix webseed requests for non-trivial path components
This commit is contained in:
parent
014cb3986b
commit
d3daaaf75a
|
@ -109,7 +109,7 @@ func readRequestPartResponses(parts []requestPart) ([]byte, error) {
|
||||||
for _, part := range parts {
|
for _, part := range parts {
|
||||||
err := recvPartResult(&buf, part)
|
err := recvPartResult(&buf, part)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return buf.Bytes(), err
|
return buf.Bytes(), fmt.Errorf("reading %q at %q: %w", part.req.URL, part.req.Header.Get("Range"), err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return buf.Bytes(), nil
|
return buf.Bytes(), nil
|
||||||
|
|
|
@ -3,6 +3,7 @@ package webseed
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"net/url"
|
||||||
"path"
|
"path"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -10,12 +11,21 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
// Creates a request per BEP 19.
|
// Creates a request per BEP 19.
|
||||||
func NewRequest(url string, fileIndex int, info *metainfo.Info, offset, length int64) (*http.Request, error) {
|
func NewRequest(url_ string, fileIndex int, info *metainfo.Info, offset, length int64) (*http.Request, error) {
|
||||||
fileInfo := info.UpvertedFiles()[fileIndex]
|
fileInfo := info.UpvertedFiles()[fileIndex]
|
||||||
if strings.HasSuffix(url, "/") {
|
if strings.HasSuffix(url_, "/") {
|
||||||
url += path.Join(append([]string{info.Name}, fileInfo.Path...)...)
|
// BEP specifies that we append the file path. We need to escape each component of the path
|
||||||
|
// for things like spaces and '#'.
|
||||||
|
url_ += path.Join(
|
||||||
|
func() (ret []string) {
|
||||||
|
for _, comp := range append([]string{info.Name}, fileInfo.Path...) {
|
||||||
|
ret = append(ret, url.PathEscape(comp))
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}()...,
|
||||||
|
)
|
||||||
}
|
}
|
||||||
req, err := http.NewRequest(http.MethodGet, url, nil)
|
req, err := http.NewRequest(http.MethodGet, url_, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue