2017-12-15 19:28:06 +01:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12"
|
2020-09-17 17:01:35 +02:00
|
|
|
"github.com/kataras/iris/v12/middleware/accesslog"
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12/middleware/recover"
|
|
|
|
"github.com/kataras/iris/v12/sessions"
|
2017-12-15 19:28:06 +01:00
|
|
|
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12/mvc"
|
2017-12-15 19:28:06 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
app := iris.New()
|
2017-12-19 22:40:42 +01:00
|
|
|
app.Logger().SetLevel("debug")
|
2020-09-17 17:01:35 +02:00
|
|
|
|
|
|
|
basic := app.Party("/basic")
|
|
|
|
{
|
|
|
|
// Register middlewares to run under the /basic path prefix.
|
|
|
|
ac := accesslog.File("./basic_access.log")
|
|
|
|
defer ac.Close()
|
|
|
|
|
|
|
|
basic.UseRouter(ac.Handler)
|
|
|
|
basic.UseRouter(recover.New())
|
|
|
|
|
|
|
|
mvc.Configure(basic, basicMVC)
|
|
|
|
}
|
2017-12-15 19:28:06 +01:00
|
|
|
|
2020-03-05 21:41:27 +01:00
|
|
|
app.Listen(":8080")
|
2017-12-15 19:28:06 +01:00
|
|
|
}
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
func basicMVC(app *mvc.Application) {
|
2020-09-14 23:23:09 +02:00
|
|
|
// Disable verbose logging of controllers for this and its children mvc apps
|
2020-09-17 17:01:35 +02:00
|
|
|
// when the log level is "debug":
|
|
|
|
app.SetControllersNoLog(true)
|
2020-09-14 23:23:09 +02:00
|
|
|
|
2020-09-17 17:01:35 +02:00
|
|
|
// You can still register middlewares at MVC apps of course.
|
|
|
|
// The app.Router returns the Party that this MVC
|
|
|
|
// was registered on.
|
|
|
|
// app.Router.UseRouter/Use/....
|
2017-12-15 19:28:06 +01:00
|
|
|
|
2017-12-27 03:15:41 +01:00
|
|
|
// Register dependencies which will be binding to the controller(s),
|
2017-12-15 19:28:06 +01:00
|
|
|
// can be either a function which accepts an iris.Context and returns a single value (dynamic binding)
|
|
|
|
// or a static struct value (service).
|
2017-12-27 03:15:41 +01:00
|
|
|
app.Register(
|
2017-12-25 20:00:14 +01:00
|
|
|
sessions.New(sessions.Config{}).Start,
|
2017-12-15 19:28:06 +01:00
|
|
|
&prefixedLogger{prefix: "DEV"},
|
2020-09-17 17:01:35 +02:00
|
|
|
accesslog.GetFields, // Set custom fields through a controller or controller's methods.
|
2017-12-15 19:28:06 +01:00
|
|
|
)
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
// GET: http://localhost:8080/basic
|
|
|
|
// GET: http://localhost:8080/basic/custom
|
2019-07-11 14:07:39 +02:00
|
|
|
// GET: http://localhost:8080/basic/custom2
|
2017-12-31 01:32:28 +01:00
|
|
|
app.Handle(new(basicController))
|
2017-12-15 19:28:06 +01:00
|
|
|
|
|
|
|
// All dependencies of the parent *mvc.Application
|
2017-12-30 19:40:52 +01:00
|
|
|
// are cloned to this new child,
|
|
|
|
// thefore it has access to the same session as well.
|
2017-12-31 01:32:28 +01:00
|
|
|
// GET: http://localhost:8080/basic/sub
|
2017-12-27 03:15:41 +01:00
|
|
|
app.Party("/sub").
|
2017-12-31 01:32:28 +01:00
|
|
|
Handle(new(basicSubController))
|
2017-12-15 19:28:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// If controller's fields (or even its functions) expecting an interface
|
2017-12-30 19:40:52 +01:00
|
|
|
// but a struct value is binded then it will check
|
|
|
|
// if that struct value implements
|
|
|
|
// the interface and if true then it will add this to the
|
|
|
|
// available bindings, as expected, before the server ran of course,
|
|
|
|
// remember? Iris always uses the best possible way to reduce load
|
|
|
|
// on serving web resources.
|
2017-12-15 19:28:06 +01:00
|
|
|
|
|
|
|
type LoggerService interface {
|
|
|
|
Log(string)
|
|
|
|
}
|
|
|
|
|
|
|
|
type prefixedLogger struct {
|
|
|
|
prefix string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *prefixedLogger) Log(msg string) {
|
|
|
|
fmt.Printf("%s: %s\n", s.prefix, msg)
|
|
|
|
}
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
type basicController struct {
|
2020-09-17 17:01:35 +02:00
|
|
|
Logger LoggerService // the static logger service attached to this app.
|
|
|
|
Session *sessions.Session // current HTTP session.
|
|
|
|
LogFields *accesslog.Fields // accesslog middleware custom fields.
|
2017-12-15 19:28:06 +01:00
|
|
|
}
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
func (c *basicController) BeforeActivation(b mvc.BeforeActivation) {
|
2019-07-11 14:07:39 +02:00
|
|
|
b.HandleMany("GET", "/custom /custom2", "Custom")
|
2017-12-17 23:16:10 +01:00
|
|
|
}
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
func (c *basicController) AfterActivation(a mvc.AfterActivation) {
|
2017-12-19 22:40:42 +01:00
|
|
|
if a.Singleton() {
|
2017-12-31 01:32:28 +01:00
|
|
|
panic("basicController should be stateless, a request-scoped, we have a 'Session' which depends on the context.")
|
2017-12-17 23:16:10 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
func (c *basicController) Get() string {
|
2017-12-15 19:28:06 +01:00
|
|
|
count := c.Session.Increment("count", 1)
|
2020-09-17 17:01:35 +02:00
|
|
|
c.LogFields.Set("count", count)
|
2017-12-15 19:28:06 +01:00
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
body := fmt.Sprintf("Hello from basicController\nTotal visits from you: %d", count)
|
2017-12-15 19:28:06 +01:00
|
|
|
c.Logger.Log(body)
|
|
|
|
return body
|
|
|
|
}
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
func (c *basicController) Custom() string {
|
2017-12-17 23:16:10 +01:00
|
|
|
return "custom"
|
|
|
|
}
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
type basicSubController struct {
|
2017-12-15 19:28:06 +01:00
|
|
|
Session *sessions.Session
|
|
|
|
}
|
|
|
|
|
2017-12-31 01:32:28 +01:00
|
|
|
func (c *basicSubController) Get() string {
|
2018-03-24 09:39:44 +01:00
|
|
|
count := c.Session.GetIntDefault("count", 1)
|
2017-12-31 01:32:28 +01:00
|
|
|
return fmt.Sprintf("Hello from basicSubController.\nRead-only visits count: %d", count)
|
2017-12-15 19:28:06 +01:00
|
|
|
}
|