You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

142 lines
4.6 KiB

package repository
import (
"gofaster/internal/auth/model"
"gorm.io/gorm"
)
// MenuRouteRepository 菜单路由关联表仓储
type MenuRouteRepository struct {
db *gorm.DB
}
// NewMenuRouteRepository 创建菜单路由关联表仓储
func NewMenuRouteRepository(db *gorm.DB) *MenuRouteRepository {
return &MenuRouteRepository{db: db}
}
// Create 创建菜单路由关联
func (r *MenuRouteRepository) Create(menuRoute *model.MenuRoute) error {
return r.db.Create(menuRoute).Error
}
// CreateBatch 批量创建菜单路由关联
func (r *MenuRouteRepository) CreateBatch(menuRoutes []*model.MenuRoute) error {
return r.db.CreateInBatches(menuRoutes, 100).Error
}
// GetByID 根据ID获取菜单路由关联
func (r *MenuRouteRepository) GetByID(id uint) (*model.MenuRoute, error) {
var menuRoute model.MenuRoute
err := r.db.Where("id = ?", id).First(&menuRoute).Error
if err != nil {
return nil, err
}
return &menuRoute, nil
}
// GetByMenuAndRoute 根据菜单ID和路由ID获取关联
func (r *MenuRouteRepository) GetByMenuAndRoute(menuID, routeMappingID uint) (*model.MenuRoute, error) {
var menuRoute model.MenuRoute
err := r.db.Where("menu_id = ? AND route_mapping_id = ?", menuID, routeMappingID).First(&menuRoute).Error
if err != nil {
return nil, err
}
return &menuRoute, nil
}
// GetByMenuID 根据菜单ID获取所有关联的路由
func (r *MenuRouteRepository) GetByMenuID(menuID uint) ([]*model.MenuRoute, error) {
var menuRoutes []*model.MenuRoute
err := r.db.Where("menu_id = ?", menuID).Order("sort ASC").Find(&menuRoutes).Error
return menuRoutes, err
}
// GetByRouteMappingID 根据路由映射ID获取所有关联的菜单
func (r *MenuRouteRepository) GetByRouteMappingID(routeMappingID uint) ([]*model.MenuRoute, error) {
var menuRoutes []*model.MenuRoute
err := r.db.Where("route_mapping_id = ?", routeMappingID).Order("sort ASC").Find(&menuRoutes).Error
return menuRoutes, err
}
// List 获取菜单路由关联列表
func (r *MenuRouteRepository) List(page, pageSize int) ([]*model.MenuRoute, int64, error) {
var menuRoutes []*model.MenuRoute
var total int64
// 获取总数
if err := r.db.Model(&model.MenuRoute{}).Count(&total).Error; err != nil {
return nil, 0, err
}
// 获取分页数据
offset := (page - 1) * pageSize
err := r.db.Offset(offset).Limit(pageSize).Order("created_at DESC").Find(&menuRoutes).Error
return menuRoutes, total, err
}
// Update 更新菜单路由关联
func (r *MenuRouteRepository) Update(menuRoute *model.MenuRoute) error {
return r.db.Save(menuRoute).Error
}
// Delete 删除菜单路由关联
func (r *MenuRouteRepository) Delete(id uint) error {
return r.db.Delete(&model.MenuRoute{}, id).Error
}
// DeleteByMenuID 根据菜单ID删除所有关联
func (r *MenuRouteRepository) DeleteByMenuID(menuID uint) error {
return r.db.Where("menu_id = ?", menuID).Delete(&model.MenuRoute{}).Error
}
// DeleteByRouteMappingID 根据路由映射ID删除所有关联
func (r *MenuRouteRepository) DeleteByRouteMappingID(routeMappingID uint) error {
return r.db.Where("route_mapping_id = ?", routeMappingID).Delete(&model.MenuRoute{}).Error
}
// DeleteByMenuAndRoute 根据菜单ID和路由ID删除关联
func (r *MenuRouteRepository) DeleteByMenuAndRoute(menuID, routeMappingID uint) error {
return r.db.Where("menu_id = ? AND route_mapping_id = ?", menuID, routeMappingID).Delete(&model.MenuRoute{}).Error
}
// GetMenuWithRoutes 获取菜单及其关联的路由信息
func (r *MenuRouteRepository) GetMenuWithRoutes(menuID uint) (*model.Menu, []*model.RouteMapping, error) {
var menu model.Menu
var routeMappings []*model.RouteMapping
// 获取菜单信息
if err := r.db.First(&menu, menuID).Error; err != nil {
return nil, nil, err
}
// 获取关联的路由映射
err := r.db.Table("route_mappings").
Joins("JOIN menu_routes ON route_mappings.id = menu_routes.route_mapping_id").
Where("menu_routes.menu_id = ?", menuID).
Order("menu_routes.sort ASC").
Find(&routeMappings).Error
return &menu, routeMappings, err
}
// GetRouteWithMenus 获取路由及其关联的菜单信息
func (r *MenuRouteRepository) GetRouteWithMenus(routeMappingID uint) (*model.RouteMapping, []*model.Menu, error) {
var routeMapping model.RouteMapping
var menus []*model.Menu
// 获取路由映射信息
if err := r.db.First(&routeMapping, routeMappingID).Error; err != nil {
return nil, nil, err
}
// 获取关联的菜单
err := r.db.Table("menus").
Joins("JOIN menu_routes ON menus.id = menu_routes.menu_id").
Where("menu_routes.route_mapping_id = ?", routeMappingID).
Order("menu_routes.sort ASC").
Find(&menus).Error
return &routeMapping, menus, err
}