mirror of
https://github.com/navidrome/navidrome.git
synced 2025-06-04 17:41:15 +03:00
Use Gravatar in GetAvatar Subsonic API
This commit is contained in:
parent
a4ef31251d
commit
b64bb706f7
@ -171,7 +171,11 @@ func h(r chi.Router, path string, f handler) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
// If it is not a Subsonic error, convert it to an ErrorGeneric
|
// If it is not a Subsonic error, convert it to an ErrorGeneric
|
||||||
if _, ok := err.(subError); !ok {
|
if _, ok := err.(subError); !ok {
|
||||||
err = newError(responses.ErrorGeneric, "Internal Error")
|
if err == model.ErrNotFound {
|
||||||
|
err = newError(responses.ErrorDataNotFound, "data not found")
|
||||||
|
} else {
|
||||||
|
err = newError(responses.ErrorGeneric, "Internal Error")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
sendError(w, r, err)
|
sendError(w, r, err)
|
||||||
return
|
return
|
||||||
|
@ -4,8 +4,10 @@ import (
|
|||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/deluan/navidrome/conf"
|
||||||
"github.com/deluan/navidrome/consts"
|
"github.com/deluan/navidrome/consts"
|
||||||
"github.com/deluan/navidrome/core"
|
"github.com/deluan/navidrome/core"
|
||||||
|
"github.com/deluan/navidrome/core/gravatar"
|
||||||
"github.com/deluan/navidrome/log"
|
"github.com/deluan/navidrome/log"
|
||||||
"github.com/deluan/navidrome/model"
|
"github.com/deluan/navidrome/model"
|
||||||
"github.com/deluan/navidrome/resources"
|
"github.com/deluan/navidrome/resources"
|
||||||
@ -15,13 +17,35 @@ import (
|
|||||||
|
|
||||||
type MediaRetrievalController struct {
|
type MediaRetrievalController struct {
|
||||||
artwork core.Artwork
|
artwork core.Artwork
|
||||||
|
ds model.DataStore
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewMediaRetrievalController(artwork core.Artwork) *MediaRetrievalController {
|
func NewMediaRetrievalController(artwork core.Artwork, ds model.DataStore) *MediaRetrievalController {
|
||||||
return &MediaRetrievalController{artwork: artwork}
|
return &MediaRetrievalController{artwork: artwork, ds: ds}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *MediaRetrievalController) GetAvatar(w http.ResponseWriter, r *http.Request) (*responses.Subsonic, error) {
|
func (c *MediaRetrievalController) GetAvatar(w http.ResponseWriter, r *http.Request) (*responses.Subsonic, error) {
|
||||||
|
if !conf.Server.EnableGravatar {
|
||||||
|
return c.getPlaceHolderAvatar(w, r)
|
||||||
|
}
|
||||||
|
username, err := requiredParamString(r, "username")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
ctx := r.Context()
|
||||||
|
u, err := c.ds.User(ctx).FindByUsername(username)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if u.Email == "" {
|
||||||
|
log.Warn(ctx, "User needs an email for gravatar to work", "username", username)
|
||||||
|
return c.getPlaceHolderAvatar(w, r)
|
||||||
|
}
|
||||||
|
http.Redirect(w, r, gravatar.Url(u.Email, 0), http.StatusFound)
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *MediaRetrievalController) getPlaceHolderAvatar(w http.ResponseWriter, r *http.Request) (*responses.Subsonic, error) {
|
||||||
f, err := resources.AssetFile().Open(consts.PlaceholderAvatar)
|
f, err := resources.AssetFile().Open(consts.PlaceholderAvatar)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error(r, "Image not found", err)
|
log.Error(r, "Image not found", err)
|
||||||
|
@ -7,6 +7,7 @@ import (
|
|||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
|
|
||||||
"github.com/deluan/navidrome/model"
|
"github.com/deluan/navidrome/model"
|
||||||
|
"github.com/deluan/navidrome/tests"
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
. "github.com/onsi/gomega"
|
. "github.com/onsi/gomega"
|
||||||
)
|
)
|
||||||
@ -18,7 +19,7 @@ var _ = Describe("MediaRetrievalController", func() {
|
|||||||
|
|
||||||
BeforeEach(func() {
|
BeforeEach(func() {
|
||||||
artwork = &fakeArtwork{}
|
artwork = &fakeArtwork{}
|
||||||
controller = NewMediaRetrievalController(artwork)
|
controller = NewMediaRetrievalController(artwork, &tests.MockDataStore{})
|
||||||
w = httptest.NewRecorder()
|
w = httptest.NewRecorder()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -57,7 +57,8 @@ func initUsersController(router *Router) *UsersController {
|
|||||||
|
|
||||||
func initMediaRetrievalController(router *Router) *MediaRetrievalController {
|
func initMediaRetrievalController(router *Router) *MediaRetrievalController {
|
||||||
artwork := router.Artwork
|
artwork := router.Artwork
|
||||||
mediaRetrievalController := NewMediaRetrievalController(artwork)
|
dataStore := router.DataStore
|
||||||
|
mediaRetrievalController := NewMediaRetrievalController(artwork, dataStore)
|
||||||
return mediaRetrievalController
|
return mediaRetrievalController
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user