2020-10-31 11:02:59 +00:00
|
|
|
package workers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
2021-10-20 19:57:29 +01:00
|
|
|
|
|
|
|
"github.com/deletescape/goop/internal/utils"
|
2021-10-24 18:28:58 +01:00
|
|
|
"github.com/deletescape/jobtracker"
|
2021-10-20 19:57:29 +01:00
|
|
|
"github.com/phuslu/log"
|
|
|
|
"github.com/valyala/fasthttp"
|
2020-10-31 11:02:59 +00:00
|
|
|
)
|
|
|
|
|
2021-10-24 17:52:27 +01:00
|
|
|
type DownloadContext struct {
|
|
|
|
C *fasthttp.Client
|
|
|
|
BaseUrl string
|
|
|
|
BaseDir string
|
|
|
|
AllowHtml bool
|
|
|
|
AlllowEmpty bool
|
2020-10-31 11:02:59 +00:00
|
|
|
}
|
2021-10-20 19:57:29 +01:00
|
|
|
|
2021-10-24 17:52:27 +01:00
|
|
|
func DownloadWorker(jt *jobtracker.JobTracker, file string, context jobtracker.Context) {
|
|
|
|
c := context.(DownloadContext)
|
2021-10-20 19:57:29 +01:00
|
|
|
checkRatelimted()
|
|
|
|
|
2021-10-24 17:52:27 +01:00
|
|
|
targetFile := utils.Url(c.BaseDir, file)
|
2021-10-20 19:57:29 +01:00
|
|
|
if utils.Exists(targetFile) {
|
|
|
|
log.Info().Str("file", targetFile).Msg("already fetched, skipping redownload")
|
|
|
|
return
|
|
|
|
}
|
2021-10-24 17:52:27 +01:00
|
|
|
uri := utils.Url(c.BaseUrl, file)
|
|
|
|
code, body, err := c.C.Get(nil, uri)
|
2021-10-20 19:57:29 +01:00
|
|
|
if err == nil && code != 200 {
|
|
|
|
if code == 429 {
|
|
|
|
setRatelimited()
|
|
|
|
jt.AddJob(file)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.Warn().Str("uri", uri).Int("code", code).Msg("couldn't fetch file")
|
|
|
|
return
|
|
|
|
} else if err != nil {
|
|
|
|
log.Error().Str("uri", uri).Int("code", code).Err(err).Msg("couldn't fetch file")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-10-24 17:52:27 +01:00
|
|
|
if !c.AllowHtml && utils.IsHtml(body) {
|
2021-10-20 19:57:29 +01:00
|
|
|
log.Warn().Str("uri", uri).Msg("file appears to be html, skipping")
|
|
|
|
return
|
|
|
|
}
|
2021-10-24 17:52:27 +01:00
|
|
|
if !c.AlllowEmpty && utils.IsEmptyBytes(body) {
|
2021-10-20 19:57:29 +01:00
|
|
|
log.Warn().Str("uri", uri).Msg("file appears to be empty, skipping")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if err := utils.CreateParentFolders(targetFile); err != nil {
|
|
|
|
log.Error().Str("uri", uri).Str("file", targetFile).Err(err).Msg("couldn't create parent directories")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if err := ioutil.WriteFile(targetFile, body, os.ModePerm); err != nil {
|
|
|
|
log.Error().Str("uri", uri).Str("file", targetFile).Err(err).Msg("clouldn't write file")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.Info().Str("uri", uri).Str("file", file).Msg("fetched file")
|
|
|
|
}
|