mirror of
https://github.com/kataras/iris.git
synced 2025-01-24 11:11:03 +01:00
40 lines
1.4 KiB
Go
40 lines
1.4 KiB
Go
|
package main
|
||
|
|
||
|
import (
|
||
|
"time"
|
||
|
|
||
|
"github.com/kataras/iris/_examples/hero/sessions/routes"
|
||
|
|
||
|
"github.com/kataras/iris"
|
||
|
"github.com/kataras/iris/hero" // <- IMPORTANT
|
||
|
"github.com/kataras/iris/sessions"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
app := iris.New()
|
||
|
sessionManager := sessions.New(sessions.Config{
|
||
|
Cookie: "site_session_id",
|
||
|
Expires: 60 * time.Minute,
|
||
|
AllowReclaim: true,
|
||
|
})
|
||
|
|
||
|
// Register
|
||
|
// dynamic dependencies like the *sessions.Session, from `sessionManager.Start(ctx) *sessions.Session` <- it accepts a Context and it returns
|
||
|
// something -> this is called dynamic request-time dependency and that "something" can be used to your handlers as input parameters,
|
||
|
// no limit about the number of dependencies, each handler will be builded once, before the server ran and it will use only dependencies that it needs.
|
||
|
hero.Register(sessionManager.Start)
|
||
|
// convert any function to an iris Handler, their input parameters are being resolved using the unique Iris' blazing-fast dependency injection
|
||
|
// for services or dynamic dependencies like the *sessions.Session, from sessionManager.Start(ctx) *sessions.Session) <- it accepts a context and it returns
|
||
|
// something-> this is called dynamic request-time dependency.
|
||
|
indexHandler := hero.Handler(routes.Index)
|
||
|
|
||
|
// Method: GET
|
||
|
// Path: http://localhost:8080
|
||
|
app.Get("/", indexHandler)
|
||
|
|
||
|
app.Run(
|
||
|
iris.Addr(":8080"),
|
||
|
iris.WithoutServerError(iris.ErrServerClosed),
|
||
|
)
|
||
|
}
|