Skip to content

Commit

Permalink
VDR: Validate subject to a sensible pattern
Browse files Browse the repository at this point in the history
  • Loading branch information
reinkrul committed Sep 3, 2024
1 parent 931dacb commit 29d3198
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 0 deletions.
7 changes: 7 additions & 0 deletions vdr/didsubject/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ import (
"github.com/nuts-foundation/nuts-node/storage/orm"
"github.com/nuts-foundation/nuts-node/vdr/log"
"gorm.io/gorm"
"regexp"
"time"
)

Expand All @@ -43,6 +44,9 @@ var ErrSubjectAlreadyExists = errors.New("subject already exists")
// ErrSubjectNotFound is returned when a subject is not found.
var ErrSubjectNotFound = errors.New("subject not found")

// subjectPattern is a regular expression for checking whether a subject follows the allowed pattern; a-z, 0-9, -, _, . (case insensitive)
var subjectPattern = regexp.MustCompile(`^[a-zA-Z0-9.-]+$`)

var _ SubjectManager = (*Manager)(nil)

type Manager struct {
Expand Down Expand Up @@ -86,6 +90,9 @@ func (r *Manager) Create(ctx context.Context, options CreationOptions) ([]did.Do
for _, option := range options.All() {
switch opt := option.(type) {
case SubjectCreationOption:
if !subjectPattern.MatchString(opt.Subject) {
return nil, "", fmt.Errorf("invalid subject (must follow pattern: %s)", subjectPattern.String())
}
subject = opt.Subject
case EncryptionKeyCreationOption:
keyFlags = keyFlags | orm.EncryptionKeyUsage()
Expand Down
22 changes: 22 additions & 0 deletions vdr/didsubject/manager_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,28 @@ func TestManager_Create(t *testing.T) {

require.ErrorIs(t, err, ErrSubjectAlreadyExists)
})
t.Run("subject validation", func(t *testing.T) {
t.Run("empty", func(t *testing.T) {
db := testDB(t)
m := Manager{DB: db, MethodManagers: map[string]MethodManager{
"example": testMethod{},
}}

_, _, err := m.Create(audit.TestContext(), DefaultCreationOptions().With(SubjectCreationOption{Subject: ""}))

require.EqualError(t, err, "invalid subject (must follow pattern: ^[a-zA-Z0-9.-]+$)")
})
t.Run("contains illegal character (space)", func(t *testing.T) {
db := testDB(t)
m := Manager{DB: db, MethodManagers: map[string]MethodManager{
"example": testMethod{},
}}

_, _, err := m.Create(audit.TestContext(), DefaultCreationOptions().With(SubjectCreationOption{Subject: "subject with space"}))

require.EqualError(t, err, "invalid subject (must follow pattern: ^[a-zA-Z0-9.-]+$)")
})
})
}

func TestManager_List(t *testing.T) {
Expand Down

0 comments on commit 29d3198

Please sign in to comment.