mirror of
https://github.com/kataras/iris.git
synced 2025-01-23 02:31:04 +01:00
add on-site documentation for the new 'apps' subpackage
This commit is contained in:
parent
cb80e43ff0
commit
02c85c27cc
217
apps/README.md
Normal file
217
apps/README.md
Normal file
|
@ -0,0 +1,217 @@
|
||||||
|
# The `apps` package
|
||||||
|
|
||||||
|
Package `github.com/kataras/iris/v12/apps` provides a globally scoped control over all registered Iris Applications of the same Program.
|
||||||
|
|
||||||
|
[Example Application](https://github.com/kataras/iris/tree/master/_examples/routing/subdomains/redirect/multi-instances)
|
||||||
|
|
||||||
|
Below you will find a use case for each feature.
|
||||||
|
|
||||||
|
## The `Get` function
|
||||||
|
|
||||||
|
The `Get` function returns an Iris Application based on its "appName".
|
||||||
|
It returns nil when no application was found with the given exact name.
|
||||||
|
|
||||||
|
If "appName" parameter is missing then it returns the last registered one.
|
||||||
|
When no application is registered yet then it creates a new on-fly
|
||||||
|
with a "Default" name and returns that instead.
|
||||||
|
The "Default" one can be used across multiple Go packages
|
||||||
|
of the same Program too.
|
||||||
|
|
||||||
|
Applications of the same program are registered automatically.
|
||||||
|
|
||||||
|
To check if at least one application is registered or not,
|
||||||
|
use the `GetAll() []*iris.Application` function instead.
|
||||||
|
|
||||||
|
```go
|
||||||
|
func Get(appName ...string) *iris.Application
|
||||||
|
```
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
- Access an Iris Application globally from all of your Go packages of the same Program without a global parameter and import cycle.
|
||||||
|
|
||||||
|
```go
|
||||||
|
/* myserver/api/user.go */
|
||||||
|
|
||||||
|
package userapi
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/kataras/iris/v12"
|
||||||
|
"github.com/kataras/iris/v12/apps"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
app := apps.Get()
|
||||||
|
app.Get("/", list)
|
||||||
|
}
|
||||||
|
|
||||||
|
func list(ctx iris.Context) {
|
||||||
|
// [...]
|
||||||
|
ctx.WriteString("list users")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
```go
|
||||||
|
/* myserver/main.go */
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
_ "myserver/api/user"
|
||||||
|
|
||||||
|
"github.com/kataras/iris/v12/apps"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
app := apps.Get()
|
||||||
|
app.Listen(":80")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
The empty `_` import statement will call the `userapi.init` function (before `main`) which
|
||||||
|
initializes an Iris Application, if not already exists, and registers it to the internal global store for further use across packages.
|
||||||
|
|
||||||
|
- Reference one or more Iris Applications based on their names.
|
||||||
|
|
||||||
|
The `Application.SetName` method sets a unique name to this Iris Application.
|
||||||
|
It sets a child prefix for the current Application's Logger.
|
||||||
|
Its `Application.String` method returns the given name. It returns itself.
|
||||||
|
|
||||||
|
```go
|
||||||
|
func (app *Application) SetName(appName string) *Application
|
||||||
|
```
|
||||||
|
|
||||||
|
```go
|
||||||
|
/* myserver/main.go */
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import "github.com/kataras/iris/v12"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
app := iris.New().SetName("app.company.com")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
```go
|
||||||
|
/* myserver/pkg/something.go */
|
||||||
|
|
||||||
|
package pkg
|
||||||
|
|
||||||
|
import "github.com/kataras/iris/v12/apps"
|
||||||
|
|
||||||
|
func DoSomething() {
|
||||||
|
app := apps.Get("app.company.com")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
The `main` function creates and registers an Iris Application on `"app.company.com"` name, after that declaration every package of the same Program can retrieve that specific Application instance through its name.
|
||||||
|
|
||||||
|
## The `Switch` function
|
||||||
|
|
||||||
|
The `Switch` function returns a new Application with the sole purpose of routing the matched Applications through the "provided cases". Read below about the available SwitchProviders and how you can create and use your own one.
|
||||||
|
|
||||||
|
The cases are filtered in order of their registration.
|
||||||
|
|
||||||
|
```go
|
||||||
|
func Switch(provider SwitchProvider, options ...SwitchOption) *iris.Application
|
||||||
|
```
|
||||||
|
|
||||||
|
Example Code:
|
||||||
|
|
||||||
|
```go
|
||||||
|
switcher := Switch(Hosts{
|
||||||
|
"mydomain.com": app,
|
||||||
|
"test.mydomain.com": testSubdomainApp,
|
||||||
|
"otherdomain.com": "appName",
|
||||||
|
})
|
||||||
|
switcher.Listen(":80")
|
||||||
|
```
|
||||||
|
|
||||||
|
Note that this is NOT an alternative for a load balancer.
|
||||||
|
The filters are executed by registration order and a matched Application
|
||||||
|
handles the request, that's all it does.
|
||||||
|
|
||||||
|
The returned Switch Iris Application can register routes that will run
|
||||||
|
when neither of the registered Applications is responsible to handle the incoming request against the provided filters.
|
||||||
|
|
||||||
|
The returned Switch Iris Application can also register custom error code handlers,
|
||||||
|
e.g. to inject the 404 on not responsible Application was found.
|
||||||
|
It can also be wrapped with its `WrapRouter` method,
|
||||||
|
which is really useful for logging and statistics.
|
||||||
|
|
||||||
|
### The `SwitchProvider` interface
|
||||||
|
|
||||||
|
This is the first required input argument for the `Switch` function.
|
||||||
|
|
||||||
|
A `SwitchProvider` should return one or more `SwitchCase` values.
|
||||||
|
|
||||||
|
```go
|
||||||
|
type SwitchProvider interface {
|
||||||
|
GetSwitchCases() []SwitchCase
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
The `SwitchCase` structure contains the Filter and the target Iris Application.
|
||||||
|
|
||||||
|
```go
|
||||||
|
type SwitchCase struct {
|
||||||
|
Filter func(ctx iris.Context) bool
|
||||||
|
App *iris.Application
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### The `SwitchOptions` structure
|
||||||
|
|
||||||
|
This is the last variadic (optional) input argument for the `Switch` function.
|
||||||
|
|
||||||
|
```go
|
||||||
|
type SwitchOptions struct {
|
||||||
|
// RequestModifiers holds functions to run
|
||||||
|
// if and only if at least one Filter passed.
|
||||||
|
// They are used to modify the request object
|
||||||
|
// of the matched Application, e.g. modify the host.
|
||||||
|
//
|
||||||
|
// See `SetHost` option too.
|
||||||
|
RequestModifiers []func(*http.Request)
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
The `SetHost` function is a SwitchOption.
|
||||||
|
It force sets a Host field for the matched Application's request object.
|
||||||
|
Extremely useful when used with Hosts SwitchProvider.
|
||||||
|
Usecase: www. to root domain without redirection (SEO reasons)
|
||||||
|
and keep the same internal request Host for both of them so
|
||||||
|
the root app's handlers will always work with a single host no matter
|
||||||
|
what the real request Host was.
|
||||||
|
|
||||||
|
```go
|
||||||
|
func SetHost(hostField string) SwitchOptionFunc
|
||||||
|
```
|
||||||
|
|
||||||
|
Example Code:
|
||||||
|
|
||||||
|
```go
|
||||||
|
cases := Hosts{
|
||||||
|
{"^(www.)?mydomain.com$", rootApp},
|
||||||
|
}
|
||||||
|
switcher := Switch(cases, SetHost("mydomain.com"))
|
||||||
|
```
|
||||||
|
|
||||||
|
### Join different type of SwitchProviders
|
||||||
|
|
||||||
|
Wrap with the `Join` slice to pass more than one provider at the same time.
|
||||||
|
|
||||||
|
Example Code:
|
||||||
|
|
||||||
|
```go
|
||||||
|
Switch(Join{
|
||||||
|
SwitchCase{
|
||||||
|
Filter: customFilter,
|
||||||
|
App: myapp,
|
||||||
|
},
|
||||||
|
Hosts{
|
||||||
|
{"^test.*$", myapp},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
```
|
50
apps/apps.go
50
apps/apps.go
|
@ -8,11 +8,29 @@ import (
|
||||||
"github.com/kataras/iris/v12/context"
|
"github.com/kataras/iris/v12/context"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Get returns an existing Iris Application based on its "appName".
|
// Get returns an Iris Application based on its "appName".
|
||||||
// Applications of the same program
|
// It returns nil when no application was found with the given exact name.
|
||||||
// are registered automatically.
|
//
|
||||||
func Get(appName string) *iris.Application {
|
// If "appName" parameter is missing then it returns the last registered one.
|
||||||
if app, ok := context.GetApplication(appName); ok {
|
// When no application is registered yet then it creates a new on-fly
|
||||||
|
// with a "Default" name and returns that instead.
|
||||||
|
// The "Default" one can be used across multiple Go packages
|
||||||
|
// of the same Program too.
|
||||||
|
//
|
||||||
|
// Applications of the same program are registered automatically.
|
||||||
|
//
|
||||||
|
// To check if at least one application is registered or not
|
||||||
|
// use the `GetAll` function instead.
|
||||||
|
func Get(appName ...string) *iris.Application {
|
||||||
|
if len(appName) == 0 || appName[0] == "" {
|
||||||
|
if app := context.LastApplication(); app != nil {
|
||||||
|
return app.(*iris.Application)
|
||||||
|
}
|
||||||
|
|
||||||
|
return iris.New().SetName("Default")
|
||||||
|
}
|
||||||
|
|
||||||
|
if app, ok := context.GetApplication(appName[0]); ok {
|
||||||
return app.(*iris.Application)
|
return app.(*iris.Application)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,25 +48,3 @@ func GetAll() []*iris.Application {
|
||||||
|
|
||||||
return apps
|
return apps
|
||||||
}
|
}
|
||||||
|
|
||||||
// Configure applies one or more configurator to the
|
|
||||||
// applications with the given "appNames".
|
|
||||||
//
|
|
||||||
// See `ConfigureAll` too.
|
|
||||||
func Configure(appNames []string, configurators ...iris.Configurator) {
|
|
||||||
for _, appName := range appNames {
|
|
||||||
if app := Get(appName); app != nil {
|
|
||||||
app.Configure(configurators...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// ConfigureAll applies one or more configurator to all
|
|
||||||
// registered applications so far.
|
|
||||||
//
|
|
||||||
// See `Configure` too.
|
|
||||||
func ConfigureAll(configurators ...iris.Configurator) {
|
|
||||||
for _, app := range context.GetApplications() {
|
|
||||||
app.(*iris.Application).Configure(configurators...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -8,26 +8,27 @@ import (
|
||||||
|
|
||||||
// Switch returns a new Application
|
// Switch returns a new Application
|
||||||
// with the sole purpose of routing the
|
// with the sole purpose of routing the
|
||||||
// matched Applications through the provided "cases".
|
// matched Applications through the "provided cases".
|
||||||
//
|
//
|
||||||
// The cases are filtered in order of register.
|
// The cases are filtered in order of their registration.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example Code:
|
||||||
// switcher := Switch(Hosts{
|
// switcher := Switch(Hosts{
|
||||||
// "mydomain.com": app,
|
// "mydomain.com": app,
|
||||||
// "test.mydomain.com": testSubdomainApp,
|
// "test.mydomain.com": testSubdomainApp,
|
||||||
// "otherdomain.com": "appName",
|
// "otherdomain.com": "appName",
|
||||||
// })
|
// })
|
||||||
// switcher.Listen(":80")
|
// switcher.Listen(":80")
|
||||||
//
|
//
|
||||||
// Note that this is NOT a load balancer. The filters
|
// Note that this is NOT an alternative for a load balancer.
|
||||||
// are executed by registration order and matched Application
|
// The filters are executed by registration order and a matched Application
|
||||||
// handles the request.
|
// handles the request, that's all it does.
|
||||||
//
|
//
|
||||||
// The returned Switch Application can register routes that will run
|
// The returned Switch Iris Application can register routes that will run
|
||||||
// if no application is matched against the given filters.
|
// when neither of the registered Applications is responsible
|
||||||
// The returned Switch Application can also register custom error code handlers,
|
// to handle the incoming request against the provided filters.
|
||||||
// e.g. to inject the 404 on not application found.
|
// The returned Switch Iris Application can also register custom error code handlers,
|
||||||
|
// e.g. to inject the 404 on not responsible Application was found.
|
||||||
// It can also be wrapped with its `WrapRouter` method,
|
// It can also be wrapped with its `WrapRouter` method,
|
||||||
// which is really useful for logging and statistics.
|
// which is really useful for logging and statistics.
|
||||||
//
|
//
|
||||||
|
|
Loading…
Reference in New Issue
Block a user