mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-05 05:27:37 +03:00
Make "ByPath" queries case-sensitive
This commit is contained in:
parent
1ef0869a54
commit
8b20c26e04
2 changed files with 19 additions and 7 deletions
|
@ -5,7 +5,6 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
|
||||||
|
|
||||||
. "github.com/Masterminds/squirrel"
|
. "github.com/Masterminds/squirrel"
|
||||||
"github.com/astaxie/beego/orm"
|
"github.com/astaxie/beego/orm"
|
||||||
|
@ -95,11 +94,9 @@ func (r mediaFileRepository) FindByPath(path string) (model.MediaFiles, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func pathStartsWith(path string) Sqlizer {
|
func pathStartsWith(path string) Sqlizer {
|
||||||
escapeChar := string(os.PathListSeparator)
|
cleanPath := filepath.Clean(path)
|
||||||
escapedPath := strings.ReplaceAll(path, escapeChar, escapeChar+escapeChar)
|
substr := fmt.Sprintf("substr(path, 1, %d)", len(cleanPath))
|
||||||
escapedPath = strings.ReplaceAll(escapedPath, "_", escapeChar+"_")
|
return Eq{substr: cleanPath}
|
||||||
escapedPath = strings.ReplaceAll(escapedPath, "%", escapeChar+"%")
|
|
||||||
return ConcatExpr(Like{"path": filepath.Join(escapedPath, "%")}, " escape '"+escapeChar+"'")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// FindPathsRecursively returns a list of all subfolders of basePath, recursively
|
// FindPathsRecursively returns a list of all subfolders of basePath, recursively
|
||||||
|
|
|
@ -51,7 +51,7 @@ var _ = Describe("MediaRepository", func() {
|
||||||
Expect(mr.FindByAlbum("67")).To(Equal(model.MediaFiles{}))
|
Expect(mr.FindByAlbum("67")).To(Equal(model.MediaFiles{}))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("finds tracks by path", func() {
|
It("finds tracks by path when using wildcards chars", func() {
|
||||||
Expect(mr.Put(&model.MediaFile{ID: "7001", Path: P("/Find:By'Path/_/123.mp3")})).To(BeNil())
|
Expect(mr.Put(&model.MediaFile{ID: "7001", Path: P("/Find:By'Path/_/123.mp3")})).To(BeNil())
|
||||||
Expect(mr.Put(&model.MediaFile{ID: "7002", Path: P("/Find:By'Path/1/123.mp3")})).To(BeNil())
|
Expect(mr.Put(&model.MediaFile{ID: "7002", Path: P("/Find:By'Path/1/123.mp3")})).To(BeNil())
|
||||||
|
|
||||||
|
@ -61,6 +61,21 @@ var _ = Describe("MediaRepository", func() {
|
||||||
Expect(found[0].ID).To(Equal("7001"))
|
Expect(found[0].ID).To(Equal("7001"))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("finds tracks by path case sensitively", func() {
|
||||||
|
Expect(mr.Put(&model.MediaFile{ID: "7003", Path: P("/Casesensitive/file1.mp3")})).To(BeNil())
|
||||||
|
Expect(mr.Put(&model.MediaFile{ID: "7004", Path: P("/casesensitive/file2.mp3")})).To(BeNil())
|
||||||
|
|
||||||
|
found, err := mr.FindByPath(P("/Casesensitive"))
|
||||||
|
Expect(err).To(BeNil())
|
||||||
|
Expect(found).To(HaveLen(1))
|
||||||
|
Expect(found[0].ID).To(Equal("7003"))
|
||||||
|
|
||||||
|
found, err = mr.FindByPath(P("/casesensitive/"))
|
||||||
|
Expect(err).To(BeNil())
|
||||||
|
Expect(found).To(HaveLen(1))
|
||||||
|
Expect(found[0].ID).To(Equal("7004"))
|
||||||
|
})
|
||||||
|
|
||||||
It("returns starred tracks", func() {
|
It("returns starred tracks", func() {
|
||||||
Expect(mr.GetStarred()).To(Equal(model.MediaFiles{
|
Expect(mr.GetStarred()).To(Equal(model.MediaFiles{
|
||||||
songComeTogether,
|
songComeTogether,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue