From f8d04462f933ca8b2e3fcc04782a03b27d6a40ab Mon Sep 17 00:00:00 2001 From: Joe Mooring Date: Sat, 29 Jan 2022 18:34:27 -0800 Subject: [PATCH] Fix validation of Page Kind in cascade target map Fixes #8888 --- resources/page/page_matcher.go | 16 ++++++++++++---- resources/page/page_matcher_test.go | 7 ++++++- 2 files changed, 18 insertions(+), 5 deletions(-) diff --git a/resources/page/page_matcher.go b/resources/page/page_matcher.go index 0c4c2d0e29e..19a0e5fee69 100644 --- a/resources/page/page_matcher.go +++ b/resources/page/page_matcher.go @@ -17,11 +17,10 @@ import ( "path/filepath" "strings" - "github.com/pkg/errors" - "github.com/gohugoio/hugo/common/maps" "github.com/gohugoio/hugo/hugofs/glob" "github.com/mitchellh/mapstructure" + "github.com/pkg/errors" ) // A PageMatcher can be used to match a Page with Glob patterns. @@ -114,8 +113,17 @@ func DecodePageMatcher(m interface{}, v *PageMatcher) error { v.Kind = strings.ToLower(v.Kind) if v.Kind != "" { - if _, found := kindMap[v.Kind]; !found { - return errors.Errorf("%q is not a valid Page Kind", v.Kind) + g, _ := glob.GetGlob(v.Kind) + // TODO figure out what to with e_err above, if anything + found := false + for _, k := range kindMap { + if g.Match(k) { + found = true + break + } + } + if !found { + return errors.Errorf("%q did not match a valid Page Kind", v.Kind) } } diff --git a/resources/page/page_matcher_test.go b/resources/page/page_matcher_test.go index 745a6aa3230..aaef27eaa37 100644 --- a/resources/page/page_matcher_test.go +++ b/resources/page/page_matcher_test.go @@ -54,7 +54,12 @@ func TestPageMatcher(t *testing.T) { c.Run("Decode", func(c *qt.C) { var v PageMatcher - c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "foo"}, &v), qt.Not((qt.IsNil))) + c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "foo"}, &v), qt.Not(qt.IsNil)) + c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "{foo,bar}"}, &v), qt.Not(qt.IsNil)) + c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "taxonomy"}, &v), qt.IsNil) + c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "{taxonomy,foo}"}, &v), qt.IsNil) + c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "{taxonomy,term}"}, &v), qt.IsNil) + c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "*"}, &v), qt.IsNil) c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "home", "path": filepath.FromSlash("/a/b/**")}, &v), qt.IsNil) c.Assert(v, qt.Equals, PageMatcher{Kind: "home", Path: "/a/b/**"}) })