sys_role.go 1.5 KB
package models

import (
	"fmt"
	"gitlab.fjmaimaimai.com/allied-creation/su-micro/cmd/ep/system/internal/pkg/domain"
	"gorm.io/gorm"
	"gorm.io/plugin/soft_delete"
)

type SysRole struct {
	Id        int64   // 唯一标识
	CompanyId int64   // 公司ID
	Name      string  // 公司名称
	Menus     []int64 `gorm:"type:jsonb;serializer:json"` // 菜单列表
	Apps      []int64 `gorm:"type:jsonb;serializer:json"` // 应用列表
	AuthUsers []int64 `gorm:"type:jsonb;serializer:json"` // 拥护该角色的用户列表
	AuthRange int
	Remark    string
	CreatedAt int64
	UpdatedAt int64
	DeletedAt int64
	Version   int
	IsDel     soft_delete.DeletedAt `gorm:"softDelete:flag,DeletedAtField:DeletedAt"`
}

func (m *SysRole) TableName() string {
	return "sys.role"
}

func (m *SysRole) BeforeCreate(tx *gorm.DB) (err error) {
	// m.CreatedAt = time.Now().Unix()
	// m.UpdatedAt = time.Now().Unix()
	return
}

func (m *SysRole) BeforeUpdate(tx *gorm.DB) (err error) {
	// m.UpdatedAt = time.Now().Unix()
	return
}

func (m *SysRole) CacheKeyFunc() string {
	if m.Id == 0 {
		return ""
	}
	return fmt.Sprintf("%v:cache:%v:id:%v", domain.ProjectName, m.TableName(), m.Id)
}

func (m *SysRole) CacheKeyFuncByObject(obj interface{}) string {
	if v, ok := obj.(*SysRole); ok {
		return v.CacheKeyFunc()
	}
	return ""
}

func (m *SysRole) CachePrimaryKeyFunc() string {
	if len("") == 0 {
		return ""
	}
	return fmt.Sprintf("%v:cache:%v:primarykey:%v", domain.ProjectName, m.TableName(), "key")
}