forked from dzatona/getcourse-video-downloader
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
69 lines (56 loc) · 1.72 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package main
import (
"log"
"os"
"getcourse-video-downloader/internal/combiner"
"getcourse-video-downloader/internal/downloader"
"getcourse-video-downloader/internal/utils"
)
func main() {
utils.ClearScreen()
utils.PrintWelcomeMessage()
// utils.ClearParts()
log.SetFlags(log.Ldate | log.Ltime)
if len(os.Args) < 3 {
log.Println("Usage: ./getcourse-video-downloader <playlist_url> <output_file>")
return
}
playlistURL := os.Args[1]
outputFile := os.Args[2]
err := os.MkdirAll("parts", 0755)
if err != nil {
log.Println("Error creating parts directory:", err)
return
}
empty, err := utils.IsDirEmpty("parts")
if err != nil {
log.Println("Error checking if parts directory is empty:", err)
return
}
if empty {
log.Println("Downloading playlist...")
playlist, err := downloader.DownloadPlaylist(playlistURL)
if err != nil {
log.Println("Error downloading playlist:", err)
return
}
log.Printf("Found %d chunks in the playlist.\n", len(playlist)-1)
err = downloader.DownloadFiles(playlist)
if err != nil {
log.Println("Error downloading files:", err)
return
}
log.Println("Files downloaded successfully!")
} else {
log.Println("Parts directory is not empty. Skipping download.")
}
log.Println("Combining files...")
err = combiner.CombineFiles(outputFile)
if err != nil {
log.Println("Error combining files:", err)
return
}
log.Println("Files combined successfully!")
utils.ClearParts()
log.Println("Temporary files cleaned up successfully!")
}