diff --git a/map_validator/functions.go b/map_validator/functions.go index 227f4bb..181c6bb 100644 --- a/map_validator/functions.go +++ b/map_validator/functions.go @@ -349,7 +349,7 @@ func validate(field string, dataTemp map[string]interface{}, validator Rules, da } return nil, errors.New("the field '" + field + "' should be string") } - regex, err := doSafeRegexpMustCompile(validator.RegexString) + regex, err := regexp.Compile(validator.RegexString) if err != nil { return nil, err } diff --git a/map_validator/roles_builder.go b/map_validator/roles_builder.go index b632b12..800923d 100644 --- a/map_validator/roles_builder.go +++ b/map_validator/roles_builder.go @@ -17,6 +17,18 @@ func (rw *RulesWrapper) SetManipulator(field string, fun func(data interface{}) return rw } +func (rw *RulesWrapper) SetFieldsManipulator(fields []string, fun func(data interface{}) (result interface{}, err error)) *RulesWrapper { + for _, field := range fields { + rw.manipulator = append(rw.manipulator, manipulator{Field: field, Func: &fun}) + } + return rw +} + +func (rw *RulesWrapper) SetSetting(setting Setting) *RulesWrapper { + rw.Setting = setting + return rw +} + func (rw *RulesWrapper) Done() RulesWrapper { return *rw } diff --git a/map_validator/safe_regex.go b/map_validator/safe_regex.go deleted file mode 100644 index a5ef813..0000000 --- a/map_validator/safe_regex.go +++ /dev/null @@ -1,19 +0,0 @@ -package map_validator - -import ( - "errors" - "fmt" - "regexp" -) - -func doSafeRegexpMustCompile(data string) (rex *regexp.Regexp, err error) { - defer func() { - if r := recover(); r != nil { - // Assign error value during panic - err = errors.New(fmt.Sprintf("Error when compiling regex: %v", r)) - } - }() - - rex = regexp.MustCompile(data) - return rex, nil -} diff --git a/map_validator/setting_builder.go b/map_validator/setting_builder.go new file mode 100644 index 0000000..7abb8c5 --- /dev/null +++ b/map_validator/setting_builder.go @@ -0,0 +1,14 @@ +package map_validator + +func BuildSetting() *Setting { + return &Setting{} +} + +func (s *Setting) MakeStrict() *Setting { + s.Strict = true + return s +} + +func (s *Setting) Done() Setting { + return *s +} diff --git a/test/manipulator_test.go b/test/manipulator_test.go index 8b92c1c..fcffa02 100644 --- a/test/manipulator_test.go +++ b/test/manipulator_test.go @@ -78,3 +78,65 @@ func TestManipulateWithFullBuilderRoles(t *testing.T) { t.Errorf("Expected description to be test arian keren bgt kan mantap bukan, but got %s", data["description"]) } } + +func TestManipulateOnNullableField(t *testing.T) { + data := map[string]interface{}{ + "note": "coba aja mungkin bisa \t mantap", + } + + trimAfterValidation := func(i interface{}) (result interface{}, e error) { + x := i.(string) + result = trimAndClean(x) + return + } + + roles := map_validator.BuildRoles(). + SetRule("description", map_validator.Rules{Type: reflect.String, Null: true}). + SetRule("note", map_validator.Rules{Type: reflect.String}). + SetManipulator("description", trimAfterValidation). + Done() + + xx, err := map_validator.NewValidateBuilder().SetRules(roles).Load(data) + extraCheck, err := xx.RunValidate() + if err != nil { + t.Errorf("Expected not have error, but got error : %s", err) + return + } + if extraCheck.GetData()["description"] != nil { + t.Errorf("Expected description to be nil, but got %s", data["description"]) + } +} + +func TestManipulateOnMultiFields(t *testing.T) { + data := map[string]interface{}{ + "name": "arian\n king saputra", + "description": "test arian keren bgt kan \t\n\n mantap bukan", + "note": "coba aja mungkin bisa \t mantap", + } + + trimAfterValidation := func(i interface{}) (result interface{}, e error) { + x := i.(string) + result = trimAndClean(x) + return + } + + roles := map_validator.BuildRoles(). + SetRule("name", map_validator.Rules{Type: reflect.String}). + SetRule("description", map_validator.Rules{Type: reflect.String}). + SetRule("note", map_validator.Rules{Type: reflect.String}). + SetFieldsManipulator([]string{"description", "name"}, trimAfterValidation). + Done() + + xx, err := map_validator.NewValidateBuilder().SetRules(roles).Load(data) + extraCheck, err := xx.RunValidate() + if err != nil { + t.Errorf("Expected not have error, but got error : %s", err) + return + } + if extraCheck.GetData()["name"] != "arian king saputra" { + t.Errorf("Expected name to be arian king saputra, but got %s", extraCheck.GetData()["name"]) + } + if extraCheck.GetData()["description"] != "test arian keren bgt kan mantap bukan" { + t.Errorf("Expected description to be test arian keren bgt kan mantap bukan, but got %s", extraCheck.GetData()["description"]) + } +}