Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0016e5afa9 | ||
|
|
70f0231371 | ||
|
|
5ac21eed3a |
@@ -6,6 +6,8 @@ WORKDIR /main
|
|||||||
|
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
|
RUN test -e /main/exec-youtuber
|
||||||
|
|
||||||
ENV GOPATH=""
|
ENV GOPATH=""
|
||||||
ENV MNT="/mnt/"
|
ENV MNT="/mnt/"
|
||||||
ENTRYPOINT ["/main/exec-youtuber"]
|
ENTRYPOINT ["/main/exec-youtuber"]
|
||||||
|
|||||||
@@ -4,14 +4,16 @@ import (
|
|||||||
"local/args"
|
"local/args"
|
||||||
"local/sandbox/contact/contact"
|
"local/sandbox/contact/contact"
|
||||||
"os"
|
"os"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
Feed string
|
Feed string
|
||||||
Root string
|
Root string
|
||||||
To string
|
To string
|
||||||
Subject string
|
Subject string
|
||||||
Emailer *contact.Emailer
|
Emailer *contact.Emailer
|
||||||
|
Interval time.Duration
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@@ -28,6 +30,7 @@ func init() {
|
|||||||
|
|
||||||
as.Append(args.STRING, "feed", "feed URL", "https://www.youtube.com/feeds/videos.xml?channel_id=UCwX0AEx-qIhQ9kgtlNhyIXw")
|
as.Append(args.STRING, "feed", "feed URL", "https://www.youtube.com/feeds/videos.xml?channel_id=UCwX0AEx-qIhQ9kgtlNhyIXw")
|
||||||
as.Append(args.STRING, "root", "root to save videos", "/tmp")
|
as.Append(args.STRING, "root", "root to save videos", "/tmp")
|
||||||
|
as.Append(args.DURATION, "interval", "check interval", time.Hour)
|
||||||
|
|
||||||
if err := as.Parse(); err != nil {
|
if err := as.Parse(); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
|
|||||||
15
main.go
15
main.go
@@ -18,7 +18,7 @@ func main() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
interval := time.Minute * 30
|
interval := config.Interval
|
||||||
for true {
|
for true {
|
||||||
err := do(client)
|
err := do(client)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -45,18 +45,17 @@ func do(client *youtubedl.Client) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for _, result := range results {
|
for _, result := range results {
|
||||||
target := fmt.Sprintf(
|
seasonNumber := fmt.Sprintf("%02d%02d", result.Date.Year()-2000, result.Date.Month())
|
||||||
"s%02d%02de%02d_%s.%%(ext)s",
|
episodeNumber := fmt.Sprintf("%02d", result.Date.Day())
|
||||||
result.Date.Year()-2000,
|
season := fmt.Sprintf("Season_%s", seasonNumber)
|
||||||
result.Date.Month(),
|
episode := fmt.Sprintf("Episode_%s_-_%s", episodeNumber, strings.Join(strings.Split(result.Title, " ")[2:], "_"))
|
||||||
result.Date.Day(),
|
target := fmt.Sprintf("%s/%s.%%(ext)s", season, episode)
|
||||||
strings.Join(strings.Split(result.Title, " ")[2:], "_"),
|
|
||||||
)
|
|
||||||
target = path.Join(config.Root, target)
|
target = path.Join(config.Root, target)
|
||||||
if _, err := os.Stat(strings.ReplaceAll(target, "%(ext)s", "mp4")); !os.IsNotExist(err) {
|
if _, err := os.Stat(strings.ReplaceAll(target, "%(ext)s", "mp4")); !os.IsNotExist(err) {
|
||||||
log.Printf("already exists: %s", target)
|
log.Printf("already exists: %s", target)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
os.MkdirAll(path.Dir(target), os.ModePerm)
|
||||||
if err := client.Download(result.Link, target); err != nil {
|
if err := client.Download(result.Link, target); err != nil {
|
||||||
errs += ", " + err.Error()
|
errs += ", " + err.Error()
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user