Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
package router
|
|
|
|
|
|
|
|
import (
|
2020-08-28 03:11:56 +02:00
|
|
|
"errors"
|
2020-02-10 18:40:17 +01:00
|
|
|
"fmt"
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"path"
|
2019-10-24 17:57:05 +02:00
|
|
|
"path/filepath"
|
2021-02-21 21:24:01 +01:00
|
|
|
"reflect"
|
2019-10-24 17:57:05 +02:00
|
|
|
"runtime"
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12/context"
|
2020-02-29 13:18:15 +01:00
|
|
|
"github.com/kataras/iris/v12/hero"
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12/macro"
|
|
|
|
macroHandler "github.com/kataras/iris/v12/macro/handler"
|
2020-08-16 06:07:36 +02:00
|
|
|
|
|
|
|
"github.com/kataras/golog"
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
)
|
|
|
|
|
2018-10-21 18:20:05 +02:00
|
|
|
// MethodNone is a Virtual method
|
|
|
|
// to store the "offline" routes.
|
|
|
|
const MethodNone = "NONE"
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// AllMethods contains the valid HTTP Methods:
|
2019-08-17 09:06:20 +02:00
|
|
|
// "GET", "POST", "PUT", "DELETE", "CONNECT", "HEAD",
|
|
|
|
// "PATCH", "OPTIONS", "TRACE".
|
|
|
|
var AllMethods = []string{
|
|
|
|
http.MethodGet,
|
|
|
|
http.MethodHead,
|
|
|
|
http.MethodPatch,
|
2020-04-26 16:51:27 +02:00
|
|
|
http.MethodPut,
|
|
|
|
http.MethodPost,
|
|
|
|
http.MethodDelete,
|
2019-08-17 09:06:20 +02:00
|
|
|
http.MethodOptions,
|
2020-04-26 16:51:27 +02:00
|
|
|
http.MethodConnect,
|
2019-08-17 09:06:20 +02:00
|
|
|
http.MethodTrace,
|
|
|
|
}
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
|
|
|
|
// repository passed to all parties(subrouters), it's the object witch keeps
|
|
|
|
// all the routes.
|
|
|
|
type repository struct {
|
|
|
|
routes []*Route
|
2021-04-04 19:24:21 +02:00
|
|
|
paths map[string]*Route // only the fullname path part, required at CreateRoutes for registering index page.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
func (repo *repository) get(routeName string) *Route {
|
|
|
|
for _, r := range repo.routes {
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
if r.Name == routeName {
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-07-29 22:09:22 +02:00
|
|
|
func (repo *repository) getRelative(r *Route) *Route {
|
|
|
|
if r.tmpl.IsTrailing() || !macroHandler.CanMakeHandler(r.tmpl) {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, route := range repo.routes {
|
2020-05-10 23:44:54 +02:00
|
|
|
if r.Subdomain == route.Subdomain && r.StatusCode == route.StatusCode && r.Method == route.Method && r.FormattedPath == route.FormattedPath && !route.tmpl.IsTrailing() {
|
2019-07-29 22:09:22 +02:00
|
|
|
return route
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
func (repo *repository) getByPath(tmplPath string) *Route {
|
2021-04-04 19:24:21 +02:00
|
|
|
if r, ok := repo.paths[tmplPath]; ok {
|
|
|
|
return r
|
2019-06-21 18:43:25 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *repository) getAll() []*Route {
|
|
|
|
return repo.routes
|
|
|
|
}
|
|
|
|
|
2021-04-04 19:24:21 +02:00
|
|
|
func (repo *repository) remove(routeName string) bool {
|
|
|
|
for i, r := range repo.routes {
|
|
|
|
if r.Name == routeName {
|
|
|
|
lastIdx := len(repo.routes) - 1
|
|
|
|
if lastIdx == i {
|
|
|
|
repo.routes = repo.routes[0:lastIdx]
|
|
|
|
} else {
|
|
|
|
cp := make([]*Route, 0, lastIdx)
|
|
|
|
cp = append(cp, repo.routes[:i]...)
|
|
|
|
repo.routes = append(cp, repo.routes[i+1:]...)
|
|
|
|
}
|
|
|
|
|
|
|
|
delete(repo.paths, r.tmpl.Src)
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2020-02-10 18:40:17 +01:00
|
|
|
func (repo *repository) register(route *Route, rule RouteRegisterRule) (*Route, error) {
|
2019-06-21 18:43:25 +02:00
|
|
|
for i, r := range repo.routes {
|
2019-08-14 07:56:03 +02:00
|
|
|
// 14 August 2019 allow register same path pattern with different macro functions,
|
|
|
|
// see #1058
|
|
|
|
if route.DeepEqual(r) {
|
2020-02-10 18:40:17 +01:00
|
|
|
if rule == RouteSkip {
|
|
|
|
return r, nil
|
|
|
|
} else if rule == RouteError {
|
|
|
|
return nil, fmt.Errorf("new route: %s conflicts with an already registered one: %s route", route.String(), r.String())
|
2020-06-14 07:09:42 +02:00
|
|
|
} else if rule == RouteOverlap {
|
|
|
|
overlapRoute(r, route)
|
|
|
|
return route, nil
|
2020-02-10 18:40:17 +01:00
|
|
|
} else {
|
|
|
|
// replace existing with the latest one, the default behavior.
|
|
|
|
repo.routes = append(repo.routes[:i], repo.routes[i+1:]...)
|
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-10 23:44:54 +02:00
|
|
|
// fmt.Printf("repo.routes append:\t%#+v\n\n", route)
|
2019-06-21 18:43:25 +02:00
|
|
|
repo.routes = append(repo.routes, route)
|
2020-05-10 23:44:54 +02:00
|
|
|
|
|
|
|
if route.StatusCode == 0 { // a common resource route, not a status code error handler.
|
2021-04-04 19:24:21 +02:00
|
|
|
if repo.paths == nil {
|
|
|
|
repo.paths = make(map[string]*Route)
|
2020-05-10 23:44:54 +02:00
|
|
|
}
|
2021-04-04 19:24:21 +02:00
|
|
|
repo.paths[route.tmpl.Src] = route
|
2019-06-21 18:43:25 +02:00
|
|
|
}
|
|
|
|
|
2020-02-10 18:40:17 +01:00
|
|
|
return route, nil
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-07-10 22:21:09 +02:00
|
|
|
var defaultOverlapFilter = func(ctx *context.Context) bool {
|
2020-06-14 07:09:42 +02:00
|
|
|
if ctx.IsStopped() {
|
2020-06-19 19:58:24 +02:00
|
|
|
// It's stopped and the response can be overridden by a new handler.
|
2020-08-28 05:21:26 +02:00
|
|
|
// An exception of compress writer, which does not implement Reseter (and it shouldn't):
|
2020-06-14 07:09:42 +02:00
|
|
|
rs, ok := ctx.ResponseWriter().(context.ResponseWriterReseter)
|
|
|
|
return ok && rs.Reset()
|
|
|
|
}
|
|
|
|
|
|
|
|
// It's not stopped, all OK no need to execute the alternative route.
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func overlapRoute(r *Route, next *Route) {
|
|
|
|
next.BuildHandlers()
|
|
|
|
nextHandlers := next.Handlers[0:]
|
|
|
|
|
2020-08-28 01:22:38 +02:00
|
|
|
isErrorRoutes := r.StatusCode > 0 && next.StatusCode > 0
|
|
|
|
|
2020-07-10 22:21:09 +02:00
|
|
|
decisionHandler := func(ctx *context.Context) {
|
2020-06-14 07:09:42 +02:00
|
|
|
ctx.Next()
|
|
|
|
|
2020-08-28 01:22:38 +02:00
|
|
|
if isErrorRoutes { // fixes issue #1602.
|
|
|
|
// If it's an error we don't need to reset (see defaultOverlapFilter)
|
|
|
|
// its status code(!) and its body, we just check if it was proceed or not.
|
|
|
|
if !ctx.IsStopped() {
|
|
|
|
return
|
|
|
|
}
|
2020-08-28 03:11:56 +02:00
|
|
|
} else {
|
|
|
|
prevStatusCode := ctx.GetStatusCode()
|
|
|
|
|
|
|
|
if !defaultOverlapFilter(ctx) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// set the status code that it was stopped with.
|
|
|
|
// useful for dependencies with StopWithStatus(XXX)
|
|
|
|
// instead of raw ctx.StopExecution().
|
|
|
|
// The func_result now also catch the last registered status code
|
|
|
|
// of the chain, unless the controller returns an integer.
|
|
|
|
// See _examples/authenticated-controller.
|
|
|
|
if prevStatusCode > 0 {
|
|
|
|
// An exception when stored error
|
|
|
|
// exists and it's type of ErrNotFound.
|
|
|
|
// Example:
|
|
|
|
// Version was not found:
|
|
|
|
// we need to be able to send the status on the last not found version
|
|
|
|
// but reset the status code if a next available matched version was found.
|
2021-01-07 03:14:41 +01:00
|
|
|
// see the versioning package.
|
2020-08-28 03:11:56 +02:00
|
|
|
if !errors.Is(ctx.GetErr(), context.ErrNotFound) {
|
|
|
|
ctx.StatusCode(prevStatusCode)
|
|
|
|
}
|
|
|
|
}
|
2020-06-14 07:09:42 +02:00
|
|
|
}
|
|
|
|
|
2020-08-06 02:35:58 +02:00
|
|
|
ctx.SetErr(nil) // clear any stored error.
|
|
|
|
// Set the route to the next one and execute it.
|
2020-06-14 07:09:42 +02:00
|
|
|
ctx.SetCurrentRoute(next.ReadOnly)
|
|
|
|
ctx.HandlerIndex(0)
|
|
|
|
ctx.Do(nextHandlers)
|
|
|
|
}
|
|
|
|
|
2020-08-28 15:02:14 +02:00
|
|
|
r.builtinBeginHandlers = append(context.Handlers{decisionHandler}, r.builtinBeginHandlers...)
|
|
|
|
r.overlappedLink = next
|
2020-06-14 07:09:42 +02:00
|
|
|
}
|
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// APIBuilder the visible API for constructing the router
|
|
|
|
// and child routers.
|
|
|
|
type APIBuilder struct {
|
2020-08-16 06:07:36 +02:00
|
|
|
// the application logger.
|
|
|
|
logger *golog.Logger
|
2020-08-12 06:20:07 +02:00
|
|
|
// parent is the creator of this Party.
|
|
|
|
// It is nil on Root.
|
2020-08-26 05:57:36 +02:00
|
|
|
parent *APIBuilder // currently it's not used anywhere.
|
2020-08-12 06:20:07 +02:00
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// the per-party APIBuilder with DI.
|
2020-04-17 14:56:36 +02:00
|
|
|
apiBuilderDI *APIContainer
|
2020-04-08 19:04:56 +02:00
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// the api builder global macros registry
|
2018-10-21 18:20:05 +02:00
|
|
|
macros *macro.Macros
|
2021-01-06 00:52:39 +01:00
|
|
|
// the per-party (and its children) values map
|
|
|
|
// that may help on building the API
|
|
|
|
// when source code is splitted between projects.
|
|
|
|
// Initialized on Properties method.
|
|
|
|
properties context.Map
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// the api builder global routes repository
|
|
|
|
routes *repository
|
2020-09-14 23:23:09 +02:00
|
|
|
// disables the debug logging of routes under a per-party and its children.
|
|
|
|
routesNoLog bool
|
2019-06-15 15:59:32 +02:00
|
|
|
|
2017-07-23 11:10:51 +02:00
|
|
|
// the per-party handlers, order
|
2020-08-26 05:57:36 +02:00
|
|
|
// of handlers registration matters,
|
|
|
|
// inherited by children unless Reset is called.
|
2020-08-15 11:17:48 +02:00
|
|
|
middleware context.Handlers
|
|
|
|
middlewareErrorCode context.Handlers
|
2017-07-23 11:10:51 +02:00
|
|
|
// the global middleware handlers, order of call doesn't matters, order
|
|
|
|
// of handlers registration matters. We need a secondary field for this
|
|
|
|
// because `UseGlobal` registers handlers that should be executed
|
|
|
|
// even before the `middleware` handlers, and in the same time keep the order
|
|
|
|
// of handlers registration, so the same type of handlers are being called in order.
|
|
|
|
beginGlobalHandlers context.Handlers
|
2018-02-08 13:04:39 +01:00
|
|
|
|
|
|
|
// the per-party done handlers, order matters.
|
|
|
|
doneHandlers context.Handlers
|
2018-05-21 06:40:43 +02:00
|
|
|
// global done handlers, order doesn't matter.
|
2017-07-23 11:10:51 +02:00
|
|
|
doneGlobalHandlers context.Handlers
|
2018-05-21 06:40:43 +02:00
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
// the per-party relative path.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
relativePath string
|
2020-08-12 06:20:07 +02:00
|
|
|
// allowMethods are filled with the `AllowMethods` method.
|
2018-03-10 13:22:56 +01:00
|
|
|
// They are used to create new routes
|
|
|
|
// per any party's (and its children) routes registered
|
|
|
|
// if the method "x" wasn't registered already via the `Handle` (and its extensions like `Get`, `Post`...).
|
|
|
|
allowMethods []string
|
2018-05-21 06:40:43 +02:00
|
|
|
|
|
|
|
// the per-party (and its children) execution rules for begin, main and done handlers.
|
|
|
|
handlerExecutionRules ExecutionRules
|
2020-02-10 18:40:17 +01:00
|
|
|
// the per-party (and its children) route registration rule, see `SetRegisterRule`.
|
|
|
|
routeRegisterRule RouteRegisterRule
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
|
2020-08-26 05:57:36 +02:00
|
|
|
// routerFilterHandlers holds a reference
|
|
|
|
// of the handlers used by the current and its parent Party's registered
|
|
|
|
// router filters. Inherited by children unless `Reset` (see `UseRouter`),
|
|
|
|
routerFilterHandlers context.Handlers
|
2020-08-12 06:20:07 +02:00
|
|
|
// routerFilters field is shared across Parties. Each Party registers
|
|
|
|
// one or more middlewares to run before the router itself using the `UseRouter` method.
|
|
|
|
// Each Party calls the shared filter (`partyMatcher`) that decides if its `UseRouter` handlers
|
|
|
|
// can be executed. By default it's based on party's static path and/or subdomain,
|
|
|
|
// it can be modified through an `Application.SetPartyMatcher` call
|
|
|
|
// once before or after routerFilters filled.
|
|
|
|
//
|
|
|
|
// The Key is the Party (instance of APIBuilder),
|
|
|
|
// value wraps the partyFilter + the handlers registered through `UseRouter`.
|
|
|
|
// See `GetRouterFilters` too.
|
|
|
|
routerFilters map[Party]*Filter
|
|
|
|
// partyMatcher field is shared across all Parties,
|
|
|
|
// can be modified through the Application level only.
|
|
|
|
//
|
|
|
|
// It defaults to the internal, simple, "defaultPartyMatcher".
|
|
|
|
// It applies when "routerFilters" are used.
|
|
|
|
partyMatcher PartyMatcherFunc
|
|
|
|
}
|
|
|
|
|
|
|
|
var (
|
|
|
|
_ Party = (*APIBuilder)(nil)
|
|
|
|
_ PartyMatcher = (*APIBuilder)(nil)
|
|
|
|
_ RoutesProvider = (*APIBuilder)(nil) // passed to the default request handler (routerHandler)
|
|
|
|
)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
|
|
|
|
// NewAPIBuilder creates & returns a new builder
|
|
|
|
// which is responsible to build the API and the router handler.
|
2020-08-16 06:07:36 +02:00
|
|
|
func NewAPIBuilder(logger *golog.Logger) *APIBuilder {
|
2020-04-25 01:30:19 +02:00
|
|
|
return &APIBuilder{
|
2020-08-16 06:07:36 +02:00
|
|
|
logger: logger,
|
2020-08-12 06:20:07 +02:00
|
|
|
parent: nil,
|
|
|
|
macros: macro.Defaults,
|
|
|
|
relativePath: "/",
|
|
|
|
routes: new(repository),
|
2020-08-24 20:44:29 +02:00
|
|
|
apiBuilderDI: &APIContainer{Container: hero.New().WithLogger(logger)},
|
2020-08-12 06:20:07 +02:00
|
|
|
routerFilters: make(map[Party]*Filter),
|
|
|
|
partyMatcher: defaultPartyMatcher,
|
2020-04-08 19:04:56 +02:00
|
|
|
}
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-08-16 06:07:36 +02:00
|
|
|
// Logger returns the Application Logger.
|
|
|
|
func (api *APIBuilder) Logger() *golog.Logger {
|
|
|
|
return api.logger
|
|
|
|
}
|
|
|
|
|
2020-08-12 06:20:07 +02:00
|
|
|
// IsRoot reports whether this Party is the root Application's one.
|
|
|
|
// It will return false on all children Parties, no exception.
|
|
|
|
func (api *APIBuilder) IsRoot() bool {
|
|
|
|
return api.parent == nil
|
|
|
|
}
|
|
|
|
|
|
|
|
/* If requested:
|
|
|
|
// GetRoot returns the very first Party (the Application).
|
|
|
|
func (api *APIBuilder) GetRoot() *APIBuilder {
|
|
|
|
root := api.parent
|
|
|
|
for root != nil {
|
|
|
|
root = api.parent
|
|
|
|
}
|
|
|
|
|
|
|
|
return root
|
|
|
|
}*/
|
|
|
|
|
2020-04-17 14:56:36 +02:00
|
|
|
// ConfigureContainer accepts one or more functions that can be used
|
|
|
|
// to configure dependency injection features of this Party
|
|
|
|
// such as register dependency and register handlers that will automatically inject any valid dependency.
|
|
|
|
// However, if the "builder" parameter is nil or not provided then it just returns the *APIContainer,
|
|
|
|
// which automatically initialized on Party allocation.
|
|
|
|
//
|
|
|
|
// It returns the same `APIBuilder` featured with Dependency Injection.
|
|
|
|
func (api *APIBuilder) ConfigureContainer(builder ...func(*APIContainer)) *APIContainer {
|
2020-04-25 01:30:19 +02:00
|
|
|
if api.apiBuilderDI.Self == nil {
|
|
|
|
api.apiBuilderDI.Self = api
|
|
|
|
}
|
|
|
|
|
2020-04-17 14:56:36 +02:00
|
|
|
for _, b := range builder {
|
2020-04-25 01:30:19 +02:00
|
|
|
if b != nil {
|
|
|
|
b(api.apiBuilderDI)
|
2020-04-17 14:56:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
return api.apiBuilderDI
|
|
|
|
}
|
|
|
|
|
2021-02-21 21:24:01 +01:00
|
|
|
// RegisterDependency calls the `ConfigureContainer.RegisterDependency` method
|
|
|
|
// with the provided value(s). See `HandleFunc` and `PartyConfigure` methods too.
|
|
|
|
func (api *APIBuilder) RegisterDependency(dependencies ...interface{}) {
|
|
|
|
diContainer := api.ConfigureContainer()
|
|
|
|
for i, dependency := range dependencies {
|
|
|
|
if dependency == nil {
|
|
|
|
api.logger.Warnf("Party: %s: nil dependency on position: %d", api.relativePath, i)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
diContainer.RegisterDependency(dependency)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-21 00:36:11 +01:00
|
|
|
// HandleFunc registers a route on HTTP verb "method" and relative, to this Party, path.
|
|
|
|
// It is like the `Handle` method but it accepts one or more "handlersFn" functions
|
|
|
|
// that each one of them can accept any input arguments as the HTTP request and
|
|
|
|
// output a result as the HTTP response. Specifically,
|
|
|
|
// the input of the "handlersFn" can be any registered dependency
|
|
|
|
// (see ConfigureContainer().RegisterDependency)
|
|
|
|
// or leave the framework to parse the request and fill the values accordingly.
|
|
|
|
// The output of the "handlersFn" can be any output result:
|
|
|
|
// custom structs <T>, string, []byte, int, error,
|
|
|
|
// a combination of the above, hero.Result(hero.View | hero.Response) and more.
|
|
|
|
//
|
|
|
|
// If more than one handler function is registered
|
|
|
|
// then the execution happens without the nessecity of the `Context.Next` method,
|
|
|
|
// simply, to stop the execution and not continue to the next "handlersFn" in chain
|
|
|
|
// you should return an `iris.ErrStopExecution`.
|
|
|
|
//
|
|
|
|
// Example Code:
|
|
|
|
//
|
|
|
|
// The client's request body and server's response body Go types.
|
|
|
|
// Could be any data structure.
|
|
|
|
//
|
|
|
|
// type (
|
|
|
|
// request struct {
|
|
|
|
// Firstname string `json:"firstname"`
|
|
|
|
// Lastname string `json:"lastname"`
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// response struct {
|
|
|
|
// ID uint64 `json:"id"`
|
|
|
|
// Message string `json:"message"`
|
|
|
|
// }
|
|
|
|
// )
|
|
|
|
//
|
|
|
|
// Register the route hander.
|
|
|
|
//
|
|
|
|
// HTTP VERB ROUTE PATH ROUTE HANDLER
|
|
|
|
// app.HandleFunc("PUT", "/users/{id:uint64}", updateUser)
|
|
|
|
//
|
|
|
|
// Code the route handler function.
|
|
|
|
// Path parameters and request body are binded
|
|
|
|
// automatically.
|
|
|
|
// The "id" uint64 binds to "{id:uint64}" route path parameter and
|
|
|
|
// the "input" binds to client request data such as JSON.
|
|
|
|
//
|
|
|
|
// func updateUser(id uint64, input request) response {
|
|
|
|
// // [custom logic...]
|
|
|
|
//
|
|
|
|
// return response{
|
|
|
|
// ID:id,
|
|
|
|
// Message: "User updated successfully",
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// Simulate a client request which sends data
|
|
|
|
// to the server and prints out the response.
|
|
|
|
//
|
|
|
|
// curl --request PUT -d '{"firstname":"John","lastname":"Doe"}' \
|
|
|
|
// -H "Content-Type: application/json" \
|
|
|
|
// http://localhost:8080/users/42
|
|
|
|
//
|
|
|
|
// {
|
|
|
|
// "id": 42,
|
|
|
|
// "message": "User updated successfully"
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// See the `ConfigureContainer` for more features regrading
|
|
|
|
// the dependency injection, mvc and function handlers.
|
|
|
|
//
|
2021-06-11 10:11:36 +02:00
|
|
|
// This method is just a shortcut of the `ConfigureContainer().Handle`.
|
2021-01-21 00:36:11 +01:00
|
|
|
func (api *APIBuilder) HandleFunc(method, relativePath string, handlersFn ...interface{}) *Route {
|
|
|
|
return api.ConfigureContainer().Handle(method, relativePath, handlersFn...)
|
|
|
|
}
|
|
|
|
|
2021-06-11 10:11:36 +02:00
|
|
|
// UseFunc registers a function which can accept one or more
|
|
|
|
// dependencies (see RegisterDependency) and returns an iris.Handler
|
|
|
|
// or a result of <T> and/or an error.
|
|
|
|
//
|
|
|
|
// This method is just a shortcut of the `ConfigureContainer().Use`.
|
|
|
|
func (api *APIBuilder) UseFunc(handlersFn ...interface{}) {
|
|
|
|
api.ConfigureContainer().Use(handlersFn...)
|
|
|
|
}
|
|
|
|
|
2018-01-20 04:17:31 +01:00
|
|
|
// GetRelPath returns the current party's relative path.
|
|
|
|
// i.e:
|
|
|
|
// if r := app.Party("/users"), then the `r.GetRelPath()` is the "/users".
|
|
|
|
// if r := app.Party("www.") or app.Subdomain("www") then the `r.GetRelPath()` is the "www.".
|
|
|
|
func (api *APIBuilder) GetRelPath() string {
|
|
|
|
return api.relativePath
|
|
|
|
}
|
|
|
|
|
2018-03-10 13:22:56 +01:00
|
|
|
// AllowMethods will re-register the future routes that will be registered
|
|
|
|
// via `Handle`, `Get`, `Post`, ... to the given "methods" on that Party and its children "Parties",
|
|
|
|
// duplicates are not registered.
|
|
|
|
//
|
|
|
|
// Call of `AllowMethod` will override any previous allow methods.
|
|
|
|
func (api *APIBuilder) AllowMethods(methods ...string) Party {
|
|
|
|
api.allowMethods = methods
|
|
|
|
return api
|
|
|
|
}
|
|
|
|
|
2018-05-21 06:40:43 +02:00
|
|
|
// SetExecutionRules alters the execution flow of the route handlers outside of the handlers themselves.
|
|
|
|
//
|
|
|
|
// For example, if for some reason the desired result is the (done or all) handlers to be executed no matter what
|
|
|
|
// even if no `ctx.Next()` is called in the previous handlers, including the begin(`Use`),
|
|
|
|
// the main(`Handle`) and the done(`Done`) handlers themselves, then:
|
|
|
|
// Party#SetExecutionRules(iris.ExecutionRules {
|
|
|
|
// Begin: iris.ExecutionOptions{Force: true},
|
|
|
|
// Main: iris.ExecutionOptions{Force: true},
|
|
|
|
// Done: iris.ExecutionOptions{Force: true},
|
|
|
|
// })
|
|
|
|
//
|
|
|
|
// Note that if : true then the only remained way to "break" the handler chain is by `ctx.StopExecution()` now that `ctx.Next()` does not matter.
|
|
|
|
//
|
|
|
|
// These rules are per-party, so if a `Party` creates a child one then the same rules will be applied to that as well.
|
|
|
|
// Reset of these rules (before `Party#Handle`) can be done with `Party#SetExecutionRules(iris.ExecutionRules{})`.
|
|
|
|
//
|
|
|
|
// The most common scenario for its use can be found inside Iris MVC Applications;
|
|
|
|
// when we want the `Done` handlers of that specific mvc app's `Party`
|
|
|
|
// to be executed but we don't want to add `ctx.Next()` on the `OurController#EndRequest`.
|
|
|
|
//
|
|
|
|
// Returns this Party.
|
|
|
|
//
|
|
|
|
// Example: https://github.com/kataras/iris/tree/master/_examples/mvc/middleware/without-ctx-next
|
|
|
|
func (api *APIBuilder) SetExecutionRules(executionRules ExecutionRules) Party {
|
|
|
|
api.handlerExecutionRules = executionRules
|
|
|
|
return api
|
|
|
|
}
|
|
|
|
|
2020-02-10 18:40:17 +01:00
|
|
|
// RouteRegisterRule is a type of uint8.
|
|
|
|
// Defines the register rule for new routes that already exists.
|
|
|
|
// Available values are: RouteOverride, RouteSkip and RouteError.
|
|
|
|
//
|
|
|
|
// See `Party#SetRegisterRule`.
|
|
|
|
type RouteRegisterRule uint8
|
|
|
|
|
|
|
|
const (
|
2020-06-14 14:24:42 +02:00
|
|
|
// RouteOverride replaces an existing route with the new one, the default rule.
|
2020-02-10 18:40:17 +01:00
|
|
|
RouteOverride RouteRegisterRule = iota
|
2020-06-14 14:24:42 +02:00
|
|
|
// RouteSkip keeps the original route and skips the new one.
|
2020-02-10 18:40:17 +01:00
|
|
|
RouteSkip
|
|
|
|
// RouteError log when a route already exists, shown after the `Build` state,
|
|
|
|
// server never starts.
|
|
|
|
RouteError
|
2020-06-14 07:09:42 +02:00
|
|
|
// RouteOverlap will overlap the new route to the previous one.
|
|
|
|
// If the route stopped and its response can be reset then the new route will be execute.
|
|
|
|
RouteOverlap
|
2020-02-10 18:40:17 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// SetRegisterRule sets a `RouteRegisterRule` for this Party and its children.
|
2020-06-14 07:09:42 +02:00
|
|
|
// Available values are:
|
|
|
|
// * RouteOverride (the default one)
|
|
|
|
// * RouteSkip
|
|
|
|
// * RouteError
|
|
|
|
// * RouteOverlap.
|
2020-02-10 18:40:17 +01:00
|
|
|
func (api *APIBuilder) SetRegisterRule(rule RouteRegisterRule) Party {
|
|
|
|
api.routeRegisterRule = rule
|
|
|
|
return api
|
|
|
|
}
|
|
|
|
|
2020-08-22 07:04:22 +02:00
|
|
|
// Handle registers a route to this Party.
|
2019-06-21 18:43:25 +02:00
|
|
|
// if empty method is passed then handler(s) are being registered to all methods, same as .Any.
|
|
|
|
//
|
|
|
|
// Returns a *Route, app will throw any errors later on.
|
|
|
|
func (api *APIBuilder) Handle(method string, relativePath string, handlers ...context.Handler) *Route {
|
2020-05-10 23:44:54 +02:00
|
|
|
return api.handle(0, method, relativePath, handlers...)
|
|
|
|
}
|
|
|
|
|
2020-08-22 07:04:22 +02:00
|
|
|
// handle registers a full route to this Party.
|
|
|
|
// Use Handle or Get, Post, Put, Delete and et.c. instead.
|
2020-05-10 23:44:54 +02:00
|
|
|
func (api *APIBuilder) handle(errorCode int, method string, relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
routes := api.createRoutes(errorCode, []string{method}, relativePath, handlers...)
|
2018-03-10 13:22:56 +01:00
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
var route *Route // the last one is returned.
|
2020-02-10 18:40:17 +01:00
|
|
|
var err error
|
2019-06-21 18:43:25 +02:00
|
|
|
for _, route = range routes {
|
2019-11-19 22:36:18 +01:00
|
|
|
if route == nil {
|
2020-08-28 15:02:14 +02:00
|
|
|
continue
|
2019-11-19 22:36:18 +01:00
|
|
|
}
|
2020-05-10 23:44:54 +02:00
|
|
|
|
2018-03-10 13:22:56 +01:00
|
|
|
// global
|
2019-07-29 22:09:22 +02:00
|
|
|
|
|
|
|
route.topLink = api.routes.getRelative(route)
|
2020-02-10 18:40:17 +01:00
|
|
|
if route, err = api.routes.register(route, api.routeRegisterRule); err != nil {
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Error(err)
|
2020-02-10 18:40:17 +01:00
|
|
|
break
|
|
|
|
}
|
2018-03-10 13:22:56 +01:00
|
|
|
}
|
2017-07-10 17:32:42 +02:00
|
|
|
|
2018-03-10 13:22:56 +01:00
|
|
|
return route
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2017-08-18 16:09:18 +02:00
|
|
|
// HandleMany works like `Handle` but can receive more than one
|
|
|
|
// paths separated by spaces and returns always a slice of *Route instead of a single instance of Route.
|
|
|
|
//
|
|
|
|
// It's useful only if the same handler can handle more than one request paths,
|
|
|
|
// otherwise use `Party` which can handle many paths with different handlers and middlewares.
|
|
|
|
//
|
|
|
|
// Usage:
|
2018-10-21 18:20:05 +02:00
|
|
|
// app.HandleMany("GET", "/user /user/{id:uint64} /user/me", genericUserHandler)
|
2017-08-18 16:09:18 +02:00
|
|
|
// At the other side, with `Handle` we've had to write:
|
2017-11-27 20:39:57 +01:00
|
|
|
// app.Handle("GET", "/user", userHandler)
|
2018-10-21 18:20:05 +02:00
|
|
|
// app.Handle("GET", "/user/{id:uint64}", userByIDHandler)
|
2017-11-27 20:39:57 +01:00
|
|
|
// app.Handle("GET", "/user/me", userMeHandler)
|
2017-08-18 16:09:18 +02:00
|
|
|
//
|
2019-10-24 17:57:05 +02:00
|
|
|
// app.HandleMany("GET POST", "/path", handler)
|
2017-10-02 03:01:23 +02:00
|
|
|
func (api *APIBuilder) HandleMany(methodOrMulti string, relativePathorMulti string, handlers ...context.Handler) (routes []*Route) {
|
2017-08-18 16:09:18 +02:00
|
|
|
// at least slash
|
|
|
|
// a space
|
|
|
|
// at least one other slash for the next path
|
2017-12-21 13:42:39 +01:00
|
|
|
paths := splitPath(relativePathorMulti)
|
|
|
|
methods := splitMethod(methodOrMulti)
|
2017-08-18 16:09:18 +02:00
|
|
|
for _, p := range paths {
|
|
|
|
if p != "" {
|
2017-10-02 03:01:23 +02:00
|
|
|
for _, method := range methods {
|
|
|
|
if method == "" {
|
|
|
|
method = "ANY"
|
|
|
|
}
|
|
|
|
if method == "ANY" || method == "ALL" {
|
|
|
|
routes = append(routes, api.Any(p, handlers...)...)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
routes = append(routes, api.Handle(method, p, handlers...))
|
2017-08-27 17:46:04 +02:00
|
|
|
}
|
2017-08-18 16:09:18 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
// HandleDir registers a handler that serves HTTP requests
|
|
|
|
// with the contents of a file system (physical or embedded).
|
|
|
|
//
|
|
|
|
// first parameter : the route path
|
2020-07-24 12:03:49 +02:00
|
|
|
// second parameter : the file system needs to be served
|
|
|
|
// third parameter : not required, the serve directory options.
|
2019-06-21 18:43:25 +02:00
|
|
|
//
|
2019-07-05 15:22:20 +02:00
|
|
|
// Alternatively, to get just the handler for that look the FileServer function instead.
|
2019-06-21 18:43:25 +02:00
|
|
|
//
|
2020-07-24 12:03:49 +02:00
|
|
|
// api.HandleDir("/static", iris.Dir("./assets"), iris.DirOptions{IndexName: "/index.html", Compress: true})
|
2019-06-21 18:43:25 +02:00
|
|
|
//
|
2020-07-05 04:39:48 +02:00
|
|
|
// Returns all the registered routes, including GET index and path patterm and HEAD.
|
2019-06-21 18:43:25 +02:00
|
|
|
//
|
2020-09-05 07:34:09 +02:00
|
|
|
// Usage:
|
|
|
|
// HandleDir("/public", "./assets", DirOptions{...}) or
|
|
|
|
// HandleDir("/public", iris.Dir("./assets"), DirOptions{...})
|
|
|
|
//
|
|
|
|
// Examples:
|
|
|
|
// https://github.com/kataras/iris/tree/master/_examples/file-server
|
|
|
|
func (api *APIBuilder) HandleDir(requestPath string, fsOrDir interface{}, opts ...DirOptions) (routes []*Route) {
|
2020-07-24 12:03:49 +02:00
|
|
|
options := DefaultDirOptions
|
|
|
|
if len(opts) > 0 {
|
|
|
|
options = opts[0]
|
|
|
|
}
|
|
|
|
|
2020-09-05 07:34:09 +02:00
|
|
|
var fs http.FileSystem
|
|
|
|
switch v := fsOrDir.(type) {
|
|
|
|
case string:
|
|
|
|
fs = http.Dir(v)
|
|
|
|
case http.FileSystem:
|
|
|
|
fs = v
|
|
|
|
default:
|
|
|
|
panic(fmt.Errorf(`unexpected "fsOrDir" argument type of %T (string or http.FileSystem)`, v))
|
|
|
|
}
|
|
|
|
|
2020-07-24 12:03:49 +02:00
|
|
|
h := FileServer(fs, options)
|
|
|
|
description := "file server"
|
|
|
|
if d, ok := fs.(http.Dir); ok {
|
|
|
|
description = string(d)
|
|
|
|
}
|
2020-07-06 15:06:48 +02:00
|
|
|
|
2020-04-26 16:23:38 +02:00
|
|
|
fileName, lineNumber := context.HandlerFileLine(h) // take those before StripPrefix.
|
2019-06-21 18:43:25 +02:00
|
|
|
|
|
|
|
// if subdomain, we get the full path of the path only,
|
|
|
|
// because a subdomain can have parties as well
|
|
|
|
// and we need that path to call the `StripPrefix`.
|
2020-04-26 16:23:38 +02:00
|
|
|
_, fullpath := splitSubdomainAndPath(joinPath(api.relativePath, requestPath))
|
|
|
|
if fullpath != "/" {
|
2019-06-21 18:43:25 +02:00
|
|
|
h = StripPrefix(fullpath, h)
|
|
|
|
}
|
|
|
|
|
2020-07-05 04:39:48 +02:00
|
|
|
if api.GetRouteByPath(fullpath) == nil {
|
|
|
|
// register index if not registered by the end-developer.
|
|
|
|
routes = api.CreateRoutes([]string{http.MethodGet, http.MethodHead}, requestPath, h)
|
|
|
|
}
|
2020-02-02 15:29:06 +01:00
|
|
|
|
2020-07-05 04:39:48 +02:00
|
|
|
requestPath = joinPath(requestPath, WildcardFileParam())
|
2020-02-02 15:29:06 +01:00
|
|
|
|
2020-07-05 04:39:48 +02:00
|
|
|
routes = append(routes, api.CreateRoutes([]string{http.MethodGet, http.MethodHead}, requestPath, h)...)
|
2019-06-21 18:43:25 +02:00
|
|
|
|
|
|
|
for _, route := range routes {
|
2020-04-26 16:23:38 +02:00
|
|
|
if route.Method == http.MethodHead {
|
|
|
|
} else {
|
2020-04-28 21:34:36 +02:00
|
|
|
route.Describe(description)
|
2020-04-26 16:23:38 +02:00
|
|
|
route.SetSourceLine(fileName, lineNumber)
|
|
|
|
}
|
|
|
|
|
2020-02-10 18:40:17 +01:00
|
|
|
if _, err := api.routes.register(route, api.routeRegisterRule); err != nil {
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Error(err)
|
2020-02-10 18:40:17 +01:00
|
|
|
break
|
|
|
|
}
|
2019-06-21 18:43:25 +02:00
|
|
|
}
|
|
|
|
|
2020-07-05 04:39:48 +02:00
|
|
|
return routes
|
2019-06-21 18:43:25 +02:00
|
|
|
}
|
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
// CreateRoutes returns a list of Party-based Routes.
|
|
|
|
// It does NOT registers the route. Use `Handle, Get...` methods instead.
|
|
|
|
// This method can be used for third-parties Iris helpers packages and tools
|
|
|
|
// that want a more detailed view of Party-based Routes before take the decision to register them.
|
|
|
|
func (api *APIBuilder) CreateRoutes(methods []string, relativePath string, handlers ...context.Handler) []*Route {
|
2020-05-10 23:44:54 +02:00
|
|
|
return api.createRoutes(0, methods, relativePath, handlers...)
|
|
|
|
}
|
|
|
|
|
2021-04-04 19:24:21 +02:00
|
|
|
// RemoveRoute deletes a registered route by its name before `Application.Listen`.
|
|
|
|
// The default naming for newly created routes is: method + subdomain + path.
|
|
|
|
// Reports whether a route with that name was found and removed successfully.
|
|
|
|
//
|
|
|
|
// Note that this method applies to all Parties (sub routers)
|
|
|
|
// even if each of the Parties have access to this method,
|
|
|
|
// as the route name is unique per Iris Application.
|
|
|
|
func (api *APIBuilder) RemoveRoute(routeName string) bool {
|
|
|
|
return api.routes.remove(routeName)
|
|
|
|
}
|
|
|
|
|
2020-05-10 23:44:54 +02:00
|
|
|
func (api *APIBuilder) createRoutes(errorCode int, methods []string, relativePath string, handlers ...context.Handler) []*Route {
|
|
|
|
if statusCodeSuccessful(errorCode) {
|
|
|
|
errorCode = 0
|
|
|
|
}
|
|
|
|
|
|
|
|
if errorCode == 0 {
|
|
|
|
if len(methods) == 0 || methods[0] == "ALL" || methods[0] == "ANY" { // then use like it was .Any
|
|
|
|
return api.Any(relativePath, handlers...)
|
|
|
|
}
|
2020-02-29 13:18:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// no clean path yet because of subdomain indicator/separator which contains a dot.
|
|
|
|
// but remove the first slash if the relative has already ending with a slash
|
|
|
|
// it's not needed because later on we do normalize/clean the path, but better do it here too
|
|
|
|
// for any future updates.
|
|
|
|
if api.relativePath[len(api.relativePath)-1] == '/' {
|
|
|
|
if relativePath[0] == '/' {
|
|
|
|
relativePath = relativePath[1:]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
filename, line := getCaller()
|
|
|
|
|
|
|
|
fullpath := api.relativePath + relativePath // for now, keep the last "/" if any, "/xyz/"
|
|
|
|
if len(handlers) == 0 {
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Errorf("missing handlers for route[%s:%d] %s: %s", filename, line, strings.Join(methods, ", "), fullpath)
|
2020-02-29 13:18:15 +01:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// note: this can not change the caller's handlers as they're but the entry values(handlers)
|
|
|
|
// of `middleware`, `doneHandlers` and `handlers` can.
|
|
|
|
// So if we just put `api.middleware` or `api.doneHandlers`
|
|
|
|
// then the next `Party` will have those updated handlers
|
|
|
|
// but dev may change the rules for that child Party, so we have to make clones of them here.
|
2020-05-10 23:44:54 +02:00
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
var (
|
2020-07-06 18:08:02 +02:00
|
|
|
// global middleware to error handlers as well.
|
|
|
|
beginHandlers = api.beginGlobalHandlers
|
|
|
|
doneHandlers = api.doneGlobalHandlers
|
2020-02-29 13:18:15 +01:00
|
|
|
)
|
|
|
|
|
2020-05-10 23:44:54 +02:00
|
|
|
if errorCode == 0 {
|
2020-07-06 18:08:02 +02:00
|
|
|
beginHandlers = context.JoinHandlers(beginHandlers, api.middleware)
|
|
|
|
doneHandlers = context.JoinHandlers(doneHandlers, api.doneHandlers)
|
2020-08-15 11:17:48 +02:00
|
|
|
} else {
|
|
|
|
beginHandlers = context.JoinHandlers(beginHandlers, api.middlewareErrorCode)
|
2020-05-10 23:44:54 +02:00
|
|
|
}
|
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
mainHandlers := context.Handlers(handlers)
|
|
|
|
// before join the middleware + handlers + done handlers and apply the execution rules.
|
|
|
|
|
2020-04-27 14:48:09 +02:00
|
|
|
mainHandlerName, mainHandlerIndex := context.MainHandlerName(mainHandlers)
|
2020-04-28 21:34:36 +02:00
|
|
|
|
2020-04-28 00:58:56 +02:00
|
|
|
mainHandlerFileName, mainHandlerFileNumber := context.HandlerFileLineRel(handlers[mainHandlerIndex])
|
2020-02-29 13:18:15 +01:00
|
|
|
|
2020-04-27 14:48:09 +02:00
|
|
|
// re-calculate mainHandlerIndex in favor of the middlewares.
|
2020-08-15 11:17:48 +02:00
|
|
|
mainHandlerIndex = len(beginHandlers) + mainHandlerIndex
|
2020-04-27 14:48:09 +02:00
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
// TODO: for UseGlobal/DoneGlobal that doesn't work.
|
|
|
|
applyExecutionRules(api.handlerExecutionRules, &beginHandlers, &doneHandlers, &mainHandlers)
|
|
|
|
|
|
|
|
// global begin handlers -> middleware that are registered before route registration
|
|
|
|
// -> handlers that are passed to this Handle function.
|
2020-06-19 19:58:24 +02:00
|
|
|
routeHandlers := context.JoinHandlers(beginHandlers, mainHandlers)
|
2020-02-29 13:18:15 +01:00
|
|
|
// -> done handlers
|
2020-06-19 19:58:24 +02:00
|
|
|
routeHandlers = context.JoinHandlers(routeHandlers, doneHandlers)
|
2020-02-29 13:18:15 +01:00
|
|
|
|
|
|
|
// here we separate the subdomain and relative path
|
|
|
|
subdomain, path := splitSubdomainAndPath(fullpath)
|
|
|
|
|
|
|
|
// if allowMethods are empty, then simply register with the passed, main, method.
|
2020-04-25 01:30:19 +02:00
|
|
|
methods = removeDuplicates(append(api.allowMethods, methods...))
|
2020-02-29 13:18:15 +01:00
|
|
|
|
|
|
|
routes := make([]*Route, len(methods))
|
|
|
|
|
2020-05-10 23:44:54 +02:00
|
|
|
for i, m := range methods { // single, empty method for error handlers.
|
2021-01-06 00:52:39 +01:00
|
|
|
route, err := NewRoute(api, errorCode, m, subdomain, path, routeHandlers, *api.macros)
|
2020-02-29 13:18:15 +01:00
|
|
|
if err != nil { // template path parser errors:
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Errorf("[%s:%d] %v -> %s:%s:%s", filename, line, err, m, subdomain, path)
|
2020-02-29 13:18:15 +01:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2020-04-27 14:48:09 +02:00
|
|
|
// The caller tiself, if anonymous, it's the first line of `app.X("/path", here)`
|
2020-04-26 05:21:20 +02:00
|
|
|
route.RegisterFileName = filename
|
|
|
|
route.RegisterLineNumber = line
|
2020-02-29 13:18:15 +01:00
|
|
|
|
2020-04-27 14:48:09 +02:00
|
|
|
route.MainHandlerName = mainHandlerName
|
|
|
|
route.MainHandlerIndex = mainHandlerIndex
|
|
|
|
|
|
|
|
// The main handler source, could be the same as the register's if anonymous.
|
|
|
|
route.SourceFileName = mainHandlerFileName
|
|
|
|
route.SourceLineNumber = mainHandlerFileNumber
|
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
// Add UseGlobal & DoneGlobal Handlers
|
2020-07-06 18:08:02 +02:00
|
|
|
// route.Use(api.beginGlobalHandlers...)
|
|
|
|
// route.Done(api.doneGlobalHandlers...)
|
2020-02-29 13:18:15 +01:00
|
|
|
|
2020-09-14 23:23:09 +02:00
|
|
|
route.NoLog = api.routesNoLog
|
2020-02-29 13:18:15 +01:00
|
|
|
routes[i] = route
|
|
|
|
}
|
|
|
|
|
|
|
|
return routes
|
|
|
|
}
|
|
|
|
|
2020-04-25 01:30:19 +02:00
|
|
|
func removeDuplicates(elements []string) (result []string) {
|
2020-04-21 08:27:28 +02:00
|
|
|
seen := make(map[string]struct{})
|
|
|
|
|
|
|
|
for v := range elements {
|
|
|
|
val := elements[v]
|
|
|
|
if _, ok := seen[val]; !ok {
|
|
|
|
seen[val] = struct{}{}
|
|
|
|
result = append(result, val)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
2020-08-12 06:20:07 +02:00
|
|
|
// Party returns a new child Party which inherites its
|
|
|
|
// parent's options and middlewares.
|
|
|
|
// A Party groups routes which may have the same prefix or subdomain and share same middlewares.
|
2017-11-22 00:01:45 +01:00
|
|
|
//
|
2020-08-12 06:20:07 +02:00
|
|
|
// To create a group of routes for subdomains
|
|
|
|
// use the `Subdomain` or `WildcardSubdomain` methods
|
2021-01-06 00:52:39 +01:00
|
|
|
// or pass a "relativePath" of "admin." or "*." respectfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Party(relativePath string, handlers ...context.Handler) Party {
|
2020-08-12 06:20:07 +02:00
|
|
|
// if app.Party("/"), root party or app.Party("/user") == app.Party("/user")
|
|
|
|
// then just add the middlewares and return itself.
|
2021-01-06 00:52:39 +01:00
|
|
|
// if relativePath == "" || api.relativePath == relativePath {
|
|
|
|
// api.Use(handlers...)
|
|
|
|
// return api
|
|
|
|
// }
|
|
|
|
// ^ No, this is wrong, let the developer do its job, if she/he wants a copy let have it,
|
|
|
|
// it's a pure check as well, a path can be the same even if it's the same as its parent, i.e.
|
|
|
|
// app.Party("/user").Party("/user") should result in a /user/user, not a /user.
|
2020-05-10 23:44:54 +02:00
|
|
|
|
2017-08-13 20:58:34 +02:00
|
|
|
parentPath := api.relativePath
|
2017-07-10 17:32:42 +02:00
|
|
|
dot := string(SubdomainPrefix[0])
|
|
|
|
if len(parentPath) > 0 && parentPath[0] == '/' && strings.HasSuffix(relativePath, dot) {
|
|
|
|
// if ends with . , i.e admin., it's subdomain->
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
parentPath = parentPath[1:] // remove first slash
|
|
|
|
}
|
|
|
|
|
2017-06-12 17:23:35 +02:00
|
|
|
// this is checked later on but for easier debug is better to do it here:
|
2017-08-23 05:14:16 +02:00
|
|
|
if api.relativePath[len(api.relativePath)-1] == '/' && relativePath[0] == '/' {
|
|
|
|
relativePath = relativePath[1:] // remove first slash if parent ended with / and new one started with /.
|
2017-06-12 17:23:35 +02:00
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// if it's subdomain then it has priority, i.e:
|
2017-08-13 20:58:34 +02:00
|
|
|
// api.relativePath == "admin."
|
2017-07-10 17:32:42 +02:00
|
|
|
// relativePath == "panel."
|
|
|
|
// then it should be panel.admin.
|
|
|
|
// instead of admin.panel.
|
|
|
|
if hasSubdomain(parentPath) && hasSubdomain(relativePath) {
|
|
|
|
relativePath = relativePath + parentPath
|
|
|
|
parentPath = ""
|
|
|
|
}
|
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
fullpath := parentPath + relativePath
|
2017-07-23 11:10:51 +02:00
|
|
|
// append the parent's + child's handlers
|
2020-06-19 19:58:24 +02:00
|
|
|
middleware := context.JoinHandlers(api.middleware, handlers)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
|
2018-03-10 13:22:56 +01:00
|
|
|
// the allow methods per party and its children.
|
|
|
|
allowMethods := make([]string, len(api.allowMethods))
|
|
|
|
copy(allowMethods, api.allowMethods)
|
|
|
|
|
2021-01-06 00:52:39 +01:00
|
|
|
// make a copy of the parent properties.
|
2021-04-04 19:24:21 +02:00
|
|
|
properties := make(context.Map, len(api.properties))
|
2021-01-06 00:52:39 +01:00
|
|
|
for k, v := range api.properties {
|
|
|
|
properties[k] = v
|
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
childAPI := &APIBuilder{
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// global/api builder
|
2020-08-21 19:48:41 +02:00
|
|
|
logger: api.logger,
|
2017-08-13 20:58:34 +02:00
|
|
|
macros: api.macros,
|
2021-01-06 00:52:39 +01:00
|
|
|
properties: properties,
|
2017-08-13 20:58:34 +02:00
|
|
|
routes: api.routes,
|
2020-09-14 23:23:09 +02:00
|
|
|
routesNoLog: api.routesNoLog,
|
2017-08-13 20:58:34 +02:00
|
|
|
beginGlobalHandlers: api.beginGlobalHandlers,
|
|
|
|
doneGlobalHandlers: api.doneGlobalHandlers,
|
2020-08-26 05:57:36 +02:00
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// per-party/children
|
2020-08-12 06:20:07 +02:00
|
|
|
parent: api,
|
2018-05-21 06:40:43 +02:00
|
|
|
middleware: middleware,
|
2020-08-15 11:17:48 +02:00
|
|
|
middlewareErrorCode: context.JoinHandlers(api.middlewareErrorCode, context.Handlers{}),
|
2018-05-21 06:40:43 +02:00
|
|
|
doneHandlers: api.doneHandlers[0:],
|
2020-08-26 05:57:36 +02:00
|
|
|
routerFilters: api.routerFilters,
|
|
|
|
routerFilterHandlers: api.routerFilterHandlers,
|
|
|
|
partyMatcher: api.partyMatcher,
|
2018-05-21 06:40:43 +02:00
|
|
|
relativePath: fullpath,
|
|
|
|
allowMethods: allowMethods,
|
|
|
|
handlerExecutionRules: api.handlerExecutionRules,
|
2020-02-10 18:40:17 +01:00
|
|
|
routeRegisterRule: api.routeRegisterRule,
|
2020-04-25 01:30:19 +02:00
|
|
|
apiBuilderDI: &APIContainer{
|
|
|
|
// attach a new Container with correct dynamic path parameter start index for input arguments
|
|
|
|
// based on the fullpath.
|
|
|
|
Container: api.apiBuilderDI.Container.Clone(),
|
|
|
|
},
|
2020-04-08 19:04:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return childAPI
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2017-08-01 21:25:08 +02:00
|
|
|
// PartyFunc same as `Party`, groups routes that share a base path or/and same handlers.
|
|
|
|
// However this function accepts a function that receives this created Party instead.
|
|
|
|
// Returns the Party in order the caller to be able to use this created Party to continue the
|
|
|
|
// top-bottom routes "tree".
|
|
|
|
//
|
|
|
|
// Note: `iris#Party` and `core/router#Party` describes the exactly same interface.
|
|
|
|
//
|
|
|
|
// Usage:
|
|
|
|
// app.PartyFunc("/users", func(u iris.Party){
|
|
|
|
// u.Use(authMiddleware, logMiddleware)
|
|
|
|
// u.Get("/", getAllUsers)
|
|
|
|
// u.Post("/", createOrUpdateUser)
|
|
|
|
// u.Delete("/", deleteUser)
|
|
|
|
// })
|
|
|
|
//
|
|
|
|
// Look `Party` for more.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) PartyFunc(relativePath string, partyBuilderFunc func(p Party)) Party {
|
|
|
|
p := api.Party(relativePath)
|
2017-08-01 21:25:08 +02:00
|
|
|
partyBuilderFunc(p)
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
2021-04-22 13:00:00 +02:00
|
|
|
type (
|
|
|
|
// PartyConfigurator is an interface which all child parties that are registered
|
|
|
|
// through `PartyConfigure` should implement.
|
|
|
|
PartyConfigurator interface {
|
|
|
|
Configure(parent Party)
|
|
|
|
}
|
|
|
|
|
|
|
|
// StrictlyPartyConfigurator is an optional interface which a `PartyConfigurator`
|
|
|
|
// can implement to make sure that all exported fields having a not-nin, non-zero
|
|
|
|
// value before server starts.
|
|
|
|
// StrictlyPartyConfigurator interface {
|
|
|
|
// Strict() bool
|
|
|
|
// }
|
|
|
|
// Good idea but a `mvc or bind:"required"` is a better one I think.
|
|
|
|
)
|
2021-02-17 15:50:36 +01:00
|
|
|
|
2021-03-03 13:39:47 +01:00
|
|
|
// PartyConfigure like `Party` and `PartyFunc` registers a new children Party
|
|
|
|
// but instead it accepts a struct value which should implement the PartyConfigurator interface.
|
|
|
|
//
|
|
|
|
// PartyConfigure accepts the relative path of the child party
|
|
|
|
// (As an exception, if it's empty then all configurators are applied to the current Party)
|
|
|
|
// and one or more Party configurators and
|
|
|
|
// executes the PartyConfigurator's Configure method.
|
2021-02-17 15:50:36 +01:00
|
|
|
//
|
2021-03-03 13:39:47 +01:00
|
|
|
// If the end-developer registered one or more dependencies upfront through
|
2021-02-21 21:24:01 +01:00
|
|
|
// RegisterDependencies or ConfigureContainer.RegisterDependency methods
|
|
|
|
// and "p" is a pointer to a struct then try to bind the unset/zero exported fields
|
|
|
|
// to the registered dependencies, just like we do with Controllers.
|
2021-03-03 13:39:47 +01:00
|
|
|
// Useful when the api's dependencies amount are too much to pass on a function.
|
2021-02-21 21:24:01 +01:00
|
|
|
//
|
2021-02-17 15:50:36 +01:00
|
|
|
// Usage:
|
|
|
|
// app.PartyConfigure("/users", &api.UsersAPI{UserRepository: ..., ...})
|
|
|
|
// Where UsersAPI looks like:
|
|
|
|
// type UsersAPI struct { [...] }
|
|
|
|
// func(api *UsersAPI) Configure(router iris.Party) {
|
|
|
|
// router.Get("/{id:uuid}", api.getUser)
|
|
|
|
// [...]
|
|
|
|
// }
|
2021-02-21 21:24:01 +01:00
|
|
|
// Usage with (static) dependencies:
|
|
|
|
// app.RegisterDependency(userRepo, ...)
|
2021-06-10 20:16:00 +02:00
|
|
|
// app.PartyConfigure("/users", new(api.UsersAPI))
|
2021-02-17 15:57:19 +01:00
|
|
|
func (api *APIBuilder) PartyConfigure(relativePath string, partyReg ...PartyConfigurator) Party {
|
2021-03-03 13:39:47 +01:00
|
|
|
var child Party
|
|
|
|
|
|
|
|
if relativePath == "" {
|
|
|
|
child = api
|
|
|
|
} else {
|
|
|
|
child = api.Party(relativePath)
|
|
|
|
}
|
|
|
|
|
2021-02-17 15:57:19 +01:00
|
|
|
for _, p := range partyReg {
|
2021-02-21 21:24:01 +01:00
|
|
|
if p == nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(api.apiBuilderDI.Container.Dependencies) > 0 {
|
|
|
|
if typ := reflect.TypeOf(p); typ.Kind() == reflect.Ptr && typ.Elem().Kind() == reflect.Struct {
|
|
|
|
api.apiBuilderDI.Container.Struct(p, -1)
|
|
|
|
}
|
2021-02-17 15:57:19 +01:00
|
|
|
}
|
2021-02-21 21:24:01 +01:00
|
|
|
|
|
|
|
p.Configure(child)
|
2021-02-17 15:57:19 +01:00
|
|
|
}
|
2021-03-03 13:39:47 +01:00
|
|
|
|
2021-02-17 15:57:19 +01:00
|
|
|
return child
|
2021-02-17 15:50:36 +01:00
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// Subdomain returns a new party which is responsible to register routes to
|
|
|
|
// this specific "subdomain".
|
|
|
|
//
|
|
|
|
// If called from a child party then the subdomain will be prepended to the path instead of appended.
|
2018-01-20 04:17:31 +01:00
|
|
|
// So if app.Subdomain("admin").Subdomain("panel") then the result is: "panel.admin.".
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Subdomain(subdomain string, middleware ...context.Handler) Party {
|
|
|
|
if api.relativePath == SubdomainWildcardIndicator {
|
2017-07-10 17:32:42 +02:00
|
|
|
// cannot concat wildcard subdomain with something else
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Errorf("cannot concat parent wildcard subdomain with anything else -> %s , %s",
|
2017-08-13 20:58:34 +02:00
|
|
|
api.relativePath, subdomain)
|
|
|
|
return api
|
2017-07-10 17:32:42 +02:00
|
|
|
}
|
2018-01-20 04:17:31 +01:00
|
|
|
if l := len(subdomain); l < 1 {
|
|
|
|
return api
|
|
|
|
} else if subdomain[l-1] != '.' {
|
|
|
|
subdomain += "."
|
|
|
|
}
|
|
|
|
|
2017-08-13 20:58:34 +02:00
|
|
|
return api.Party(subdomain, middleware...)
|
2017-07-10 17:32:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// WildcardSubdomain returns a new party which is responsible to register routes to
|
|
|
|
// a dynamic, wildcard(ed) subdomain. A dynamic subdomain is a subdomain which
|
|
|
|
// can reply to any subdomain requests. Server will accept any subdomain
|
|
|
|
// (if not static subdomain found) and it will search and execute the handlers of this party.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) WildcardSubdomain(middleware ...context.Handler) Party {
|
|
|
|
if hasSubdomain(api.relativePath) {
|
2017-07-10 17:32:42 +02:00
|
|
|
// cannot concat static subdomain with a dynamic one, wildcard should be at the root level
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Errorf("cannot concat static subdomain with a dynamic one. Dynamic subdomains should be at the root level -> %s",
|
2017-08-13 20:58:34 +02:00
|
|
|
api.relativePath)
|
|
|
|
return api
|
2017-07-10 17:32:42 +02:00
|
|
|
}
|
2017-08-13 20:58:34 +02:00
|
|
|
return api.Subdomain(SubdomainWildcardIndicator, middleware...)
|
2017-07-10 17:32:42 +02:00
|
|
|
}
|
|
|
|
|
2018-10-21 18:20:05 +02:00
|
|
|
// Macros returns the macro collection that is responsible
|
|
|
|
// to register custom macros with their own parameter types and their macro functions for all routes.
|
2017-06-12 03:47:16 +02:00
|
|
|
//
|
2017-07-10 17:32:42 +02:00
|
|
|
// Learn more at: https://github.com/kataras/iris/tree/master/_examples/routing/dynamic-path
|
2018-10-21 18:20:05 +02:00
|
|
|
func (api *APIBuilder) Macros() *macro.Macros {
|
2017-08-13 20:58:34 +02:00
|
|
|
return api.macros
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2021-01-06 00:52:39 +01:00
|
|
|
// Properties returns the original Party's properties map,
|
|
|
|
// it can be modified before server startup but not afterwards.
|
|
|
|
func (api *APIBuilder) Properties() context.Map {
|
|
|
|
if api.properties == nil {
|
|
|
|
api.properties = make(context.Map)
|
|
|
|
}
|
|
|
|
|
|
|
|
return api.properties
|
|
|
|
}
|
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// GetRoutes returns the routes information,
|
|
|
|
// some of them can be changed at runtime some others not.
|
|
|
|
//
|
|
|
|
// Needs refresh of the router to Method or Path or Handlers changes to take place.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) GetRoutes() []*Route {
|
|
|
|
return api.routes.getAll()
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetRoute returns the registered route based on its name, otherwise nil.
|
|
|
|
// One note: "routeName" should be case-sensitive.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) GetRoute(routeName string) *Route {
|
|
|
|
return api.routes.get(routeName)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
// GetRouteByPath returns the registered route based on the template path (`Route.Tmpl().Src`).
|
|
|
|
func (api *APIBuilder) GetRouteByPath(tmplPath string) *Route {
|
|
|
|
return api.routes.getByPath(tmplPath)
|
2017-08-23 15:46:55 +02:00
|
|
|
}
|
|
|
|
|
2018-08-05 12:51:05 +02:00
|
|
|
// GetRoutesReadOnly returns the registered routes with "read-only" access,
|
|
|
|
// you cannot and you should not change any of these routes' properties on request state,
|
|
|
|
// you can use the `GetRoutes()` for that instead.
|
|
|
|
//
|
|
|
|
// It returns interface-based slice instead of the real ones in order to apply
|
|
|
|
// safe fetch between context(request-state) and the builded application.
|
|
|
|
//
|
|
|
|
// Look `GetRouteReadOnly` too.
|
|
|
|
func (api *APIBuilder) GetRoutesReadOnly() []context.RouteReadOnly {
|
|
|
|
routes := api.GetRoutes()
|
|
|
|
readOnlyRoutes := make([]context.RouteReadOnly, len(routes))
|
|
|
|
for i, r := range routes {
|
2020-05-10 23:44:54 +02:00
|
|
|
readOnlyRoutes[i] = r.ReadOnly
|
2018-08-05 12:51:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return readOnlyRoutes
|
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
// GetRouteReadOnly returns the registered "read-only" route based on its name, otherwise nil.
|
|
|
|
// One note: "routeName" should be case-sensitive. Used by the context to get the current route.
|
|
|
|
// It returns an interface instead to reduce wrong usage and to keep the decoupled design between
|
|
|
|
// the context and the routes.
|
|
|
|
// Look `GetRoutesReadOnly` to fetch a list of all registered routes.
|
|
|
|
//
|
|
|
|
// Look `GetRoute` for more.
|
|
|
|
func (api *APIBuilder) GetRouteReadOnly(routeName string) context.RouteReadOnly {
|
|
|
|
r := api.GetRoute(routeName)
|
|
|
|
if r == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2020-05-10 23:44:54 +02:00
|
|
|
return r.ReadOnly
|
2019-06-21 18:43:25 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetRouteReadOnlyByPath returns the registered read-only route based on the template path (`Route.Tmpl().Src`).
|
|
|
|
func (api *APIBuilder) GetRouteReadOnlyByPath(tmplPath string) context.RouteReadOnly {
|
|
|
|
r := api.GetRouteByPath(tmplPath)
|
|
|
|
if r == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-05-10 23:44:54 +02:00
|
|
|
return r.ReadOnly
|
2019-06-21 18:43:25 +02:00
|
|
|
}
|
|
|
|
|
2020-09-14 23:23:09 +02:00
|
|
|
// SetRoutesNoLog disables (true) the verbose logging for the next registered
|
|
|
|
// routes under this Party and its children.
|
|
|
|
//
|
|
|
|
// To disable logging for controllers under MVC Application,
|
|
|
|
// see `mvc/Application.SetControllersNoLog` instead.
|
|
|
|
//
|
|
|
|
// Defaults to false when log level is "debug".
|
|
|
|
func (api *APIBuilder) SetRoutesNoLog(disable bool) Party {
|
|
|
|
api.routesNoLog = disable
|
|
|
|
return api
|
|
|
|
}
|
|
|
|
|
2020-08-12 06:20:07 +02:00
|
|
|
type (
|
|
|
|
// PartyMatcherFunc used to build a filter which decides
|
|
|
|
// if the given Party is responsible to fire its `UseRouter` handlers or not.
|
|
|
|
// Can be customized through `SetPartyMatcher` method. See `Match` method too.
|
2020-08-26 05:57:36 +02:00
|
|
|
PartyMatcherFunc func(*context.Context, Party) bool
|
2020-08-12 06:20:07 +02:00
|
|
|
// PartyMatcher decides if `UseRouter` handlers should be executed or not.
|
|
|
|
// A different interface becauwe we want to separate
|
|
|
|
// the Party's public API from `UseRouter` internals.
|
|
|
|
PartyMatcher interface {
|
|
|
|
Match(ctx *context.Context) bool
|
|
|
|
}
|
|
|
|
// Filter is a wraper for a Router Filter contains information
|
|
|
|
// for its Party's fullpath, subdomain the Party's
|
|
|
|
// matcher and the associated handlers to be executed before main router's request handler.
|
|
|
|
Filter struct {
|
2020-08-26 05:57:36 +02:00
|
|
|
Matcher PartyMatcher // it's a Party, for freedom that can be changed through a custom matcher which accepts the same filter.
|
|
|
|
Skippers map[*APIBuilder]struct{} // skip execution on these builders ( see `Reset`)
|
2020-08-12 06:20:07 +02:00
|
|
|
Subdomain string
|
|
|
|
Path string
|
|
|
|
Handlers context.Handlers
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
// SetPartyMatcher accepts a function which runs against
|
|
|
|
// a Party and should report whether its `UseRouter` handlers should be executed.
|
|
|
|
// PartyMatchers are run through parent to children.
|
|
|
|
// It modifies the default Party filter that decides
|
|
|
|
// which `UseRouter` middlewares to run before the Router,
|
|
|
|
// each one of those middlewares can skip `Context.Next` or call `Context.StopXXX`
|
|
|
|
// to stop the main router from searching for a route match.
|
|
|
|
// Can be called before or after `UseRouter`, it doesn't matter.
|
|
|
|
func (api *APIBuilder) SetPartyMatcher(matcherFunc PartyMatcherFunc) {
|
|
|
|
if matcherFunc == nil {
|
|
|
|
matcherFunc = defaultPartyMatcher
|
|
|
|
}
|
|
|
|
api.partyMatcher = matcherFunc
|
|
|
|
}
|
|
|
|
|
|
|
|
// Match reports whether the `UseRouter` handlers should be executed.
|
|
|
|
// Calls its parent's Match if possible.
|
|
|
|
// Implements the `PartyMatcher` interface.
|
|
|
|
func (api *APIBuilder) Match(ctx *context.Context) bool {
|
2020-08-26 05:57:36 +02:00
|
|
|
return api.partyMatcher(ctx, api)
|
2020-08-12 06:20:07 +02:00
|
|
|
}
|
|
|
|
|
2020-08-26 05:57:36 +02:00
|
|
|
func defaultPartyMatcher(ctx *context.Context, p Party) bool {
|
2020-08-12 06:20:07 +02:00
|
|
|
subdomain, path := splitSubdomainAndPath(p.GetRelPath())
|
|
|
|
staticPath := staticPath(path)
|
|
|
|
hosts := subdomain != ""
|
|
|
|
|
|
|
|
if p.IsRoot() {
|
|
|
|
// ALWAYS executed first when registered
|
|
|
|
// through an `Application.UseRouter` call.
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
if hosts {
|
|
|
|
// Note(@kataras): do NOT try to implement something like party matcher for each party
|
|
|
|
// separately. We will introduce a new problem with subdomain inside a subdomain:
|
|
|
|
// they are not by prefix, so parenting calls will not help
|
|
|
|
// e.g. admin. and control.admin, control.admin is a sub of the admin.
|
|
|
|
if !canHandleSubdomain(ctx, subdomain) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// this is the longest static path.
|
|
|
|
return strings.HasPrefix(ctx.Path(), staticPath)
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetRouterFilters returns the global router filters.
|
|
|
|
// Read `UseRouter` for more.
|
|
|
|
// The map can be altered before router built.
|
|
|
|
// The router internally prioritized them by the subdomains and
|
|
|
|
// longest static path.
|
|
|
|
// Implements the `RoutesProvider` interface.
|
|
|
|
func (api *APIBuilder) GetRouterFilters() map[Party]*Filter {
|
|
|
|
return api.routerFilters
|
|
|
|
}
|
|
|
|
|
|
|
|
// UseRouter upserts one or more handlers that will be fired
|
|
|
|
// right before the main router's request handler.
|
|
|
|
//
|
|
|
|
// Use this method to register handlers, that can ran
|
|
|
|
// independently of the incoming request's values,
|
|
|
|
// that they will be executed ALWAYS against ALL children incoming requests.
|
|
|
|
// Example of use-case: CORS.
|
|
|
|
//
|
|
|
|
// Note that because these are executed before the router itself
|
|
|
|
// the Context should not have access to the `GetCurrentRoute`
|
|
|
|
// as it is not decided yet which route is responsible to handle the incoming request.
|
|
|
|
// It's one level higher than the `WrapRouter`.
|
|
|
|
// The context SHOULD call its `Next` method in order to proceed to
|
|
|
|
// the next handler in the chain or the main request handler one.
|
|
|
|
func (api *APIBuilder) UseRouter(handlers ...context.Handler) {
|
2020-09-11 08:38:55 +02:00
|
|
|
if len(handlers) == 0 || handlers[0] == nil {
|
2020-08-12 06:20:07 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
beginHandlers := context.Handlers(handlers)
|
|
|
|
// respect any execution rules (begin).
|
|
|
|
api.handlerExecutionRules.Begin.apply(&beginHandlers)
|
2020-08-26 05:57:36 +02:00
|
|
|
beginHandlers = context.JoinHandlers(api.routerFilterHandlers, beginHandlers)
|
2020-08-12 06:20:07 +02:00
|
|
|
|
|
|
|
if f := api.routerFilters[api]; f != nil && len(f.Handlers) > 0 { // exists.
|
|
|
|
beginHandlers = context.UpsertHandlers(f.Handlers, beginHandlers) // remove dupls.
|
|
|
|
}
|
|
|
|
|
2020-08-26 05:57:36 +02:00
|
|
|
// we are not using the parent field here,
|
|
|
|
// we need to have control over those values in order to be able to `Reset`.
|
|
|
|
api.routerFilterHandlers = beginHandlers
|
|
|
|
|
2020-08-12 06:20:07 +02:00
|
|
|
subdomain, path := splitSubdomainAndPath(api.relativePath)
|
|
|
|
api.routerFilters[api] = &Filter{
|
|
|
|
Matcher: api,
|
|
|
|
Subdomain: subdomain,
|
|
|
|
Path: path,
|
|
|
|
Handlers: beginHandlers,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-18 04:42:48 +02:00
|
|
|
// GetDefaultErrorMiddleware returns the application's error pre handlers
|
|
|
|
// registered through `UseError` for the default error handlers.
|
|
|
|
// This is used when no matching error handlers registered
|
|
|
|
// for a specific status code but `UseError` is called to register a middleware,
|
|
|
|
// so the default error handler should make use of those middleware now.
|
|
|
|
func (api *APIBuilder) GetDefaultErrorMiddleware() context.Handlers {
|
|
|
|
return api.middlewareErrorCode
|
|
|
|
}
|
|
|
|
|
2020-08-15 11:17:48 +02:00
|
|
|
// UseError upserts one or more handlers that will be fired,
|
|
|
|
// as middleware, before any error handler registered through `On(Any)ErrorCode`.
|
|
|
|
// See `OnErrorCode` too.
|
|
|
|
func (api *APIBuilder) UseError(handlers ...context.Handler) {
|
|
|
|
api.middlewareErrorCode = context.UpsertHandlers(api.middlewareErrorCode, handlers)
|
|
|
|
}
|
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// Use appends Handler(s) to the current Party's routes and child routes.
|
|
|
|
// If the current Party is the root, then it registers the middleware to all child Parties' routes too.
|
2020-08-31 04:07:55 +02:00
|
|
|
// The given "handlers" will be executed only on matched routes.
|
2017-07-23 11:10:51 +02:00
|
|
|
//
|
|
|
|
// Call order matters, it should be called right before the routes that they care about these handlers.
|
|
|
|
//
|
|
|
|
// If it's called after the routes then these handlers will never be executed.
|
|
|
|
// Use `UseGlobal` if you want to register begin handlers(middleware)
|
|
|
|
// that should be always run before all application's routes.
|
2020-08-15 11:24:51 +02:00
|
|
|
// To register a middleware for error handlers, look `UseError` method instead.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Use(handlers ...context.Handler) {
|
|
|
|
api.middleware = append(api.middleware, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-08-06 02:35:58 +02:00
|
|
|
// UseOnce either inserts a middleware,
|
|
|
|
// or on the basis of the middleware already existing,
|
|
|
|
// replace that existing middleware instead.
|
2020-08-15 11:24:51 +02:00
|
|
|
// To register a middleware for error handlers, look `UseError` method instead.
|
2020-08-06 02:35:58 +02:00
|
|
|
func (api *APIBuilder) UseOnce(handlers ...context.Handler) {
|
2020-08-12 06:20:07 +02:00
|
|
|
api.middleware = context.UpsertHandlers(api.middleware, handlers)
|
2020-08-06 02:35:58 +02:00
|
|
|
}
|
|
|
|
|
2018-02-08 13:04:39 +01:00
|
|
|
// UseGlobal registers handlers that should run at the very beginning.
|
|
|
|
// It prepends those handler(s) to all routes,
|
2020-08-25 23:07:07 +02:00
|
|
|
// including all parties, subdomains and errors.
|
2017-07-23 11:10:51 +02:00
|
|
|
// It doesn't care about call order, it will prepend the handlers to all
|
|
|
|
// existing routes and the future routes that may being registered.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
2020-08-31 04:07:55 +02:00
|
|
|
// The given "handlers" will be executed only on matched routes and registered errors.
|
|
|
|
// See `UseRouter` if you want to register middleware that will always run, even on 404 not founds.
|
|
|
|
//
|
2020-01-09 07:15:01 +01:00
|
|
|
// The difference from `.DoneGlobal` is that this/or these Handler(s) are being always running first.
|
2018-02-08 13:04:39 +01:00
|
|
|
// Use of `ctx.Next()` of those handler(s) is necessary to call the main handler or the next middleware.
|
2017-07-23 11:10:51 +02:00
|
|
|
// It's always a good practise to call it right before the `Application#Run` function.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) UseGlobal(handlers ...context.Handler) {
|
|
|
|
for _, r := range api.routes.routes {
|
2020-07-06 18:08:02 +02:00
|
|
|
// r.beginHandlers = append(handlers, r.beginHandlers...)
|
|
|
|
// ^ this is correct but we act global begin handlers as one chain, so
|
|
|
|
// if called last more than one time, after all routes registered, we must somehow
|
|
|
|
// register them by order, so:
|
|
|
|
r.Use(handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
2017-07-23 11:10:51 +02:00
|
|
|
// set as begin handlers for the next routes as well.
|
2017-08-13 20:58:34 +02:00
|
|
|
api.beginGlobalHandlers = append(api.beginGlobalHandlers, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2018-02-08 13:04:39 +01:00
|
|
|
// Done appends to the very end, Handler(s) to the current Party's routes and child routes.
|
2020-08-31 04:07:55 +02:00
|
|
|
// The given "handlers" will be executed only on matched routes.
|
2018-02-08 13:04:39 +01:00
|
|
|
//
|
|
|
|
// Call order matters, it should be called right before the routes that they care about these handlers.
|
|
|
|
//
|
|
|
|
// The difference from .Use is that this/or these Handler(s) are being always running last.
|
|
|
|
func (api *APIBuilder) Done(handlers ...context.Handler) {
|
|
|
|
api.doneHandlers = append(api.doneHandlers, handlers...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// DoneGlobal registers handlers that should run at the very end.
|
|
|
|
// It appends those handler(s) to all routes,
|
|
|
|
// including all parties, subdomains.
|
|
|
|
// It doesn't care about call order, it will append the handlers to all
|
|
|
|
// existing routes and the future routes that may being registered.
|
|
|
|
//
|
2020-08-31 04:07:55 +02:00
|
|
|
// The given "handlers" will be executed only on matched and registered error routes.
|
|
|
|
//
|
2018-02-08 13:04:39 +01:00
|
|
|
// The difference from `.UseGlobal` is that this/or these Handler(s) are being always running last.
|
|
|
|
// Use of `ctx.Next()` at the previous handler is necessary.
|
|
|
|
// It's always a good practise to call it right before the `Application#Run` function.
|
|
|
|
func (api *APIBuilder) DoneGlobal(handlers ...context.Handler) {
|
|
|
|
for _, r := range api.routes.routes {
|
2019-06-21 18:43:25 +02:00
|
|
|
r.Done(handlers...) // append the handlers to the existing routes
|
2018-02-08 13:04:39 +01:00
|
|
|
}
|
|
|
|
// set as done handlers for the next routes as well.
|
|
|
|
api.doneGlobalHandlers = append(api.doneGlobalHandlers, handlers...)
|
|
|
|
}
|
|
|
|
|
2020-10-12 11:56:54 +02:00
|
|
|
// RemoveHandler deletes a handler from begin and done handlers
|
|
|
|
// based on its name or the handler pc function.
|
2021-01-06 00:52:39 +01:00
|
|
|
// Note that UseGlobal and DoneGlobal handlers cannot be removed
|
|
|
|
// through this method as they were registered to the routes already.
|
2020-10-12 11:56:54 +02:00
|
|
|
//
|
|
|
|
// As an exception, if one of the arguments is a pointer to an int,
|
|
|
|
// then this is used to set the total amount of removed handlers.
|
|
|
|
//
|
|
|
|
// Returns the Party itself for chain calls.
|
|
|
|
//
|
|
|
|
// Should be called before children routes regitration.
|
|
|
|
func (api *APIBuilder) RemoveHandler(namesOrHandlers ...interface{}) Party {
|
|
|
|
var counter *int
|
|
|
|
|
|
|
|
for _, nameOrHandler := range namesOrHandlers {
|
|
|
|
handlerName := ""
|
|
|
|
switch h := nameOrHandler.(type) {
|
|
|
|
case string:
|
|
|
|
handlerName = h
|
2021-01-27 00:22:20 +01:00
|
|
|
case context.Handler, func(*context.Context):
|
2020-10-12 11:56:54 +02:00
|
|
|
handlerName = context.HandlerName(h)
|
|
|
|
case *int:
|
|
|
|
counter = h
|
|
|
|
default:
|
|
|
|
panic(fmt.Sprintf("remove handler: unexpected type of %T", h))
|
|
|
|
}
|
|
|
|
|
|
|
|
api.middleware = removeHandler(handlerName, api.middleware, counter)
|
|
|
|
api.doneHandlers = removeHandler(handlerName, api.doneHandlers, counter)
|
|
|
|
}
|
|
|
|
|
|
|
|
return api
|
|
|
|
}
|
|
|
|
|
2018-02-08 13:04:39 +01:00
|
|
|
// Reset removes all the begin and done handlers that may derived from the parent party via `Use` & `Done`,
|
2018-05-21 06:40:43 +02:00
|
|
|
// and the execution rules.
|
|
|
|
// Note that the `Reset` will not reset the handlers that are registered via `UseGlobal` & `DoneGlobal`.
|
2018-02-08 13:04:39 +01:00
|
|
|
//
|
|
|
|
// Returns this Party.
|
|
|
|
func (api *APIBuilder) Reset() Party {
|
|
|
|
api.middleware = api.middleware[0:0]
|
2020-08-15 11:17:48 +02:00
|
|
|
api.middlewareErrorCode = api.middlewareErrorCode[0:0]
|
2020-08-26 05:57:36 +02:00
|
|
|
api.ResetRouterFilters()
|
|
|
|
|
2018-02-08 13:04:39 +01:00
|
|
|
api.doneHandlers = api.doneHandlers[0:0]
|
2018-05-21 06:40:43 +02:00
|
|
|
api.handlerExecutionRules = ExecutionRules{}
|
2020-02-11 02:24:57 +01:00
|
|
|
api.routeRegisterRule = RouteOverride
|
2020-08-26 05:57:36 +02:00
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
// keep container as it's.
|
2018-02-08 13:04:39 +01:00
|
|
|
return api
|
|
|
|
}
|
|
|
|
|
2020-08-28 03:11:56 +02:00
|
|
|
// ResetRouterFilters deactivates any previous registered
|
2020-08-26 05:57:36 +02:00
|
|
|
// router filters and the parents ones for this Party.
|
|
|
|
//
|
|
|
|
// Returns this Party.
|
|
|
|
func (api *APIBuilder) ResetRouterFilters() Party {
|
|
|
|
api.routerFilterHandlers = api.routerFilterHandlers[0:0]
|
|
|
|
delete(api.routerFilters, api)
|
|
|
|
|
|
|
|
if api.parent == nil {
|
|
|
|
// it's the root, stop, nothing else to do here.
|
|
|
|
return api
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set a filter with empty handlers, the router will find it, execute nothing
|
|
|
|
// and continue with the request handling. This works on Reset() and no UseRouter
|
|
|
|
// and with Reset().UseRouter.
|
|
|
|
subdomain, path := splitSubdomainAndPath(api.relativePath)
|
|
|
|
api.routerFilters[api] = &Filter{
|
|
|
|
Matcher: api,
|
|
|
|
Handlers: nil,
|
|
|
|
Subdomain: subdomain,
|
|
|
|
Path: path,
|
|
|
|
}
|
|
|
|
|
|
|
|
return api
|
|
|
|
}
|
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// None registers an "offline" route
|
|
|
|
// see context.ExecRoute(routeName) and
|
|
|
|
// party.Routes().Online(handleResultRouteInfo, "GET") and
|
|
|
|
// Offline(handleResultRouteInfo)
|
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) None(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(MethodNone, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Get registers a route for the Get HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Get(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodGet, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Post registers a route for the Post HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Post(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodPost, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Put registers a route for the Put HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Put(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodPut, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Delete registers a route for the Delete HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Delete(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodDelete, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Connect registers a route for the Connect HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Connect(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodConnect, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Head registers a route for the Head HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Head(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodHead, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Options registers a route for the Options HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Options(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodOptions, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Patch registers a route for the Patch HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Patch(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodPatch, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Trace registers a route for the Trace HTTP Method.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Returns a *Route and an error which will be filled if route wasn't registered successfully.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Trace(relativePath string, handlers ...context.Handler) *Route {
|
|
|
|
return api.Handle(http.MethodTrace, relativePath, handlers...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-04-08 19:04:56 +02:00
|
|
|
// Any registers a route for ALL of the HTTP methods:
|
|
|
|
// Get
|
|
|
|
// Post
|
|
|
|
// Put
|
|
|
|
// Delete
|
|
|
|
// Head
|
|
|
|
// Patch
|
|
|
|
// Options
|
|
|
|
// Connect
|
|
|
|
// Trace
|
2017-08-18 16:09:18 +02:00
|
|
|
func (api *APIBuilder) Any(relativePath string, handlers ...context.Handler) (routes []*Route) {
|
|
|
|
for _, m := range AllMethods {
|
|
|
|
r := api.HandleMany(m, relativePath, handlers...)
|
|
|
|
routes = append(routes, r...)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
2017-06-15 19:02:08 +02:00
|
|
|
|
2017-08-18 16:09:18 +02:00
|
|
|
return
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
func (api *APIBuilder) registerResourceRoute(reqPath string, h context.Handler) *Route {
|
|
|
|
api.Head(reqPath, h)
|
|
|
|
return api.Get(reqPath, h)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// StaticContent registers a GET and HEAD method routes to the requestPath
|
|
|
|
// that are ready to serve raw static bytes, memory cached.
|
|
|
|
//
|
|
|
|
// Returns the GET *Route.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) StaticContent(reqPath string, cType string, content []byte) *Route {
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
modtime := time.Now()
|
2020-07-10 22:21:09 +02:00
|
|
|
h := func(ctx *context.Context) {
|
2017-07-10 17:32:42 +02:00
|
|
|
ctx.ContentType(cType)
|
|
|
|
if _, err := ctx.WriteWithExpiration(content, modtime); err != nil {
|
|
|
|
ctx.StatusCode(http.StatusInternalServerError)
|
|
|
|
// ctx.Application().Logger().Infof("error while serving []byte via StaticContent: %s", err.Error())
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
return api.registerResourceRoute(reqPath, h)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Favicon serves static favicon
|
|
|
|
// accepts 2 parameters, second is optional
|
|
|
|
// favPath (string), declare the system directory path of the __.ico
|
|
|
|
// requestPath (string), it's the route's path, by default this is the "/favicon.ico" because some browsers tries to get this by default first,
|
|
|
|
// you can declare your own path if you have more than one favicon (desktop, mobile and so on)
|
|
|
|
//
|
|
|
|
// this func will add a route for you which will static serve the /yuorpath/yourfile.ico to the /yourfile.ico
|
|
|
|
// (nothing special that you can't handle by yourself).
|
|
|
|
// Note that you have to call it on every favicon you have to serve automatically (desktop, mobile and so on).
|
|
|
|
//
|
|
|
|
// Returns the GET *Route.
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Favicon(favPath string, requestPath ...string) *Route {
|
2020-04-26 16:23:38 +02:00
|
|
|
description := favPath
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
favPath = Abs(favPath)
|
|
|
|
f, err := os.Open(favPath)
|
|
|
|
if err != nil {
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Errorf("favicon: file or directory %s not found: %w", favPath, err)
|
2017-07-10 17:32:42 +02:00
|
|
|
return nil
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
defer f.Close()
|
|
|
|
fi, _ := f.Stat()
|
|
|
|
if fi.IsDir() { // if it's dir the try to get the favicon.ico
|
2017-10-02 03:01:23 +02:00
|
|
|
return api.Favicon(path.Join(favPath, "favicon.ico"))
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// copy the bytes here in order to cache and not read the ico on each request.
|
|
|
|
cacheFav := make([]byte, fi.Size())
|
|
|
|
if _, err = f.Read(cacheFav); err != nil {
|
|
|
|
// Here we are before actually run the server.
|
|
|
|
// So we could panic but we don't,
|
|
|
|
// we just interrupt with a message
|
|
|
|
// to the (user-defined) logger.
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Errorf("favicon: couldn't read the data bytes for %s: %w", favPath, err)
|
2017-07-10 17:32:42 +02:00
|
|
|
return nil
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2018-01-25 02:16:49 +01:00
|
|
|
modtime := time.Now()
|
|
|
|
cType := TypeByFilename(favPath)
|
2020-07-10 22:21:09 +02:00
|
|
|
h := func(ctx *context.Context) {
|
2018-01-25 02:16:49 +01:00
|
|
|
ctx.ContentType(cType)
|
|
|
|
if _, err := ctx.WriteWithExpiration(cacheFav, modtime); err != nil {
|
2017-06-15 19:02:08 +02:00
|
|
|
ctx.StatusCode(http.StatusInternalServerError)
|
2018-01-25 02:16:49 +01:00
|
|
|
ctx.Application().Logger().Debugf("while trying to serve the favicon: %s", err.Error())
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-02 03:01:23 +02:00
|
|
|
reqPath := "/favicon" + path.Ext(fi.Name()) // we could use the filename, but because standards is /favicon.ico
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
if len(requestPath) > 0 && requestPath[0] != "" {
|
|
|
|
reqPath = requestPath[0]
|
|
|
|
}
|
|
|
|
|
2020-04-28 21:34:36 +02:00
|
|
|
return api.registerResourceRoute(reqPath, h).Describe(description)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-05-16 22:40:42 +02:00
|
|
|
// OnErrorCode registers a handlers chain for this `Party` for a specific HTTP status code.
|
|
|
|
// Read more at: http://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml
|
2020-08-15 11:17:48 +02:00
|
|
|
// Look `UseError` and `OnAnyErrorCode` too.
|
2020-05-17 02:25:32 +02:00
|
|
|
func (api *APIBuilder) OnErrorCode(statusCode int, handlers ...context.Handler) (routes []*Route) {
|
|
|
|
routes = append(routes, api.handle(statusCode, "", "/", handlers...))
|
2020-05-11 10:11:27 +02:00
|
|
|
|
2020-05-10 23:44:54 +02:00
|
|
|
if api.relativePath != "/" {
|
2020-05-17 02:25:32 +02:00
|
|
|
routes = append(routes, api.handle(statusCode, "", "/{tail:path}", handlers...))
|
2017-10-01 15:29:25 +02:00
|
|
|
}
|
2020-05-17 02:25:32 +02:00
|
|
|
|
|
|
|
return
|
2017-07-16 12:58:10 +02:00
|
|
|
}
|
|
|
|
|
2020-05-16 22:40:42 +02:00
|
|
|
// OnAnyErrorCode registers a handlers chain for all error codes
|
2020-06-08 04:16:55 +02:00
|
|
|
// (4xxx and 5xxx, change the `context.ClientErrorCodes` and `context.ServerErrorCodes` variables to modify those)
|
2020-08-15 11:17:48 +02:00
|
|
|
// Look `UseError` and `OnErrorCode` too.
|
2020-05-17 02:25:32 +02:00
|
|
|
func (api *APIBuilder) OnAnyErrorCode(handlers ...context.Handler) (routes []*Route) {
|
2020-06-08 04:16:55 +02:00
|
|
|
for _, statusCode := range context.ClientAndServerErrorCodes {
|
2020-05-17 02:25:32 +02:00
|
|
|
routes = append(routes, api.OnErrorCode(statusCode, handlers...)...)
|
2017-07-16 12:58:10 +02:00
|
|
|
}
|
2020-05-17 02:25:32 +02:00
|
|
|
|
2020-08-22 07:04:22 +02:00
|
|
|
if n := len(routes); n > 1 {
|
|
|
|
for _, r := range routes[1:n] {
|
|
|
|
r.NoLog = true
|
|
|
|
}
|
|
|
|
|
|
|
|
routes[0].Title = "ERR"
|
|
|
|
}
|
|
|
|
|
2020-05-17 02:25:32 +02:00
|
|
|
return
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-09-29 18:19:19 +02:00
|
|
|
// RegisterView registers and loads a view engine middleware for this group of routes.
|
2020-08-05 18:34:55 +02:00
|
|
|
// It overrides any of the application's root registered view engines.
|
|
|
|
// To register a view engine per handler chain see the `Context.ViewEngine` instead.
|
|
|
|
// Read `Configuration.ViewEngineContextKey` documentation for more.
|
|
|
|
func (api *APIBuilder) RegisterView(viewEngine context.ViewEngine) {
|
|
|
|
if err := viewEngine.Load(); err != nil {
|
2020-08-24 20:44:29 +02:00
|
|
|
api.logger.Error(err)
|
2020-08-05 18:34:55 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2020-08-15 11:17:48 +02:00
|
|
|
handler := func(ctx *context.Context) {
|
2020-08-05 18:34:55 +02:00
|
|
|
ctx.ViewEngine(viewEngine)
|
|
|
|
ctx.Next()
|
2020-08-15 11:17:48 +02:00
|
|
|
}
|
|
|
|
api.Use(handler)
|
|
|
|
api.UseError(handler)
|
2020-08-05 18:34:55 +02:00
|
|
|
// Note (@kataras): It does not return the Party in order
|
|
|
|
// to keep the iris.Application a compatible Party.
|
|
|
|
}
|
|
|
|
|
2021-01-24 13:08:37 +01:00
|
|
|
// FallbackView registers one or more fallback views for a template or a template layout.
|
|
|
|
// Usage:
|
|
|
|
// FallbackView(iris.FallbackView("fallback.html"))
|
|
|
|
// FallbackView(iris.FallbackViewLayout("layouts/fallback.html"))
|
|
|
|
// OR
|
|
|
|
// FallbackView(iris.FallbackViewFunc(ctx iris.Context, err iris.ErrViewNotExist) error {
|
|
|
|
// err.Name is the previous template name.
|
|
|
|
// err.IsLayout reports whether the failure came from the layout template.
|
|
|
|
// err.Data is the template data provided to the previous View call.
|
|
|
|
// [...custom logic e.g. ctx.View("fallback", err.Data)]
|
|
|
|
// })
|
|
|
|
func (api *APIBuilder) FallbackView(provider context.FallbackViewProvider) {
|
|
|
|
handler := func(ctx *context.Context) {
|
|
|
|
ctx.FallbackView(provider)
|
|
|
|
ctx.Next()
|
|
|
|
}
|
|
|
|
api.Use(handler)
|
|
|
|
api.UseError(handler)
|
|
|
|
}
|
|
|
|
|
2018-01-25 02:16:49 +01:00
|
|
|
// Layout overrides the parent template layout with a more specific layout for this Party.
|
|
|
|
// It returns the current Party.
|
|
|
|
//
|
|
|
|
// The "tmplLayoutFile" should be a relative path to the templates dir.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// Usage:
|
2018-01-25 02:16:49 +01:00
|
|
|
//
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// app := iris.New()
|
2018-01-25 02:16:49 +01:00
|
|
|
// app.RegisterView(iris.$VIEW_ENGINE("./views", ".$extension"))
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// my := app.Party("/my").Layout("layouts/mylayout.html")
|
2018-01-25 02:16:49 +01:00
|
|
|
// my.Get("/", func(ctx iris.Context) {
|
|
|
|
// ctx.View("page1.html")
|
|
|
|
// })
|
|
|
|
//
|
|
|
|
// Examples: https://github.com/kataras/iris/tree/master/_examples/view
|
2017-08-13 20:58:34 +02:00
|
|
|
func (api *APIBuilder) Layout(tmplLayoutFile string) Party {
|
2020-08-15 11:17:48 +02:00
|
|
|
handler := func(ctx *context.Context) {
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
ctx.ViewLayout(tmplLayoutFile)
|
|
|
|
ctx.Next()
|
2020-08-15 11:17:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
api.Use(handler)
|
|
|
|
api.UseError(handler)
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
|
2017-08-13 20:58:34 +02:00
|
|
|
return api
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
}
|
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
// https://golang.org/doc/go1.9#callersframes
|
|
|
|
func getCaller() (string, int) {
|
|
|
|
var pcs [32]uintptr
|
|
|
|
n := runtime.Callers(1, pcs[:])
|
|
|
|
frames := runtime.CallersFrames(pcs[:n])
|
|
|
|
wd, _ := os.Getwd()
|
2020-05-27 11:02:17 +02:00
|
|
|
|
|
|
|
var (
|
|
|
|
frame runtime.Frame
|
|
|
|
more = true
|
|
|
|
)
|
|
|
|
|
2020-02-29 13:18:15 +01:00
|
|
|
for {
|
2020-05-27 11:02:17 +02:00
|
|
|
if !more {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
|
|
|
frame, more = frames.Next()
|
2020-05-11 10:11:27 +02:00
|
|
|
file := filepath.ToSlash(frame.File)
|
2020-05-27 11:02:17 +02:00
|
|
|
// fmt.Printf("%s:%d | %s\n", file, frame.Line, frame.Function)
|
2020-02-29 13:18:15 +01:00
|
|
|
|
2020-05-27 11:02:17 +02:00
|
|
|
if strings.Contains(file, "go/src/runtime/") {
|
|
|
|
continue
|
2020-05-11 10:11:27 +02:00
|
|
|
}
|
|
|
|
|
2020-05-27 11:02:17 +02:00
|
|
|
if !strings.Contains(file, "_test.go") {
|
|
|
|
if strings.Contains(file, "/kataras/iris") &&
|
|
|
|
!strings.Contains(file, "kataras/iris/_examples") &&
|
|
|
|
!strings.Contains(file, "kataras/iris/middleware") &&
|
|
|
|
!strings.Contains(file, "iris-contrib/examples") {
|
|
|
|
continue
|
2020-05-11 10:11:27 +02:00
|
|
|
}
|
2020-03-02 09:07:44 +01:00
|
|
|
}
|
|
|
|
|
2020-05-11 10:11:27 +02:00
|
|
|
if relFile, err := filepath.Rel(wd, file); err == nil {
|
|
|
|
if !strings.HasPrefix(relFile, "..") {
|
|
|
|
// Only if it's relative to this path, not parent.
|
2020-08-27 06:23:56 +02:00
|
|
|
file = "./" + filepath.ToSlash(relFile)
|
2020-02-29 13:18:15 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-11 10:11:27 +02:00
|
|
|
return file, frame.Line
|
2020-02-29 13:18:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return "???", 0
|
|
|
|
}
|