mirror of https://github.com/gabehf/Koito.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
119 lines
3.9 KiB
119 lines
3.9 KiB
package handlers
|
|
|
|
import (
|
|
"net/http"
|
|
"strconv"
|
|
|
|
"github.com/gabehf/koito/internal/db"
|
|
"github.com/gabehf/koito/internal/logger"
|
|
"github.com/gabehf/koito/internal/utils"
|
|
)
|
|
|
|
func MergeTracksHandler(store db.DB) http.HandlerFunc {
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
l := logger.FromContext(r.Context())
|
|
|
|
l.Debug().Msg("MergeTracksHandler: Received request to merge tracks")
|
|
|
|
fromidStr := r.URL.Query().Get("from_id")
|
|
fromId, err := strconv.Atoi(fromidStr)
|
|
if err != nil {
|
|
l.Debug().AnErr("error", err).Msg("MergeTracksHandler: Invalid from_id parameter")
|
|
utils.WriteError(w, "from_id is invalid", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
toidStr := r.URL.Query().Get("to_id")
|
|
toId, err := strconv.Atoi(toidStr)
|
|
if err != nil {
|
|
l.Debug().AnErr("error", err).Msg("MergeTracksHandler: Invalid to_id parameter")
|
|
utils.WriteError(w, "to_id is invalid", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
l.Debug().Msgf("MergeTracksHandler: Merging tracks from ID %d to ID %d", fromId, toId)
|
|
|
|
err = store.MergeTracks(r.Context(), int32(fromId), int32(toId))
|
|
if err != nil {
|
|
l.Err(err).Msg("MergeTracksHandler: Failed to merge tracks")
|
|
utils.WriteError(w, "Failed to merge tracks: "+err.Error(), http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
l.Debug().Msgf("MergeTracksHandler: Successfully merged tracks from ID %d to ID %d", fromId, toId)
|
|
w.WriteHeader(http.StatusNoContent)
|
|
}
|
|
}
|
|
|
|
func MergeReleaseGroupsHandler(store db.DB) http.HandlerFunc {
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
l := logger.FromContext(r.Context())
|
|
|
|
l.Debug().Msg("MergeReleaseGroupsHandler: Received request to merge release groups")
|
|
|
|
fromidStr := r.URL.Query().Get("from_id")
|
|
fromId, err := strconv.Atoi(fromidStr)
|
|
if err != nil {
|
|
l.Debug().AnErr("error", err).Msg("MergeReleaseGroupsHandler: Invalid from_id parameter")
|
|
utils.WriteError(w, "from_id is invalid", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
toidStr := r.URL.Query().Get("to_id")
|
|
toId, err := strconv.Atoi(toidStr)
|
|
if err != nil {
|
|
l.Debug().AnErr("error", err).Msg("MergeReleaseGroupsHandler: Invalid to_id parameter")
|
|
utils.WriteError(w, "to_id is invalid", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
l.Debug().Msgf("MergeReleaseGroupsHandler: Merging release groups from ID %d to ID %d", fromId, toId)
|
|
|
|
err = store.MergeAlbums(r.Context(), int32(fromId), int32(toId))
|
|
if err != nil {
|
|
l.Err(err).Msg("MergeReleaseGroupsHandler: Failed to merge release groups")
|
|
utils.WriteError(w, "Failed to merge release groups: "+err.Error(), http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
l.Debug().Msgf("MergeReleaseGroupsHandler: Successfully merged release groups from ID %d to ID %d", fromId, toId)
|
|
w.WriteHeader(http.StatusNoContent)
|
|
}
|
|
}
|
|
|
|
func MergeArtistsHandler(store db.DB) http.HandlerFunc {
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
l := logger.FromContext(r.Context())
|
|
|
|
l.Debug().Msg("MergeArtistsHandler: Received request to merge artists")
|
|
|
|
fromidStr := r.URL.Query().Get("from_id")
|
|
fromId, err := strconv.Atoi(fromidStr)
|
|
if err != nil {
|
|
l.Debug().AnErr("error", err).Msg("MergeArtistsHandler: Invalid from_id parameter")
|
|
utils.WriteError(w, "from_id is invalid", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
toidStr := r.URL.Query().Get("to_id")
|
|
toId, err := strconv.Atoi(toidStr)
|
|
if err != nil {
|
|
l.Debug().AnErr("error", err).Msg("MergeArtistsHandler: Invalid to_id parameter")
|
|
utils.WriteError(w, "to_id is invalid", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
l.Debug().Msgf("MergeArtistsHandler: Merging artists from ID %d to ID %d", fromId, toId)
|
|
|
|
err = store.MergeArtists(r.Context(), int32(fromId), int32(toId))
|
|
if err != nil {
|
|
l.Err(err).Msg("MergeArtistsHandler: Failed to merge artists")
|
|
utils.WriteError(w, "Failed to merge artists: "+err.Error(), http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
l.Debug().Msgf("MergeArtistsHandler: Successfully merged artists from ID %d to ID %d", fromId, toId)
|
|
w.WriteHeader(http.StatusNoContent)
|
|
}
|
|
}
|