Explorar o código

feat: withUnauthorizedCallback

double.huang %!s(int64=4) %!d(string=hai) anos
pai
achega
e8ccdf5a50
Modificáronse 2 ficheiros con 15 adicións e 2 borrados
  1. 7 2
      i2bill.go
  2. 8 0
      internal/utils/resp.go

+ 7 - 2
i2bill.go

@@ -3,16 +3,22 @@ package main
 import (
 	"flag"
 	"fmt"
+	"net/http"
 
 	"git.i2edu.net/i2/i2-bill-api/internal/config"
 	"git.i2edu.net/i2/i2-bill-api/internal/handler"
 	"git.i2edu.net/i2/i2-bill-api/internal/svc"
+	"git.i2edu.net/i2/i2-bill-api/internal/utils"
 
 	"git.i2edu.net/i2/go-zero/core/conf"
 	"git.i2edu.net/i2/go-zero/rest"
+	"git.i2edu.net/i2/go-zero/rest/httpx"
 )
 
 var configFile = flag.String("f", "etc/i2bill-api.yaml", "the config file")
+var withUnauthorizedCallback = rest.WithUnauthorizedCallback(func(w http.ResponseWriter, r *http.Request, err error) {
+	httpx.OkJson(w, utils.ReturnHTTPUnauthorized(err))
+})
 
 func main() {
 	flag.Parse()
@@ -21,11 +27,10 @@ func main() {
 	conf.MustLoad(*configFile, &c)
 
 	ctx := svc.NewServiceContext(c)
-	server := rest.MustNewServer(c.RestConf)
+	server := rest.MustNewServer(c.RestConf, withUnauthorizedCallback)
 	defer server.Stop()
 
 	handler.RegisterHandlers(server, ctx)
-	// Register asserts routes
 	server.AddRoutes(handler.Static("/asserts/", handler.LocalFile("asserts", false)))
 	fmt.Printf("Starting server at %s:%d...\n", c.Host, c.Port)
 	server.Start()

+ 8 - 0
internal/utils/resp.go

@@ -22,3 +22,11 @@ func ReturnHTTPFail(err error) HTTPData {
 	}
 	return rtndata
 }
+
+func ReturnHTTPUnauthorized(err error) HTTPData {
+	rtndata := HTTPData{
+		ErrNo:  401,
+		ErrMsg: err.Error(),
+	}
+	return rtndata
+}