Files
EdgeAPI/internal/rpc/services/service_ip_list.go

336 lines
8.8 KiB
Go
Raw Normal View History

2020-11-07 19:40:24 +08:00
package services
import (
"context"
2024-07-27 14:15:25 +08:00
2020-11-07 19:40:24 +08:00
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
"github.com/TeaOSLab/EdgeAPI/internal/errors"
2021-11-17 19:51:00 +08:00
"github.com/TeaOSLab/EdgeAPI/internal/utils"
2020-11-07 19:40:24 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/firewallconfigs"
2021-08-15 15:42:32 +08:00
"github.com/iwind/TeaGo/lists"
"github.com/iwind/TeaGo/rands"
2020-11-07 19:40:24 +08:00
)
2021-06-23 13:12:54 +08:00
// IPListService IP名单相关服务
2020-11-07 19:40:24 +08:00
type IPListService struct {
2020-11-24 15:02:44 +08:00
BaseService
2020-11-07 19:40:24 +08:00
}
2021-06-23 13:12:54 +08:00
// CreateIPList 创建IP列表
2020-11-07 19:40:24 +08:00
func (this *IPListService) CreateIPList(ctx context.Context, req *pb.CreateIPListRequest) (*pb.CreateIPListResponse, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
_, userId, err := this.ValidateAdminAndUser(ctx, true)
2020-11-07 19:40:24 +08:00
if err != nil {
return nil, err
}
2022-06-15 19:22:33 +08:00
var tx = this.NullTx()
// 修正默认的代号
if req.Code == "white" || req.Code == "black" || req.Code == "grey" {
req.Code = req.Code + "-" + rands.HexString(8)
}
2022-06-15 19:22:33 +08:00
// 检查用户相关信息
var sourceUserId = userId
2022-06-15 19:22:33 +08:00
if userId > 0 {
// 检查网站ID
2022-06-15 19:22:33 +08:00
if req.ServerId > 0 {
err = models.SharedServerDAO.CheckUserServer(tx, userId, req.ServerId)
if err != nil {
return nil, err
}
}
} else if req.ServerId > 0 {
sourceUserId, err = models.SharedServerDAO.FindServerUserId(tx, req.ServerId)
if err != nil {
return nil, err
}
2022-06-15 19:22:33 +08:00
}
// 检查代号
if len(req.Code) > 0 {
2024-05-05 19:19:42 +08:00
if len(req.Code) > 100 {
return nil, errors.New("too long 'code', should be short than 100 characters")
}
if !models.SharedIPListDAO.ValidateIPListCode(req.Code) {
return nil, errors.New("invalid 'code' format")
}
oldListId, findErr := models.SharedIPListDAO.FindIPListIdWithCode(tx, req.Code)
if findErr != nil {
return nil, findErr
}
if oldListId > 0 {
return nil, errors.New("the code '" + req.Code + "' has been used")
}
}
listId, err := models.SharedIPListDAO.CreateIPList(tx, sourceUserId, req.ServerId, req.Type, req.Name, req.Code, req.TimeoutJSON, req.Description, req.IsPublic, req.IsGlobal)
2020-11-07 19:40:24 +08:00
if err != nil {
return nil, err
}
return &pb.CreateIPListResponse{IpListId: listId}, nil
}
2021-06-23 13:12:54 +08:00
// UpdateIPList 修改IP列表
func (this *IPListService) UpdateIPList(ctx context.Context, req *pb.UpdateIPListRequest) (*pb.RPCSuccess, error) {
2020-11-07 19:40:24 +08:00
// 校验请求
2022-07-22 14:35:17 +08:00
_, err := this.ValidateAdmin(ctx)
2020-11-07 19:40:24 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
// 检查代号
if len(req.Code) > 0 {
2024-05-05 19:19:42 +08:00
if len(req.Code) > 100 {
return nil, errors.New("too long 'code', should be short than 100 characters")
}
if !models.SharedIPListDAO.ValidateIPListCode(req.Code) {
return nil, errors.New("invalid 'code' format")
}
oldListId, findErr := models.SharedIPListDAO.FindIPListIdWithCode(tx, req.Code)
if findErr != nil {
return nil, findErr
}
if oldListId > 0 && oldListId != req.IpListId {
return nil, errors.New("the code '" + req.Code + "' has been used")
}
}
2021-06-23 13:12:54 +08:00
err = models.SharedIPListDAO.UpdateIPList(tx, req.IpListId, req.Name, req.Code, req.TimeoutJSON, req.Description)
2020-11-07 19:40:24 +08:00
if err != nil {
return nil, err
}
2020-11-24 15:02:44 +08:00
return this.Success()
2020-11-07 19:40:24 +08:00
}
2021-06-23 13:12:54 +08:00
// FindEnabledIPList 查找IP列表
2020-11-07 19:40:24 +08:00
func (this *IPListService) FindEnabledIPList(ctx context.Context, req *pb.FindEnabledIPListRequest) (*pb.FindEnabledIPListResponse, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
_, userId, err := this.ValidateAdminAndUser(ctx, true)
2020-11-07 19:40:24 +08:00
if err != nil {
return nil, err
}
2022-06-15 19:22:33 +08:00
var tx = this.NullTx()
if userId > 0 {
// 检查用户所属名单
if !firewallconfigs.IsGlobalListId(req.IpListId) {
err = models.SharedIPListDAO.CheckUserIPList(tx, userId, req.IpListId)
if err != nil {
return nil, err
}
2022-06-15 19:22:33 +08:00
}
}
2021-11-17 19:51:00 +08:00
list, err := models.SharedIPListDAO.FindEnabledIPList(tx, req.IpListId, nil)
2020-11-07 19:40:24 +08:00
if err != nil {
return nil, err
}
if list == nil {
return &pb.FindEnabledIPListResponse{IpList: nil}, nil
}
return &pb.FindEnabledIPListResponse{IpList: &pb.IPList{
Id: int64(list.Id),
2022-03-22 21:45:07 +08:00
IsOn: list.IsOn,
2020-11-07 19:40:24 +08:00
Type: list.Type,
Name: list.Name,
Code: list.Code,
2022-03-22 19:30:30 +08:00
TimeoutJSON: list.Timeout,
2021-06-23 13:12:54 +08:00
Description: list.Description,
2022-03-22 22:11:32 +08:00
IsGlobal: list.IsGlobal,
2020-11-07 19:40:24 +08:00
}}, nil
}
2021-06-23 13:12:54 +08:00
// CountAllEnabledIPLists 计算名单数量
func (this *IPListService) CountAllEnabledIPLists(ctx context.Context, req *pb.CountAllEnabledIPListsRequest) (*pb.RPCCountResponse, error) {
2022-07-22 14:35:17 +08:00
_, err := this.ValidateAdmin(ctx)
2021-06-23 13:12:54 +08:00
if err != nil {
return nil, err
}
var tx = this.NullTx()
count, err := models.SharedIPListDAO.CountAllEnabledIPLists(tx, req.Type, req.IsPublic, req.Keyword)
if err != nil {
return nil, err
}
return this.SuccessCount(count)
}
// ListEnabledIPLists 列出单页名单
func (this *IPListService) ListEnabledIPLists(ctx context.Context, req *pb.ListEnabledIPListsRequest) (*pb.ListEnabledIPListsResponse, error) {
2022-07-22 14:35:17 +08:00
_, err := this.ValidateAdmin(ctx)
2021-06-23 13:12:54 +08:00
if err != nil {
return nil, err
}
var tx = this.NullTx()
ipLists, err := models.SharedIPListDAO.ListEnabledIPLists(tx, req.Type, req.IsPublic, req.Keyword, req.Offset, req.Size)
2021-06-23 13:12:54 +08:00
if err != nil {
return nil, err
}
var pbLists []*pb.IPList
for _, list := range ipLists {
2021-06-23 13:12:54 +08:00
pbLists = append(pbLists, &pb.IPList{
Id: int64(list.Id),
2022-03-22 21:45:07 +08:00
IsOn: list.IsOn,
2021-06-23 13:12:54 +08:00
Type: list.Type,
Name: list.Name,
Code: list.Code,
2022-03-22 19:30:30 +08:00
TimeoutJSON: list.Timeout,
2022-03-22 22:11:32 +08:00
IsPublic: list.IsPublic,
2021-06-23 13:12:54 +08:00
Description: list.Description,
2022-03-22 22:11:32 +08:00
IsGlobal: list.IsGlobal,
2021-06-23 13:12:54 +08:00
})
}
return &pb.ListEnabledIPListsResponse{IpLists: pbLists}, nil
}
// DeleteIPList 删除IP名单
func (this *IPListService) DeleteIPList(ctx context.Context, req *pb.DeleteIPListRequest) (*pb.RPCSuccess, error) {
2022-07-22 14:35:17 +08:00
_, err := this.ValidateAdmin(ctx)
2021-06-23 13:12:54 +08:00
if err != nil {
return nil, err
}
var tx = this.NullTx()
err = models.SharedIPListDAO.DisableIPList(tx, req.IpListId)
if err != nil {
return nil, err
}
// 删除所有IP
err = models.SharedIPItemDAO.DisableIPItemsWithListId(tx, req.IpListId)
if err != nil {
return nil, err
}
2021-06-23 13:12:54 +08:00
return this.Success()
}
// ExistsEnabledIPList 检查IPList是否存在
func (this *IPListService) ExistsEnabledIPList(ctx context.Context, req *pb.ExistsEnabledIPListRequest) (*pb.ExistsEnabledIPListResponse, error) {
2022-07-22 14:35:17 +08:00
_, err := this.ValidateAdmin(ctx)
2021-06-23 13:12:54 +08:00
if err != nil {
return nil, err
}
var tx = this.NullTx()
b, err := models.SharedIPListDAO.ExistsEnabledIPList(tx, req.IpListId)
if err != nil {
return nil, err
}
return &pb.ExistsEnabledIPListResponse{Exists: b}, nil
}
2021-08-15 15:42:32 +08:00
// FindEnabledIPListContainsIP 根据IP来搜索IP名单
func (this *IPListService) FindEnabledIPListContainsIP(ctx context.Context, req *pb.FindEnabledIPListContainsIPRequest) (*pb.FindEnabledIPListContainsIPResponse, error) {
2022-07-22 14:35:17 +08:00
_, err := this.ValidateAdmin(ctx)
2021-08-15 15:42:32 +08:00
if err != nil {
return nil, err
}
var tx = this.NullTx()
items, err := models.SharedIPItemDAO.FindEnabledItemsWithIP(tx, req.Ip)
if err != nil {
return nil, err
}
var pbLists = []*pb.IPList{}
var listIds = []int64{}
2021-11-17 19:51:00 +08:00
var cacheMap = utils.NewCacheMap()
2021-08-15 15:42:32 +08:00
for _, item := range items {
if lists.ContainsInt64(listIds, int64(item.ListId)) {
continue
}
2021-11-17 19:51:00 +08:00
list, err := models.SharedIPListDAO.FindEnabledIPList(tx, int64(item.ListId), cacheMap)
2021-08-15 15:42:32 +08:00
if err != nil {
return nil, err
}
if list == nil {
continue
}
2022-03-22 22:11:32 +08:00
if !list.IsPublic {
2021-08-15 15:42:32 +08:00
continue
}
pbLists = append(pbLists, &pb.IPList{
Id: int64(list.Id),
2022-03-22 21:45:07 +08:00
IsOn: list.IsOn,
2021-08-15 15:42:32 +08:00
Type: list.Type,
Name: list.Name,
Code: list.Code,
2022-03-22 22:11:32 +08:00
IsPublic: list.IsPublic,
IsGlobal: list.IsGlobal,
2021-08-15 15:42:32 +08:00
Description: "",
})
listIds = append(listIds, int64(item.ListId))
}
return &pb.FindEnabledIPListContainsIPResponse{IpLists: pbLists}, nil
}
2023-12-20 15:08:05 +08:00
// FindServerIdWithIPListId 查找IP名单对应的网站ID
func (this *IPListService) FindServerIdWithIPListId(ctx context.Context, req *pb.FindServerIdWithIPListIdRequest) (*pb.FindServerIdWithIPListIdResponse, error) {
_, userId, err := this.ValidateAdminAndUser(ctx, true)
if err != nil {
return nil, err
}
var tx = this.NullTx()
serverId, err := models.SharedIPListDAO.FindServerIdWithListId(tx, req.IpListId)
if err != nil {
return nil, err
}
// check user
if serverId > 0 && userId > 0 {
err = models.SharedServerDAO.CheckUserServer(tx, userId, serverId)
if err != nil {
return nil, err
}
}
return &pb.FindServerIdWithIPListIdResponse{
ServerId: serverId,
}, nil
}
// FindIPListIdWithCode 根据IP名单代号获取IP名单ID
func (this *IPListService) FindIPListIdWithCode(ctx context.Context, req *pb.FindIPListIdWithCodeRequest) (*pb.FindIPListIdWithCodeResponse, error) {
_, userId, err := this.ValidateAdminAndUser(ctx, true)
if err != nil {
return nil, err
}
if len(req.Code) == 0 {
return nil, errors.New("require 'code'")
}
var tx = this.NullTx()
listId, err := models.SharedIPListDAO.FindIPListIdWithCode(tx, req.Code)
if err != nil {
return nil, err
}
if listId > 0 {
if userId > 0 {
err = models.SharedIPListDAO.CheckUserIPList(tx, userId, listId)
if err != nil {
return nil, err
}
}
}
return &pb.FindIPListIdWithCodeResponse{
IpListId: listId,
}, nil
}