| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274 | package systemimport (	"kpt-tmr-group/http/middleware"	"kpt-tmr-group/pkg/apierr"	"kpt-tmr-group/pkg/ginutil"	"kpt-tmr-group/pkg/valid"	operationPb "kpt-tmr-group/proto/go/backend/operation"	"net/http"	"strconv"	"github.com/gin-gonic/gin")// Auth 用户登录func Auth(c *gin.Context) {	var req operationPb.UserAuthData	if err := ginutil.BindProto(c, &req); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	if err := valid.ValidateStruct(&req,		valid.Field(&req.UserName, valid.Required),		valid.Field(&req.Password, valid.Required),	); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	res, err := middleware.Dependency(c).StoreEventHub.OpsService.Auth(c, &req)	if err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, res)}func GetWxAppletOpenId(c *gin.Context) {	jsCode := c.Param("js_code")	if err := valid.Validate(jsCode, valid.Required, valid.Length(1, 100)); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	res, err := middleware.BackendOperation(c).OpsService.GetOpenId(c, jsCode)	if err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, res)}// AddSystemUser 创建系统用户func AddSystemUser(c *gin.Context) {	var req operationPb.AddSystemUser	if err := ginutil.BindProto(c, &req); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	if err := valid.ValidateStruct(&req,		valid.Field(&req.Name, valid.Required),		valid.Field(&req.Phone, valid.Required),		valid.Field(&req.EmployeeName, valid.Required),		valid.Field(&req.Roles, valid.NotNil),		valid.Field(&req.IsShow, valid.Max(2), valid.Min(1)),		valid.Field(&req.CreateUser, valid.Required),	); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	if err := middleware.Dependency(c).StoreEventHub.OpsService.CreateSystemUser(c, &req); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, &operationPb.CommonOK{		Code: http.StatusOK,		Msg:  "ok",		Data: &operationPb.Success{Success: true},	})}// DetailsSystemUser 系统用户详情func DetailsSystemUser(c *gin.Context) {	userIdStr := c.Param("user_id")	userId, _ := strconv.Atoi(userIdStr)	if err := valid.Validate(userId, valid.Required, valid.Min(1)); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	res, err := middleware.BackendOperation(c).OpsService.DetailsSystemUser(c, int64(userId))	if err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, res)}// GetUserInfo 获取用户信息func GetUserInfo(c *gin.Context) {	token := middleware.GetToken(c)	if err := valid.Validate(token, valid.Required); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	res, err := middleware.BackendOperation(c).OpsService.GetUserInfo(c, token)	if err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, res)}// SearchSystemUserList 查询系统用户列表func SearchSystemUserList(c *gin.Context) {	var req operationPb.SearchUserRequest	if err := ginutil.BindProto(c, &req); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	if err := valid.ValidateStruct(&req,		valid.Field(&req.IsShow, valid.Max(2), valid.Min(1)),	); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	req.Pagination = &operationPb.PaginationModel{		Page:       int32(c.GetInt(middleware.Page)),		PageSize:   int32(c.GetInt(middleware.PageSize)),		PageOffset: int32(c.GetInt(middleware.PageOffset)),	}	res, err := middleware.Dependency(c).StoreEventHub.OpsService.SearchSystemUserList(c, &req)	if err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, res)}// EditSystemUser 编辑系统用户func EditSystemUser(c *gin.Context) {	var req operationPb.AddSystemUser	if err := ginutil.BindProto(c, &req); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	if err := valid.ValidateStruct(&req,		valid.Field(&req.Id, valid.Required, valid.Min(1)),		valid.Field(&req.Name, valid.Required),		valid.Field(&req.Phone, valid.Required),		valid.Field(&req.EmployeeName, valid.Required),		valid.Field(&req.Roles, valid.Required),		valid.Field(&req.CreateUser, valid.Required),	); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	if err := middleware.Dependency(c).StoreEventHub.OpsService.EditSystemUser(c, &req); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, &operationPb.CommonOK{		Code: http.StatusOK,		Msg:  "ok",		Data: &operationPb.Success{Success: true},	})}// DeleteUser 删除系统用户func DeleteUser(c *gin.Context) {	userIdStr := c.Param("user_id")	userId, _ := strconv.Atoi(userIdStr)	if err := valid.Validate(userId, valid.Required, valid.Min(1)); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	if err := middleware.BackendOperation(c).OpsService.DeleteSystemUser(c, int64(userId)); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, &operationPb.CommonOK{		Code: http.StatusOK,		Msg:  "ok",		Data: &operationPb.Success{Success: true},	})}// IsShowSystemUser 系统用户启动开关func IsShowSystemUser(c *gin.Context) {	var req operationPb.IsShowSystemUserRequest	if err := ginutil.BindProto(c, &req); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	if err := valid.ValidateStruct(&req,		valid.Field(&req.UserId, valid.Required, valid.Min(1)),		valid.Field(&req.IsShow, valid.Required, valid.Min(1), valid.Max(2)),	); err != nil {		apierr.AbortBadRequest(c, http.StatusBadRequest, err)		return	}	if err := middleware.Dependency(c).StoreEventHub.OpsService.IsShowSystemUser(c, &req); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, &operationPb.CommonOK{		Code: http.StatusOK,		Msg:  "ok",		Data: &operationPb.Success{Success: true},	})}// GetSystemUserPermissions 获取系统用户菜单权限func GetSystemUserPermissions(c *gin.Context) {	token := middleware.GetToken(c)	if err := valid.Validate(token, valid.Required); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	res, err := middleware.BackendOperation(c).OpsService.GetSystemUserPermissions(c, token)	if err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, res)}// ResetPasswordSystemUser 用户密码重置func ResetPasswordSystemUser(c *gin.Context) {	userIdStr := c.Param("user_id")	userId, _ := strconv.Atoi(userIdStr)	if err := valid.Validate(userId, valid.Required, valid.Min(1)); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	if err := middleware.BackendOperation(c).OpsService.ResetPasswordSystemUser(c, int64(userId)); err != nil {		apierr.ClassifiedAbort(c, err)		return	}	ginutil.JSONResp(c, &operationPb.CommonOK{		Code: http.StatusOK,		Msg:  "ok",		Data: &operationPb.Success{Success: true},	})}// LogoutSystemUser 用户登出,func LogoutSystemUser(c *gin.Context) {	ginutil.JSONResp(c, &operationPb.CommonOK{		Code: http.StatusOK,		Msg:  "ok",		Data: &operationPb.Success{Success: true},	})}
 |