package beego

import (
	"fmt"
	"github.com/beego/beego/v2/core/logs"
	"github.com/beego/beego/v2/server/web"
	"github.com/beego/beego/v2/server/web/context"
	"github.com/linmadan/egglib-go/web/beego/filters"
	"gitlab.fjmaimaimai.com/allied-creation/character-library-metadata-bastion/pkg/domain"
	"net/http"
	"os"
	"strconv"
	"strings"

	. "gitlab.fjmaimaimai.com/allied-creation/character-library-metadata-bastion/pkg/log"
	_ "gitlab.fjmaimaimai.com/allied-creation/character-library-metadata-bastion/pkg/port/beego/routers"
)

func init() {
	web.BConfig.AppName = "character-library-metadata-bastion"
	web.BConfig.CopyRequestBody = true
	web.BConfig.RunMode = "dev" //"prod"
	web.BConfig.Listen.HTTPPort = 8080
	web.BConfig.Listen.EnableAdmin = false
	web.BConfig.WebConfig.CommentRouterPath = "/pkg/port/beego/routers"
	if os.Getenv("RUN_MODE") != "" {
		web.BConfig.RunMode = os.Getenv("RUN_MODE")
	}
	if os.Getenv("HTTP_PORT") != "" {
		portStr := os.Getenv("HTTP_PORT")
		if port, err := strconv.Atoi(portStr); err == nil {
			web.BConfig.Listen.HTTPPort = port
		}
	}

	//https支持
	web.BConfig.Listen.EnableHTTPS = true
	web.BConfig.Listen.HTTPSPort = 443

	web.BConfig.Listen.HTTPSCertFile = "./config/fjmaimaimai.com_bundle.crt"
	web.BConfig.Listen.HTTPSKeyFile = "./config/fjmaimaimai.com.key"

	//进程内监控
	//web.BConfig.Listen.EnableAdmin = true
	//web.BConfig.Listen.AdminPort = 8088
	if os.Getenv("HTTPS_PORT") != "" {
		portStr := os.Getenv("HTTPS_PORT")
		if port, err := strconv.Atoi(portStr); err == nil {
			web.BConfig.Listen.HTTPSPort = port
		}
	}

	web.InsertFilter("/*", web.BeforeRouter, filters.AllowCors())
	web.InsertFilter("/*", web.BeforeRouter, JwtFilter())
	web.InsertFilter("/*", web.BeforeExec, CreateRequestLogFilter(true)) //  filters.CreateRequstLogFilter(Logger)
	web.InsertFilter("/*", web.AfterExec, filters.CreateResponseLogFilter(Logger), web.WithReturnOnOutput(false))
}

func CreateRequestLogFilter(console bool) func(ctx *context.Context) {
	return func(ctx *context.Context) {
		msg := fmt.Sprintf("beego | %v | %v \n %v", ctx.Input.Method(), ctx.Input.URL(), string(ctx.Input.RequestBody))
		logs.Debug(msg)
		if console {
			fmt.Println(msg)
		}
	}
}

func JwtFilter() func(ctx *context.Context) {
	return func(ctx *context.Context) {
		token := ctx.Request.Header.Get("Authorization")
		if len(token) > 0 {
			token = strings.TrimPrefix(token, "Bearer ")
			userToken := &domain.UserToken{}
			err := userToken.ParseToken(token)
			if err != nil {
				ctx.Output.SetStatus(http.StatusOK)
				ctx.Output.JSON(map[string]interface{}{
					"msg":  "token 过期或无效,需刷新令牌",
					"code": 901,
					"data": struct{}{},
				}, false, false)
				return
			}
			ctx.Input.SetData("UserToken", userToken)
		}
	}
}