mirror of
https://github.com/Superredstone/spotiflac-cli.git
synced 2026-03-07 20:18:07 +01:00
feat: add amazon and qobuz services
This commit is contained in:
@@ -55,6 +55,8 @@
|
|||||||
go
|
go
|
||||||
# Required for .deb build
|
# Required for .deb build
|
||||||
dpkg
|
dpkg
|
||||||
|
|
||||||
|
ffmpeg_7
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@@ -67,6 +69,10 @@
|
|||||||
src = ./.;
|
src = ./.;
|
||||||
vendorHash = "sha256-EpGgfiCqJjHEOphV2x8FmXeIFls7eq2NVxb/or4NLUo=";
|
vendorHash = "sha256-EpGgfiCqJjHEOphV2x8FmXeIFls7eq2NVxb/or4NLUo=";
|
||||||
|
|
||||||
|
dependencies = with pkgs; [
|
||||||
|
ffmpeg_7
|
||||||
|
];
|
||||||
|
|
||||||
nativeBuildInputs = with pkgs; [
|
nativeBuildInputs = with pkgs; [
|
||||||
installShellFiles
|
installShellFiles
|
||||||
];
|
];
|
||||||
|
|||||||
10
main.go
10
main.go
@@ -11,7 +11,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
var output_folder string
|
var output_folder, service string
|
||||||
|
|
||||||
application := app.NewApp()
|
application := app.NewApp()
|
||||||
|
|
||||||
@@ -32,10 +32,16 @@ func main() {
|
|||||||
Usage: "set output folder",
|
Usage: "set output folder",
|
||||||
Destination: &output_folder,
|
Destination: &output_folder,
|
||||||
},
|
},
|
||||||
|
&cli.StringFlag{
|
||||||
|
Name: "service",
|
||||||
|
Aliases: []string{"s"},
|
||||||
|
Usage: "set service to tidal/amazon/qobuz (FFmpeg is required for amazon and qobuz)",
|
||||||
|
Destination: &service,
|
||||||
|
},
|
||||||
},
|
},
|
||||||
Action: func(ctx context.Context, cmd *cli.Command) error {
|
Action: func(ctx context.Context, cmd *cli.Command) error {
|
||||||
song_url := cmd.Args().First()
|
song_url := cmd.Args().First()
|
||||||
err := pkg.Download(application, song_url, output_folder)
|
err := pkg.Download(application, song_url, output_folder, service)
|
||||||
return err
|
return err
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -13,11 +13,26 @@ const (
|
|||||||
DEFAULT_DOWNLOAD_OUTPUT_FOLDER = "."
|
DEFAULT_DOWNLOAD_OUTPUT_FOLDER = "."
|
||||||
)
|
)
|
||||||
|
|
||||||
func Download(application *app.App, url string, output_folder string) error {
|
func Download(application *app.App, url string, output_folder string, service string) error {
|
||||||
if output_folder == "" {
|
if output_folder == "" {
|
||||||
output_folder = DEFAULT_DOWNLOAD_OUTPUT_FOLDER
|
output_folder = DEFAULT_DOWNLOAD_OUTPUT_FOLDER
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if service == "" {
|
||||||
|
service = DEFAULT_DOWNLOAD_SERVICE
|
||||||
|
}
|
||||||
|
|
||||||
|
if service == "amazon" || service == "qobuz" {
|
||||||
|
isInstalled, err := application.CheckFFmpegInstalled()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if !isInstalled {
|
||||||
|
return errors.New("FFmpeg is not installed.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
url_type := GetUrlType(url)
|
url_type := GetUrlType(url)
|
||||||
|
|
||||||
switch url_type {
|
switch url_type {
|
||||||
@@ -29,7 +44,7 @@ func Download(application *app.App, url string, output_folder string) error {
|
|||||||
|
|
||||||
track := metadata.Track
|
track := metadata.Track
|
||||||
downloadRequest := app.DownloadRequest{
|
downloadRequest := app.DownloadRequest{
|
||||||
Service: DEFAULT_DOWNLOAD_SERVICE,
|
Service: service,
|
||||||
TrackName: track.Name,
|
TrackName: track.Name,
|
||||||
ArtistName: track.Artists,
|
ArtistName: track.Artists,
|
||||||
AlbumName: track.AlbumName,
|
AlbumName: track.AlbumName,
|
||||||
@@ -53,7 +68,7 @@ func Download(application *app.App, url string, output_folder string) error {
|
|||||||
fmt.Println("[" + strconv.Itoa(idx+1) + "/" + trackListSize + "] " + track.Name + " - " + track.Artists)
|
fmt.Println("[" + strconv.Itoa(idx+1) + "/" + trackListSize + "] " + track.Name + " - " + track.Artists)
|
||||||
|
|
||||||
downloadRequest := app.DownloadRequest{
|
downloadRequest := app.DownloadRequest{
|
||||||
Service: DEFAULT_DOWNLOAD_SERVICE,
|
Service: service,
|
||||||
TrackName: track.Name,
|
TrackName: track.Name,
|
||||||
ArtistName: track.Artists,
|
ArtistName: track.Artists,
|
||||||
AlbumName: track.AlbumName,
|
AlbumName: track.AlbumName,
|
||||||
|
|||||||
Reference in New Issue
Block a user