3 Commits

Author SHA1 Message Date
7f49105b23 feat: 添加 MustStop 方法
feat: 添加 gin 统一执行 api 函数
2025-07-10 16:29:43 +08:00
6cd0fa3d6c chore: 修改 401 错误信息 2025-07-08 16:47:37 +08:00
9c8460fc44 feat: 添加 MustWithData 2025-07-04 13:57:26 +08:00
5 changed files with 110 additions and 1 deletions

60
api/api.go Normal file
View File

@ -0,0 +1,60 @@
package api
import (
"context"
"crypto/tls"
"errors"
"gitea.loveuer.com/yizhisec/packages/logger"
"github.com/gin-gonic/gin"
"net"
"net/http"
)
type Api struct {
Address string
Name string
App *gin.Engine
TlsConfig *tls.Config
}
func New(ctx context.Context, api *Api) (func(context.Context) error, error) {
var (
err error
fn func(context.Context) error
ln net.Listener
)
if api == nil {
return fn, errors.New("api is nil")
}
if api.TlsConfig != nil {
ln, err = tls.Listen("tcp", api.Address, api.TlsConfig)
} else {
ln, err = net.Listen("tcp", api.Address)
}
if err != nil {
return fn, err
}
svc := &http.Server{
Handler: api.App,
}
go func() {
logger.InfoCtx(ctx, "[%s] api svc running at: %s", api.Name, api.Address)
if err = svc.Serve(ln); err != nil {
if !errors.Is(err, http.ErrServerClosed) {
logger.ErrorCtx(ctx, "api svc run failed, err = %s", err.Error())
}
}
}()
fn = func(timeout context.Context) error {
logger.WarnCtx(ctx, "[%s] api svc shutdown...", api.Name)
return svc.Shutdown(timeout)
}
return fn, nil
}

4
opt/opt.go Normal file
View File

@ -0,0 +1,4 @@
package opt
type Config struct {
}

View File

@ -3,7 +3,7 @@ package resp
const (
Msg200 = "操作成功"
Msg400 = "参数错误"
Msg401 = "登录信息不存在或已过期, 请重新登录"
Msg401 = "该账号登录已失效, 请重新登录"
Msg401NoMulti = "用户已在其他地方登录"
Msg403 = "权限不足"
Msg404 = "资源不存在"

View File

@ -70,6 +70,7 @@ func _r(c *gin.Context, r *res, args ...any) {
func R400(c *gin.Context, args ...any) {
r := &res{
Status: 400,
Code: -1,
}
_r(c, r, args...)
@ -78,6 +79,7 @@ func R400(c *gin.Context, args ...any) {
func R401(c *gin.Context, args ...any) {
r := &res{
Status: 401,
Code: -1,
}
_r(c, r, args...)
@ -86,6 +88,7 @@ func R401(c *gin.Context, args ...any) {
func R403(c *gin.Context, args ...any) {
r := &res{
Status: 403,
Code: -1,
}
_r(c, r, args...)
@ -94,6 +97,7 @@ func R403(c *gin.Context, args ...any) {
func R500(c *gin.Context, args ...any) {
r := &res{
Status: 500,
Code: -1,
}
_r(c, r, args...)
@ -102,6 +106,7 @@ func R500(c *gin.Context, args ...any) {
func R501(c *gin.Context, args ...any) {
r := &res{
Status: 501,
Code: -1,
}
_r(c, r, args...)

View File

@ -1,7 +1,9 @@
package tool
import (
"context"
"gitea.loveuer.com/yizhisec/packages/logger"
"sync"
)
func Must(errs ...error) {
@ -11,3 +13,41 @@ func Must(errs ...error) {
}
}
}
func MustWithData[T any](data T, err error) T {
Must(err)
return data
}
func MustStop(ctx context.Context, stopFns ...func(ctx context.Context) error) {
if len(stopFns) == 0 {
return
}
ok := make(chan struct{})
wg := &sync.WaitGroup{}
wg.Add(len(stopFns))
for _, fn := range stopFns {
go func() {
defer wg.Done()
if err := fn(ctx); err != nil {
logger.ErrorCtx(ctx, "stop function failed, err = %s", err.Error())
}
}()
}
go func() {
select {
case <-ctx.Done():
logger.FatalCtx(ctx, "stop function timeout, force down")
case _, _ = <-ok:
return
}
}()
wg.Wait()
close(ok)
}