2020-09-06 09:38:48 +02:00
|
|
|
package main // See https://github.com/kataras/iris/issues/1601
|
|
|
|
|
|
|
|
import (
|
2020-09-07 05:12:45 +02:00
|
|
|
"time"
|
|
|
|
|
2020-09-06 09:38:48 +02:00
|
|
|
"github.com/kataras/iris/v12"
|
|
|
|
"github.com/kataras/iris/v12/middleware/accesslog"
|
2020-09-07 05:12:45 +02:00
|
|
|
|
|
|
|
rotatelogs "github.com/lestrrat-go/file-rotatelogs"
|
2020-09-06 09:38:48 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2020-09-07 05:12:45 +02:00
|
|
|
pathToAccessLog := "./access_log.%Y%m%d%H%M"
|
|
|
|
w, err := rotatelogs.New(
|
|
|
|
pathToAccessLog,
|
|
|
|
rotatelogs.WithMaxAge(24*time.Hour),
|
|
|
|
rotatelogs.WithRotationTime(time.Hour))
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2020-09-07 17:04:35 +02:00
|
|
|
ac := accesslog.New(w)
|
|
|
|
ac.TimeFormat = "2006-01-02 15:04:05"
|
2020-09-07 15:31:43 +02:00
|
|
|
|
2020-09-07 05:12:45 +02:00
|
|
|
/*
|
|
|
|
Use a file directly:
|
|
|
|
ac := accesslog.File("./access.log")
|
|
|
|
|
2020-09-08 12:44:50 +02:00
|
|
|
Log after the response was sent (defaults to false):
|
2020-09-07 05:12:45 +02:00
|
|
|
ac.Async = true
|
|
|
|
|
2020-09-07 17:04:35 +02:00
|
|
|
Force-protect writer with locks.
|
|
|
|
On this example this is not required:
|
|
|
|
ac.LockWriter = true"
|
2020-09-07 05:12:45 +02:00
|
|
|
|
2020-09-08 12:44:50 +02:00
|
|
|
// To disable request and response calculations
|
|
|
|
// (enabled by default but slows down the whole operation if Async is false):
|
|
|
|
ac.RequestBody = false
|
|
|
|
ac.ResponseBody = false
|
|
|
|
ac.BytesReceived = false
|
|
|
|
ac.BytesSent = false
|
|
|
|
|
2020-09-07 05:12:45 +02:00
|
|
|
Add second output:
|
2020-09-07 15:31:43 +02:00
|
|
|
ac.AddOutput(app.Logger().Printer)
|
2020-09-07 05:12:45 +02:00
|
|
|
|
|
|
|
Change format (after output was set):
|
|
|
|
ac.SetFormatter(&accesslog.JSON{Indent: " "})
|
2020-09-07 10:35:27 +02:00
|
|
|
|
2020-09-08 12:44:50 +02:00
|
|
|
Modify the output format and customize the order
|
|
|
|
with the Template formatter:
|
2020-09-07 10:35:27 +02:00
|
|
|
ac.SetFormatter(&accesslog.Template{
|
2020-09-08 12:44:50 +02:00
|
|
|
Text: "{{.Now.Format .TimeFormat}}|{{.Latency}}|{{.Method}}|{{.Path}}|{{.RequestValuesLine}}|{{.Code}}|{{.BytesReceivedLine}}|{{.BytesSentLine}}|{{.Request}}|{{.Response}}|\n",
|
|
|
|
// Default ^
|
2020-09-07 10:35:27 +02:00
|
|
|
})
|
2020-09-07 10:53:16 +02:00
|
|
|
|
|
|
|
Set custom request fields:
|
|
|
|
ac.AddField(func(ctx iris.Context) (string, interface{}) {
|
|
|
|
v := ctx.RemoteAddr()
|
|
|
|
if v == "" {
|
|
|
|
return "", nil
|
|
|
|
}
|
|
|
|
// the log entry name and its value.
|
|
|
|
return "IP", v
|
|
|
|
})
|
2020-09-07 05:12:45 +02:00
|
|
|
*/
|
|
|
|
|
2020-09-06 09:38:48 +02:00
|
|
|
defer ac.Close()
|
|
|
|
iris.RegisterOnInterrupt(func() {
|
|
|
|
ac.Close()
|
|
|
|
})
|
|
|
|
|
2020-09-07 05:12:45 +02:00
|
|
|
app := iris.New()
|
2020-09-06 09:38:48 +02:00
|
|
|
// Register the middleware (UseRouter to catch http errors too).
|
|
|
|
app.UseRouter(ac.Handler)
|
|
|
|
//
|
|
|
|
|
|
|
|
// Register some routes...
|
|
|
|
app.HandleDir("/", iris.Dir("./public"))
|
|
|
|
|
|
|
|
app.Get("/user/{username}", userHandler)
|
|
|
|
app.Post("/read_body", readBodyHandler)
|
|
|
|
app.Get("/html_response", htmlResponse)
|
|
|
|
//
|
|
|
|
|
|
|
|
app.Listen(":8080")
|
|
|
|
}
|
|
|
|
|
|
|
|
func readBodyHandler(ctx iris.Context) {
|
|
|
|
var request interface{}
|
|
|
|
if err := ctx.ReadBody(&request); err != nil {
|
|
|
|
ctx.StopWithPlainError(iris.StatusBadRequest, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx.JSON(iris.Map{"message": "OK", "data": request})
|
|
|
|
}
|
|
|
|
|
|
|
|
func userHandler(ctx iris.Context) {
|
|
|
|
ctx.Writef("Hello, %s!", ctx.Params().Get("username"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func htmlResponse(ctx iris.Context) {
|
|
|
|
ctx.HTML("<h1>HTML Response</h1>")
|
|
|
|
}
|