pikpak: add option to use original file links - fixes #8246
This commit is contained in:
parent
caac95ff54
commit
51cde23e82
1 changed files with 14 additions and 9 deletions
|
@ -213,6 +213,11 @@ Fill in for rclone to use a non root folder as its starting point.
|
||||||
Default: false,
|
Default: false,
|
||||||
Help: "Only show files that are in the trash.\n\nThis will show trashed files in their original directory structure.",
|
Help: "Only show files that are in the trash.\n\nThis will show trashed files in their original directory structure.",
|
||||||
Advanced: true,
|
Advanced: true,
|
||||||
|
}, {
|
||||||
|
Name: "no_media_link",
|
||||||
|
Default: false,
|
||||||
|
Help: "Use original file links instead of media links.\n\nThis avoids issues caused by invalid media links, but may reduce download speeds.",
|
||||||
|
Advanced: true,
|
||||||
}, {
|
}, {
|
||||||
Name: "hash_memory_limit",
|
Name: "hash_memory_limit",
|
||||||
Help: "Files bigger than this will be cached on disk to calculate hash if required.",
|
Help: "Files bigger than this will be cached on disk to calculate hash if required.",
|
||||||
|
@ -286,6 +291,7 @@ type Options struct {
|
||||||
RootFolderID string `config:"root_folder_id"`
|
RootFolderID string `config:"root_folder_id"`
|
||||||
UseTrash bool `config:"use_trash"`
|
UseTrash bool `config:"use_trash"`
|
||||||
TrashedOnly bool `config:"trashed_only"`
|
TrashedOnly bool `config:"trashed_only"`
|
||||||
|
NoMediaLink bool `config:"no_media_link"`
|
||||||
HashMemoryThreshold fs.SizeSuffix `config:"hash_memory_limit"`
|
HashMemoryThreshold fs.SizeSuffix `config:"hash_memory_limit"`
|
||||||
ChunkSize fs.SizeSuffix `config:"chunk_size"`
|
ChunkSize fs.SizeSuffix `config:"chunk_size"`
|
||||||
UploadConcurrency int `config:"upload_concurrency"`
|
UploadConcurrency int `config:"upload_concurrency"`
|
||||||
|
@ -1575,19 +1581,18 @@ func (o *Object) setMetaData(info *api.File) (err error) {
|
||||||
o.md5sum = info.Md5Checksum
|
o.md5sum = info.Md5Checksum
|
||||||
if info.Links.ApplicationOctetStream != nil {
|
if info.Links.ApplicationOctetStream != nil {
|
||||||
o.link = info.Links.ApplicationOctetStream
|
o.link = info.Links.ApplicationOctetStream
|
||||||
|
if !o.fs.opt.NoMediaLink {
|
||||||
if fid := parseFileID(o.link.URL); fid != "" {
|
if fid := parseFileID(o.link.URL); fid != "" {
|
||||||
for mid, media := range info.Medias {
|
for _, media := range info.Medias {
|
||||||
if media.Link == nil {
|
if media.Link != nil && parseFileID(media.Link.URL) == fid {
|
||||||
continue
|
fs.Debugf(o, "Using a media link")
|
||||||
}
|
|
||||||
if mfid := parseFileID(media.Link.URL); fid == mfid {
|
|
||||||
fs.Debugf(o, "Using a media link from Medias[%d]", mid)
|
|
||||||
o.link = media.Link
|
o.link = media.Link
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue