mirror of
https://github.com/gabehf/Koito.git
synced 2026-04-22 20:11:50 -07:00
feat: search/merge items by id
This commit is contained in:
parent
5537b6fb89
commit
1425f7f416
9 changed files with 752 additions and 46 deletions
|
|
@ -2,6 +2,8 @@ package handlers
|
|||
|
||||
import (
|
||||
"net/http"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
||||
"github.com/gabehf/koito/internal/db"
|
||||
"github.com/gabehf/koito/internal/logger"
|
||||
|
|
@ -20,27 +22,62 @@ func SearchHandler(store db.DB) http.HandlerFunc {
|
|||
ctx := r.Context()
|
||||
l := logger.FromContext(ctx)
|
||||
q := r.URL.Query().Get("q")
|
||||
artists, err := store.SearchArtists(ctx, q)
|
||||
|
||||
l.Debug().Msgf("SearchHandler: Received search with query: %s", r.URL.Query().Encode())
|
||||
|
||||
if err != nil {
|
||||
l.Err(err).Msg("Failed to search for artists")
|
||||
utils.WriteError(w, "failed to search in database", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
albums, err := store.SearchAlbums(ctx, q)
|
||||
if err != nil {
|
||||
l.Err(err).Msg("Failed to search for albums")
|
||||
utils.WriteError(w, "failed to search in database", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
tracks, err := store.SearchTracks(ctx, q)
|
||||
if err != nil {
|
||||
l.Err(err).Msg("Failed to search for tracks")
|
||||
utils.WriteError(w, "failed to search in database", http.StatusInternalServerError)
|
||||
return
|
||||
var artists []*models.Artist
|
||||
var albums []*models.Album
|
||||
var tracks []*models.Track
|
||||
|
||||
if strings.HasPrefix(q, "id:") {
|
||||
idStr := strings.TrimPrefix(q, "id:")
|
||||
id, _ := strconv.Atoi(idStr)
|
||||
|
||||
artist, err := store.GetArtist(ctx, db.GetArtistOpts{ID: int32(id)})
|
||||
if err != nil {
|
||||
l.Debug().Msg("No artists found with id")
|
||||
}
|
||||
if artist != nil {
|
||||
artists = append(artists, artist)
|
||||
}
|
||||
|
||||
album, err := store.GetAlbum(ctx, db.GetAlbumOpts{ID: int32(id)})
|
||||
if err != nil {
|
||||
l.Debug().Msg("No albums found with id")
|
||||
}
|
||||
if album != nil {
|
||||
albums = append(albums, album)
|
||||
}
|
||||
|
||||
track, err := store.GetTrack(ctx, db.GetTrackOpts{ID: int32(id)})
|
||||
if err != nil {
|
||||
l.Debug().Msg("No tracks found with id")
|
||||
}
|
||||
if track != nil {
|
||||
tracks = append(tracks, track)
|
||||
}
|
||||
} else {
|
||||
var err error
|
||||
artists, err = store.SearchArtists(ctx, q)
|
||||
if err != nil {
|
||||
l.Err(err).Msg("Failed to search for artists")
|
||||
utils.WriteError(w, "failed to search in database", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
albums, err = store.SearchAlbums(ctx, q)
|
||||
if err != nil {
|
||||
l.Err(err).Msg("Failed to search for albums")
|
||||
utils.WriteError(w, "failed to search in database", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
tracks, err = store.SearchTracks(ctx, q)
|
||||
if err != nil {
|
||||
l.Err(err).Msg("Failed to search for tracks")
|
||||
utils.WriteError(w, "failed to search in database", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
utils.WriteJSON(w, http.StatusOK, SearchResults{
|
||||
Artists: artists,
|
||||
Albums: albums,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue