2017-07-16 12:58:10 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12"
|
|
|
|
"github.com/kataras/iris/v12/middleware/logger"
|
2017-07-16 12:58:10 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
const deleteFileOnExit = true
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
app := iris.New()
|
|
|
|
r, close := newRequestLogger()
|
|
|
|
defer close()
|
|
|
|
|
|
|
|
app.Use(r)
|
2017-08-27 19:35:23 +02:00
|
|
|
app.OnAnyErrorCode(r, func(ctx iris.Context) {
|
2017-07-16 12:58:10 +02:00
|
|
|
ctx.HTML("<h1> Error: Please try <a href ='/'> this </a> instead.</h1>")
|
|
|
|
})
|
|
|
|
|
2017-08-27 19:35:23 +02:00
|
|
|
h := func(ctx iris.Context) {
|
2017-07-16 12:58:10 +02:00
|
|
|
ctx.Writef("Hello from %s", ctx.Path())
|
|
|
|
}
|
|
|
|
|
|
|
|
app.Get("/", h)
|
|
|
|
|
|
|
|
app.Get("/1", h)
|
|
|
|
|
|
|
|
app.Get("/2", h)
|
|
|
|
|
|
|
|
// http://localhost:8080
|
|
|
|
// http://localhost:8080/1
|
|
|
|
// http://localhost:8080/2
|
|
|
|
// http://lcoalhost:8080/notfoundhere
|
2020-04-28 04:22:58 +02:00
|
|
|
app.Listen(":8080")
|
2017-07-16 12:58:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// get a filename based on the date, file logs works that way the most times
|
|
|
|
// but these are just a sugar.
|
|
|
|
func todayFilename() string {
|
|
|
|
today := time.Now().Format("Jan 02 2006")
|
|
|
|
return today + ".txt"
|
|
|
|
}
|
|
|
|
|
|
|
|
func newLogFile() *os.File {
|
|
|
|
filename := todayFilename()
|
|
|
|
// open an output file, this will append to the today's file if server restarted.
|
|
|
|
f, err := os.OpenFile(filename, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return f
|
|
|
|
}
|
|
|
|
|
|
|
|
var excludeExtensions = [...]string{
|
|
|
|
".js",
|
|
|
|
".css",
|
|
|
|
".jpg",
|
|
|
|
".png",
|
|
|
|
".ico",
|
|
|
|
".svg",
|
|
|
|
}
|
|
|
|
|
2017-08-27 19:35:23 +02:00
|
|
|
func newRequestLogger() (h iris.Handler, close func() error) {
|
2017-07-16 12:58:10 +02:00
|
|
|
close = func() error { return nil }
|
|
|
|
|
|
|
|
c := logger.Config{
|
|
|
|
Status: true,
|
|
|
|
IP: true,
|
|
|
|
Method: true,
|
|
|
|
Path: true,
|
|
|
|
Columns: true,
|
|
|
|
}
|
|
|
|
|
|
|
|
logFile := newLogFile()
|
|
|
|
close = func() error {
|
|
|
|
err := logFile.Close()
|
|
|
|
if deleteFileOnExit {
|
|
|
|
err = os.Remove(logFile.Name())
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-06-21 18:43:25 +02:00
|
|
|
c.LogFunc = func(endTime time.Time, latency time.Duration, status, ip, method, path string, message interface{}, headerMessage interface{}) {
|
|
|
|
output := logger.Columnize(endTime.Format("2006/01/02 - 15:04:05"), latency, status, ip, method, path, message, headerMessage)
|
2017-07-16 12:58:10 +02:00
|
|
|
logFile.Write([]byte(output))
|
2019-06-21 18:43:25 +02:00
|
|
|
} // or make use of the `LogFuncCtx`, see the '../request-logger-file-json' example for more.
|
2017-07-16 12:58:10 +02:00
|
|
|
|
|
|
|
// we don't want to use the logger
|
|
|
|
// to log requests to assets and etc
|
2017-08-27 19:35:23 +02:00
|
|
|
c.AddSkipper(func(ctx iris.Context) bool {
|
2017-07-16 12:58:10 +02:00
|
|
|
path := ctx.Path()
|
|
|
|
for _, ext := range excludeExtensions {
|
|
|
|
if strings.HasSuffix(path, ext) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
})
|
|
|
|
|
|
|
|
h = logger.New(c)
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|