package data_manage_permission

import (
	"eta/eta_mobile/models/data_manage/data_manage_permission"
	"eta/eta_mobile/models/data_manage/excel"
	"eta/eta_mobile/utils"
	"fmt"
)

// CheckExcelPermissionByPermissionIdList
// @Description: 检查ETA图库(只包含ETA图库,不包含统计分析等模块)权限
// @author: Roc
// @datetime 2024-03-28 16:12:08
// @param excelIsJoinPermission int
// @param excelClassifyIsJoinPermission int
// @param excelInfoId int
// @param excelClassifyId int
// @param permissionExcelInfoIdList []int
// @param permissionExcelClassifyIdList []int
// @return hasAuth bool
func CheckExcelPermissionByPermissionIdList(excelIsJoinPermission, excelClassifyIsJoinPermission, excelInfoId, excelClassifyId int, permissionExcelInfoIdList, permissionExcelClassifyIdList []int) (hasAuth bool) {
	//hasAuth = true

	// 判断 分类是否纳入权限管控
	if excelClassifyIsJoinPermission == 1 {
		// 不属于已授权的分类,那么就无权限
		if !utils.InArrayByInt(permissionExcelClassifyIdList, excelClassifyId) {
			return false
		}
	}

	// 判断 指标是否纳入权限管控
	if excelIsJoinPermission == 1 {
		// 不属于已授权的指标,那么就无权限
		if !utils.InArrayByInt(permissionExcelInfoIdList, excelInfoId) {
			return false
		}
	}

	hasAuth = true

	return
}

// CheckExcelClassifyPermissionByPermissionIdList
// @Description: 检查EDB分类权限
// @author: Roc
// @datetime 2024-03-29 14:35:19
// @param excelClassifyIsJoinPermission int
// @param excelClassifyId int
// @param permissionExcelClassifyIdList []int
// @return hasAuth bool
func CheckExcelClassifyPermissionByPermissionIdList(excelClassifyIsJoinPermission, excelClassifyId int, permissionExcelClassifyIdList []int) (hasAuth bool) {
	// 判断 分类是否纳入权限管控
	if excelClassifyIsJoinPermission == 1 {
		// 不属于已授权的分类,那么就无权限
		if !utils.InArrayByInt(permissionExcelClassifyIdList, excelClassifyId) {
			return
		}
	}

	hasAuth = true

	return
}

// GetUserExcelAndClassifyPermissionList
// @Description: 根据用户获取已经授权指标ID列表和指标分类ID列表
// @author: Roc
// @datetime 2024-03-28 17:20:36
// @param userId int
// @param excelInfoId int 如果传递了excelInfoId,则只返回该excelInfoId的权限列表(其实也就是为了判断是否存在该指标权限了,目的是为了少获取数据)
// @param classifyId int  classifyId,则只返回该classifyId的权限列表(其实也就是为了判断是否存在该指标分类权限了,目的是为了少获取数据)
// @return excelIdList []int
// @return classifyIdList []int
// @return err error
func GetUserExcelAndClassifyPermissionList(userId, excelInfoId, classifyId int) (excelIdList, classifyIdList []int, err error) {
	// 获取有权限的指标ID列表
	excelIdList, err = data_manage_permission.GetPermissionExcelIdList(userId, excelInfoId)
	if err != nil {
		fmt.Println("获取授权指标列表失败, err:", err)
		return
	}

	// 获取有权限的指标分类ID列表
	classifyIdList, err = data_manage_permission.GetPermissionExcelClassifyIdList(userId, classifyId)
	if err != nil {
		fmt.Println("获取授权指标分类列表失败, err:", err)
		return
	}

	return
}

// GetUserExcelClassifyPermissionList
// @Description: 根据用户获取已经授权指标分类ID列表
// @author: Roc
// @datetime 2024-03-28 17:20:36
// @param userId int
// @param classifyId int  classifyId,则只返回该classifyId的权限列表(其实也就是为了判断是否存在该指标分类权限了,目的是为了少获取数据)
// @return classifyIdList []int
// @return err error
func GetUserExcelClassifyPermissionList(userId, classifyId int) (classifyIdList []int, err error) {
	// 获取有权限的指标分类ID列表
	classifyIdList, err = data_manage_permission.GetPermissionExcelClassifyIdList(userId, classifyId)
	if err != nil {
		fmt.Println("获取授权指标分类列表失败, err:", err)
		return
	}

	return
}

// CheckExcelPermissionByExcelInfoId
// @Description: 根据指标id和指标分类id,检查EDB指标(含预测指标)权限(方法内部自己获取所有的指标和指标分类权限,不用额外传递)
// @author: Roc
// @datetime 2024-03-29 13:28:06
// @param excelInfoId int
// @param excelClassifyId int
// @param excelIsJoinPermission int
// @param userId int
// @return hasAuth bool
// @return err error
func CheckExcelPermissionByExcelInfoId(excelInfoId, excelClassifyId, excelIsJoinPermission, userId int) (hasAuth bool, err error) {
	currClassify, err := excel.GetExcelClassifyById(excelClassifyId)
	if err != nil {
		return
	}
	if currClassify != nil {
		return CheckExcelPermission(excelIsJoinPermission, currClassify.IsJoinPermission, userId, excelInfoId, excelClassifyId)
	}

	return
}

// CheckExcelPermission
// @Description: 检查EDB指标(含预测指标)权限(方法内部自己获取所有的指标和指标分类权限,不用额外传递)
// @author: Roc
// @datetime 2024-03-28 16:12:08
// @param excelIsJoinPermission int
// @param excelClassifyIsJoinPermission int
// @param excelInfoId int
// @param excelClassifyId int
// @return hasAuth bool
func CheckExcelPermission(excelIsJoinPermission, excelClassifyIsJoinPermission, userId, excelInfoId, excelClassifyId int) (hasAuth bool, err error) {
	excelIdList, classifyIdList, err := GetUserExcelAndClassifyPermissionList(userId, excelInfoId, excelClassifyId)
	if err != nil {
		fmt.Println("GetUserExcelAndClassifyPermissionList err:", err)
		return
	}

	hasAuth = CheckExcelPermissionByPermissionIdList(excelIsJoinPermission, excelClassifyIsJoinPermission, excelInfoId, excelClassifyId, excelIdList, classifyIdList)

	return
}