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 (
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12/context"
|
|
|
|
"github.com/kataras/iris/v12/macro"
|
2020-08-16 06:07:36 +02:00
|
|
|
|
|
|
|
"github.com/kataras/golog"
|
2017-08-01 21:25:08 +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
|
|
|
// Party is just a group joiner of routes which have the same prefix and share same middleware(s) also.
|
|
|
|
// Party could also be named as 'Join' or 'Node' or 'Group' , Party chosen because it is fun.
|
|
|
|
//
|
2020-04-17 14:56:36 +02:00
|
|
|
// Look the `APIBuilder` structure for its implementation.
|
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
|
|
|
type Party interface {
|
2020-08-16 06:07:36 +02:00
|
|
|
// Logger returns the Application Logger.
|
|
|
|
Logger() *golog.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.
|
|
|
|
IsRoot() bool
|
|
|
|
|
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.
|
|
|
|
ConfigureContainer(builder ...func(*APIContainer)) *APIContainer
|
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.
|
|
|
|
RegisterDependency(dependencies ...interface{})
|
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
// This method is just a shortcut for the `ConfigureContainer().Handle` one.
|
|
|
|
HandleFunc(method, relativePath string, handlersFn ...interface{}) *Route
|
2020-04-08 19:04:56 +02:00
|
|
|
|
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.".
|
|
|
|
GetRelPath() string
|
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-11-27 20:39:57 +01:00
|
|
|
//
|
|
|
|
// Learn more at: https://github.com/kataras/iris/tree/master/_examples/routing/dynamic-path
|
2018-10-21 18:20:05 +02:00
|
|
|
Macros() *macro.Macros
|
2017-11-27 20:39:57 +01: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.
|
|
|
|
Properties() context.Map
|
|
|
|
|
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".
|
|
|
|
SetRoutesNoLog(disable bool) Party
|
|
|
|
|
2020-05-16 22:40:42 +02:00
|
|
|
// OnErrorCode registers a handlers chain for this `Party` for a specific HTTP status code.
|
2020-05-10 23:44:54 +02:00
|
|
|
// 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
|
|
|
OnErrorCode(statusCode int, handlers ...context.Handler) []*Route
|
2020-05-16 22:40:42 +02:00
|
|
|
// OnAnyErrorCode registers a handlers chain for all error codes
|
|
|
|
// (4xxx and 5xxx, change the `ClientErrorCodes` and `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
|
|
|
OnAnyErrorCode(handlers ...context.Handler) []*Route
|
2020-05-10 23:44:54 +02:00
|
|
|
|
2020-08-12 06:20:07 +02:00
|
|
|
// Party returns a new child Party which inherites its
|
|
|
|
// parent's options and middlewares.
|
|
|
|
// If "relativePath" matches the parent's one then it returns the current Party.
|
|
|
|
// 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
|
|
|
|
// or pass a "relativePath" as "admin." or "*." respectfully.
|
2017-07-10 17:32:42 +02:00
|
|
|
Party(relativePath string, middleware ...context.Handler) Party
|
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.
|
|
|
|
PartyFunc(relativePath string, partyBuilderFunc func(p Party)) Party
|
2021-02-17 15:50:36 +01:00
|
|
|
// PartyConfigure like `Party` and `PartyFunc` registers a new children Party but instead it accepts a struct value.
|
|
|
|
// It initializes a new children Party and executes the PartyConfigurator's Configure.
|
|
|
|
// Useful when the api's dependencies amount are too much to pass on a function.
|
|
|
|
//
|
2021-02-21 21:24:01 +01:00
|
|
|
// As an exception, if the end-developer registered one or more dependencies upfront through
|
|
|
|
// 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-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, ...)
|
|
|
|
// app.PartyConfigure("/users", &api.UsersAPI{})
|
2021-02-17 15:57:19 +01:00
|
|
|
PartyConfigure(relativePath string, partyReg ...PartyConfigurator) Party
|
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-02-08 13:04:39 +01:00
|
|
|
// So if app.Subdomain("admin").Subdomain("panel") then the result is: "panel.admin.".
|
2017-07-10 17:32:42 +02:00
|
|
|
Subdomain(subdomain string, middleware ...context.Handler) Party
|
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-12 06:20:07 +02:00
|
|
|
// 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.
|
|
|
|
UseRouter(handlers ...context.Handler)
|
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.
|
|
|
|
UseError(handlers ...context.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
|
|
|
// 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-15 11:24:51 +02:00
|
|
|
// To register a middleware for error handlers, look `UseError` method instead.
|
2017-07-10 17:32:42 +02:00
|
|
|
Use(middleware ...context.Handler)
|
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
|
|
|
UseOnce(handlers ...context.Handler)
|
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.
|
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 difference from .Use is that this/or these Handler(s) are being always running last.
|
|
|
|
Done(handlers ...context.Handler)
|
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.
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
RemoveHandler(namesOrHandlers ...interface{}) Party
|
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.
|
|
|
|
Reset() Party
|
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.
|
|
|
|
ResetRouterFilters() Party
|
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.
|
|
|
|
AllowMethods(methods ...string) Party
|
|
|
|
|
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
|
|
|
|
SetExecutionRules(executionRules ExecutionRules) Party
|
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
|
|
|
SetRegisterRule(rule RouteRegisterRule) Party
|
2020-02-29 13:18:15 +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
|
|
|
// Handle registers a route to the server's router.
|
|
|
|
// if empty method is passed then handler(s) are being registered to all methods, same as .Any.
|
|
|
|
//
|
|
|
|
// Returns the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Handle(method string, registeredPath string, handlers ...context.Handler) *Route
|
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(iris.MethodGet, "/user /user/{id:uint64} /user/me", userHandler)
|
2017-08-18 16:09:18 +02:00
|
|
|
// At the other side, with `Handle` we've had to write:
|
|
|
|
// app.Handle(iris.MethodGet, "/user", userHandler)
|
2018-10-21 18:20:05 +02:00
|
|
|
// app.Handle(iris.MethodGet, "/user/{id:uint64}", userHandler)
|
2017-08-24 14:40:06 +02:00
|
|
|
// app.Handle(iris.MethodGet, "/user/me", userHandler)
|
2017-08-18 16:09:18 +02:00
|
|
|
//
|
|
|
|
// This method is used behind the scenes at the `Controller` function
|
|
|
|
// in order to handle more than one paths for the same controller instance.
|
|
|
|
HandleMany(method string, relativePath string, handlers ...context.Handler) []*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
|
|
|
|
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
|
|
|
//
|
2020-07-05 04:39:48 +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
|
|
|
|
HandleDir(requestPath string, fileSystem interface{}, opts ...DirOptions) []*Route
|
2019-06-21 18:43:25 +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
|
|
|
// None registers an "offline" route
|
|
|
|
// see context.ExecRoute(routeName) and
|
|
|
|
// party.Routes().Online(handleResultregistry.*Route, "GET") and
|
|
|
|
// Offline(handleResultregistry.*Route)
|
|
|
|
//
|
|
|
|
// Returns the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
None(path string, handlers ...context.Handler) *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
|
|
|
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Get(path string, handlers ...context.Handler) *Route
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Post(path string, handlers ...context.Handler) *Route
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Put(path string, handlers ...context.Handler) *Route
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Delete(path string, handlers ...context.Handler) *Route
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Connect(path string, handlers ...context.Handler) *Route
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Head(path string, handlers ...context.Handler) *Route
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Options(path string, handlers ...context.Handler) *Route
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Patch(path string, handlers ...context.Handler) *Route
|
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 the read-only route information.
|
2017-07-10 17:32:42 +02:00
|
|
|
Trace(path string, handlers ...context.Handler) *Route
|
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-07-10 17:32:42 +02:00
|
|
|
Any(registeredPath string, handlers ...context.Handler) []*Route
|
2019-12-13 22:06:18 +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.
|
|
|
|
CreateRoutes(methods []string, relativePath string, handlers ...context.Handler) []*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
|
|
|
// 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-07-10 17:32:42 +02:00
|
|
|
StaticContent(requestPath 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
|
|
|
// 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-07-10 17:32:42 +02:00
|
|
|
Favicon(favPath string, requestPath ...string) *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
|
|
|
|
2020-09-29 18:19:19 +02:00
|
|
|
// RegisterView registers and loads a view engine middleware for this group of routes.
|
|
|
|
// It overrides any of the application's root registered view engine.
|
2020-08-05 18:34:55 +02:00
|
|
|
// To register a view engine per handler chain see the `Context.ViewEngine` instead.
|
|
|
|
// Read `Configuration.ViewEngineContextKey` documentation for more.
|
|
|
|
RegisterView(viewEngine context.ViewEngine)
|
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)]
|
|
|
|
// })
|
|
|
|
FallbackView(provider context.FallbackViewProvider)
|
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
|
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
|
|
|
Layout(tmplLayoutFile string) Party
|
|
|
|
}
|