iris/_future/ipel/README.md
Gerasimos (Makis) Maropoulos 126c4de29b _future
1. Fix index, including both start and end. So Literal[start:end+1] will
be a valid part.

2. Replace any with string, add file param type

3. Start of making the evaluator, starting with regexp for param types
(these expression can be changed or/and overriden by user later on)


Former-commit-id: ab95265f953dadbf84170b543e1ff8840f9c4a14
2017-03-27 22:33:19 +03:00

3.8 KiB

Iris Path Expression Language (_future)

Ideas & Goals

  • Optional.
  • No Breaking Changes.
  • No performance cost if not used.
  • Can convert a path for the existing routers, if no router is being used, then it will use its own, new, router.
  • 4+1 basic parameter types: string, int, alphabetical, file, path (file with any number of slashes), based on regexp.
  • Each type has unlimited functions of its own, they should be able to be overriden.
  • Give devs the ability to parse their function's arguments before use them and return a func which is the validator.
  • Function will be a generic type(interface{}) in order to devs be able to use any type without boilerplate code for conversions, can be done using reflection and reflect.Call, on .Boot time to parse the function automatically, and keep the returning validator function (already tested and worked).
  • The string will be the default if dev use functions to the named path parameter but missing a type.
  • If a type doesnt't contains a function of its own, then it will use the string's, so string will contain global-use functions too.

Preview

/api/users/{id:int min(1)}/posts

minValidator := func(min int) func(string) bool {
    return func(paramValue string) bool {
       	paramValueInt, err := strconv.Atoi(paramValue)
		if err != nil {
			return false
		}
        if paramValueInt < min {
            return false
        }
        return true
    }
}

app := iris.New()
app.Int.Set("min", minValidator)

/api/{version:string len(2) isVersion()}

isVersionStrValidator := func() func(string) bool {
    versions := []string{"v1","v2"}
    return func(paramValue string) bool {
        for _, s := range versions {
            if s == paramValue {
                return true
            }
        }
        return false
    }
}

lenStrValidator := func(i int) func(string) bool {
    if i <= 0 {
        i = 1
    }
    return func(paramValue string) bool {
       return len(paramValue) != i
    }
}


app := iris.New()
app.String.Set("isVersion", isVersionStrValidator)
app.String.Set("len", lenStrValidator)

/uploads/{fullpath:path contains(.) else 403}

[...]

[...]

/api/validate/year/{year:int range(1970,2017) else 500}

[...]

[...]

Resources