Replace gg.If with cmp.Or

This commit is contained in:
Deluan 2024-06-05 22:48:00 -04:00
parent 11bef060a3
commit b4ef1b1e38
5 changed files with 6 additions and 47 deletions

View file

@ -12,11 +12,9 @@ import (
"time" "time"
"github.com/go-chi/chi/v5" "github.com/go-chi/chi/v5"
"github.com/go-chi/chi/v5/middleware"
"github.com/go-chi/cors" "github.com/go-chi/cors"
"github.com/navidrome/navidrome/conf" "github.com/navidrome/navidrome/conf"
. "github.com/navidrome/navidrome/utils/gg"
"github.com/go-chi/chi/v5/middleware"
"github.com/navidrome/navidrome/consts" "github.com/navidrome/navidrome/consts"
"github.com/navidrome/navidrome/log" "github.com/navidrome/navidrome/log"
"github.com/navidrome/navidrome/model/request" "github.com/navidrome/navidrome/model/request"
@ -139,7 +137,7 @@ func clientUniqueIDMiddleware(next http.Handler) http.Handler {
HttpOnly: true, HttpOnly: true,
Secure: true, Secure: true,
SameSite: http.SameSiteStrictMode, SameSite: http.SameSiteStrictMode,
Path: If(conf.Server.BasePath, "/"), Path: cmp.Or(conf.Server.BasePath, "/"),
} }
http.SetCookie(w, c) http.SetCookie(w, c)
} else { } else {

View file

@ -1,6 +1,7 @@
package server package server
import ( import (
"cmp"
"context" "context"
"errors" "errors"
"fmt" "fmt"
@ -23,7 +24,6 @@ import (
"github.com/navidrome/navidrome/model" "github.com/navidrome/navidrome/model"
"github.com/navidrome/navidrome/server/events" "github.com/navidrome/navidrome/server/events"
"github.com/navidrome/navidrome/ui" "github.com/navidrome/navidrome/ui"
. "github.com/navidrome/navidrome/utils/gg"
) )
type Server struct { type Server struct {
@ -237,7 +237,7 @@ func AbsoluteURL(r *http.Request, u string, params url.Values) string {
if strings.HasPrefix(u, "/") { if strings.HasPrefix(u, "/") {
buildUrl.Path = path.Join(conf.Server.BasePath, buildUrl.Path) buildUrl.Path = path.Join(conf.Server.BasePath, buildUrl.Path)
if conf.Server.BaseHost != "" { if conf.Server.BaseHost != "" {
buildUrl.Scheme = If(conf.Server.BaseScheme, "http") buildUrl.Scheme = cmp.Or(conf.Server.BaseScheme, "http")
buildUrl.Host = conf.Server.BaseHost buildUrl.Host = conf.Server.BaseHost
} else { } else {
buildUrl.Scheme = r.URL.Scheme buildUrl.Scheme = r.URL.Scheme

View file

@ -1,6 +1,7 @@
package subsonic package subsonic
import ( import (
"cmp"
"crypto/md5" "crypto/md5"
"encoding/hex" "encoding/hex"
"errors" "errors"
@ -20,7 +21,6 @@ import (
"github.com/navidrome/navidrome/model/request" "github.com/navidrome/navidrome/model/request"
"github.com/navidrome/navidrome/server" "github.com/navidrome/navidrome/server"
"github.com/navidrome/navidrome/server/subsonic/responses" "github.com/navidrome/navidrome/server/subsonic/responses"
. "github.com/navidrome/navidrome/utils/gg"
"github.com/navidrome/navidrome/utils/req" "github.com/navidrome/navidrome/utils/req"
) )
@ -183,7 +183,7 @@ func getPlayer(players core.Players) func(next http.Handler) http.Handler {
MaxAge: consts.CookieExpiry, MaxAge: consts.CookieExpiry,
HttpOnly: true, HttpOnly: true,
SameSite: http.SameSiteStrictMode, SameSite: http.SameSiteStrictMode,
Path: If(conf.Server.BasePath, "/"), Path: cmp.Or(conf.Server.BasePath, "/"),
} }
http.SetCookie(w, cookie) http.SetCookie(w, cookie)
} }

View file

@ -1,18 +1,6 @@
// Package gg implements simple "extensions" to Go language. Based on https://github.com/icza/gog // Package gg implements simple "extensions" to Go language. Based on https://github.com/icza/gog
package gg package gg
// If returns v if it is a non-zero value, orElse otherwise.
//
// This is similar to elvis operator (?:) in Groovy and other languages.
// Note: Different from the real elvis operator, the orElse expression will always get evaluated.
func If[T comparable](v T, orElse T) T {
var zero T
if v != zero {
return v
}
return orElse
}
// P returns a pointer to the input value // P returns a pointer to the input value
func P[T any](v T) *T { func P[T any](v T) *T {
return &v return &v

View file

@ -16,33 +16,6 @@ func TestGG(t *testing.T) {
} }
var _ = Describe("GG", func() { var _ = Describe("GG", func() {
Describe("If", func() {
DescribeTable("string",
func(v, orElse, expected string) {
Expect(gg.If(v, orElse)).To(Equal(expected))
},
Entry("zero value", "", "default", "default"),
Entry("non-zero value", "anything", "default", "anything"),
)
DescribeTable("numeric",
func(v, orElse, expected int) {
Expect(gg.If(v, orElse)).To(Equal(expected))
},
Entry("zero value", 0, 2, 2),
Entry("non-zero value", -1, 2, -1),
)
type testStruct struct {
field1 int
}
DescribeTable("struct",
func(v, orElse, expected testStruct) {
Expect(gg.If(v, orElse)).To(Equal(expected))
},
Entry("zero value", testStruct{}, testStruct{123}, testStruct{123}),
Entry("non-zero value", testStruct{456}, testStruct{123}, testStruct{456}),
)
})
Describe("P", func() { Describe("P", func() {
It("returns a pointer to the input value", func() { It("returns a pointer to the input value", func() {
v := 123 v := 123