removed comment fix & moved comment fix to sort
This commit is contained in:
@@ -32,14 +32,9 @@ type NavidromeArgs struct {
|
||||
NavidromePass string `arg:"--navidrome-pass,env:ND_PASS,required"`
|
||||
}
|
||||
|
||||
type FixCommentCmd struct {
|
||||
Path string `arg:"positional,required"`
|
||||
}
|
||||
|
||||
type args struct {
|
||||
Info *InfoCmd `arg:"subcommand:info"`
|
||||
Sort *SortCmd `arg:"subcommand:sort"`
|
||||
FixCommentTag *FixCommentCmd `arg:"subcommand:fix-comment"`
|
||||
SyncPlaylists *SyncPlaylists `arg:"subcommand:sync-playlist"`
|
||||
Verbose bool `arg:"-v" default:"false"`
|
||||
DryRun bool `arg:"--dry-run" default:"false"`
|
||||
@@ -58,8 +53,6 @@ func Run() {
|
||||
ripsort.Scan(args.Info.File)
|
||||
case args.Sort != nil:
|
||||
ripsort.Sort(args.Sort.Dst, args.Sort.Path)
|
||||
case args.FixCommentTag != nil:
|
||||
ripsort.FixComment(args.FixCommentTag.Path, args.DryRun)
|
||||
case args.SyncPlaylists != nil:
|
||||
ripsort.SyncPlaylists(
|
||||
args.SyncPlaylists.SpotifyClientID,
|
||||
|
||||
@@ -1,103 +0,0 @@
|
||||
package ripsort
|
||||
|
||||
import (
|
||||
"io/fs"
|
||||
"log/slog"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"regexp"
|
||||
|
||||
"git.kapelle.org/niklas/ripsort/internal/metadata"
|
||||
)
|
||||
|
||||
func FixComment(path string, dry bool) {
|
||||
|
||||
info, err := os.Stat(path)
|
||||
if err != nil {
|
||||
slog.Error("Failed to stat path", "file", path, "err", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
// Handle single file
|
||||
if !info.IsDir() {
|
||||
if !fileSupported(path) {
|
||||
slog.Error("Unsupported file format", "file", path)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
err = fixCommentForFile(path, dry)
|
||||
if err != nil {
|
||||
slog.Error("Failed to fix comment on file", "file", path, "err", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
// Handle directory
|
||||
err = filepath.WalkDir(path, func(p string, d fs.DirEntry, err error) error {
|
||||
if err != nil {
|
||||
slog.Error("Failed to walk path", "path", path, "file", p, "err", err)
|
||||
return err
|
||||
}
|
||||
|
||||
if !d.IsDir() {
|
||||
if !fileSupported(p) {
|
||||
return nil
|
||||
}
|
||||
err = fixCommentForFile(p, dry)
|
||||
if err != nil {
|
||||
slog.Error("Failed to fix comment on file", "file", path, "err", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
return nil
|
||||
})
|
||||
|
||||
if err != nil {
|
||||
os.Exit(1)
|
||||
}
|
||||
}
|
||||
|
||||
func fixCommentForFile(file string, dry bool) error {
|
||||
|
||||
info, err := metadata.ReadAudioTags(file)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
var re = regexp.MustCompile(`(?m)(https:\/\/open\.spotify\.com\/track\/)(.*)`)
|
||||
|
||||
if info.Comment == nil {
|
||||
slog.Debug("Song does not contain comment", "file", file)
|
||||
return nil
|
||||
}
|
||||
|
||||
matches := re.FindAllStringSubmatch(*info.Comment, -1)
|
||||
|
||||
if len(matches) != 1 {
|
||||
slog.Debug("Song does not match regex", "file", file, "comment", info.Comment)
|
||||
return nil
|
||||
}
|
||||
|
||||
id := matches[0][2]
|
||||
|
||||
slog.Debug("Spotify tag found", "file", file, "id", id)
|
||||
|
||||
if dry {
|
||||
slog.Info("Dryrun: Don't wite id", "file", file, "id", id)
|
||||
return nil
|
||||
}
|
||||
|
||||
info.SpotifyID = &id
|
||||
info.Comment = nil
|
||||
|
||||
err = metadata.UpdateMetadata(file, file, *info)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
@@ -5,6 +5,7 @@ import (
|
||||
"log/slog"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"regexp"
|
||||
"strings"
|
||||
|
||||
"github.com/dhowden/tag"
|
||||
@@ -62,6 +63,8 @@ func readGenericAudioTags(filePath string) (*Metadata, error) {
|
||||
Comment: &comment,
|
||||
}
|
||||
|
||||
commentToSpotifyid(info)
|
||||
|
||||
return info, nil
|
||||
}
|
||||
|
||||
@@ -89,3 +92,21 @@ func UpdateMetadata(src, dst string, m Metadata) error {
|
||||
return nil
|
||||
|
||||
}
|
||||
|
||||
func commentToSpotifyid(m *Metadata) {
|
||||
var re = regexp.MustCompile(`(?m)(https:\/\/open\.spotify\.com\/track\/)(.*)`)
|
||||
|
||||
if m.Comment == nil {
|
||||
return
|
||||
}
|
||||
|
||||
matches := re.FindAllStringSubmatch(*m.Comment, -1)
|
||||
|
||||
if len(matches) != 1 {
|
||||
return
|
||||
}
|
||||
|
||||
id := matches[0][2]
|
||||
|
||||
m.SpotifyID = &id
|
||||
}
|
||||
|
||||
@@ -105,6 +105,8 @@ func readVorbisMetadata(file string) (*Metadata, error) {
|
||||
ISRC: isrc,
|
||||
}
|
||||
|
||||
commentToSpotifyid(metadata)
|
||||
|
||||
return metadata, nil
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user