mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 07:50:25 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			251 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			251 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package services
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"encoding/json"
 | 
						|
	"errors"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/db/models"
 | 
						|
	"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
						|
	"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/ossconfigs"
 | 
						|
	"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/shared"
 | 
						|
	"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/sslconfigs"
 | 
						|
	"github.com/iwind/TeaGo/maps"
 | 
						|
)
 | 
						|
 | 
						|
// OriginService 源站相关管理
 | 
						|
type OriginService struct {
 | 
						|
	BaseService
 | 
						|
}
 | 
						|
 | 
						|
// CreateOrigin 创建源站
 | 
						|
func (this *OriginService) CreateOrigin(ctx context.Context, req *pb.CreateOriginRequest) (*pb.CreateOriginResponse, error) {
 | 
						|
	adminId, userId, err := this.ValidateAdminAndUser(ctx, true)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	// 源站地址设置
 | 
						|
	if req.Addr == nil {
 | 
						|
		return nil, errors.New("'addr' can not be nil")
 | 
						|
	}
 | 
						|
	var addrMap = maps.Map{
 | 
						|
		"protocol":  req.Addr.Protocol,
 | 
						|
		"portRange": req.Addr.PortRange,
 | 
						|
		"host":      req.Addr.Host,
 | 
						|
	}
 | 
						|
 | 
						|
	// OSS设置
 | 
						|
	var ossConfig *ossconfigs.OSSConfig
 | 
						|
	if len(req.OssJSON) > 0 {
 | 
						|
		ossConfig = ossconfigs.NewOSSConfig()
 | 
						|
		err = json.Unmarshal(req.OssJSON, ossConfig)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	var tx = this.NullTx()
 | 
						|
 | 
						|
	// 校验参数
 | 
						|
	var connTimeout = &shared.TimeDuration{}
 | 
						|
	if len(req.ConnTimeoutJSON) > 0 {
 | 
						|
		err = json.Unmarshal(req.ConnTimeoutJSON, connTimeout)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	var readTimeout = &shared.TimeDuration{}
 | 
						|
	if len(req.ReadTimeoutJSON) > 0 {
 | 
						|
		err = json.Unmarshal(req.ReadTimeoutJSON, readTimeout)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	var idleTimeout = &shared.TimeDuration{}
 | 
						|
	if len(req.IdleTimeoutJSON) > 0 {
 | 
						|
		err = json.Unmarshal(req.IdleTimeoutJSON, idleTimeout)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	// cert
 | 
						|
	var certRef *sslconfigs.SSLCertRef
 | 
						|
	if len(req.CertRefJSON) > 0 {
 | 
						|
		certRef = &sslconfigs.SSLCertRef{}
 | 
						|
		err = json.Unmarshal(req.CertRefJSON, certRef)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
		if certRef.CertId <= 0 {
 | 
						|
			certRef = nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	originId, err := models.SharedOriginDAO.CreateOrigin(tx, adminId, userId, req.Name, addrMap.AsJSON(), ossConfig, req.Description, req.Weight, req.IsOn, connTimeout, readTimeout, idleTimeout, req.MaxConns, req.MaxIdleConns, certRef, req.Domains, req.Host, req.FollowPort, req.Http2Enabled)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	return &pb.CreateOriginResponse{OriginId: originId}, nil
 | 
						|
}
 | 
						|
 | 
						|
// UpdateOrigin 修改源站
 | 
						|
func (this *OriginService) UpdateOrigin(ctx context.Context, req *pb.UpdateOriginRequest) (*pb.RPCSuccess, error) {
 | 
						|
	_, userId, err := this.ValidateAdminAndUser(ctx, true)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	var tx = this.NullTx()
 | 
						|
 | 
						|
	if userId > 0 {
 | 
						|
		err = models.SharedOriginDAO.CheckUserOrigin(tx, userId, req.OriginId)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	// 源站地址设置
 | 
						|
	if req.Addr == nil {
 | 
						|
		return nil, errors.New("'addr' can not be nil")
 | 
						|
	}
 | 
						|
	var addrMap = maps.Map{
 | 
						|
		"protocol":  req.Addr.Protocol,
 | 
						|
		"portRange": req.Addr.PortRange,
 | 
						|
		"host":      req.Addr.Host,
 | 
						|
	}
 | 
						|
 | 
						|
	// OSS设置
 | 
						|
	var ossConfig *ossconfigs.OSSConfig
 | 
						|
	if len(req.OssJSON) > 0 {
 | 
						|
		ossConfig = ossconfigs.NewOSSConfig()
 | 
						|
		err = json.Unmarshal(req.OssJSON, ossConfig)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	// 校验参数
 | 
						|
	var connTimeout = &shared.TimeDuration{}
 | 
						|
	if len(req.ConnTimeoutJSON) > 0 {
 | 
						|
		err = json.Unmarshal(req.ConnTimeoutJSON, connTimeout)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	var readTimeout = &shared.TimeDuration{}
 | 
						|
	if len(req.ReadTimeoutJSON) > 0 {
 | 
						|
		err = json.Unmarshal(req.ReadTimeoutJSON, readTimeout)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	var idleTimeout = &shared.TimeDuration{}
 | 
						|
	if len(req.IdleTimeoutJSON) > 0 {
 | 
						|
		err = json.Unmarshal(req.IdleTimeoutJSON, idleTimeout)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	// cert
 | 
						|
	var certRef *sslconfigs.SSLCertRef
 | 
						|
	if len(req.CertRefJSON) > 0 {
 | 
						|
		certRef = &sslconfigs.SSLCertRef{}
 | 
						|
		err = json.Unmarshal(req.CertRefJSON, certRef)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
		if certRef.CertId <= 0 {
 | 
						|
			certRef = nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	err = models.SharedOriginDAO.UpdateOrigin(tx, req.OriginId, req.Name, addrMap.AsJSON(), ossConfig, req.Description, req.Weight, req.IsOn, connTimeout, readTimeout, idleTimeout, req.MaxConns, req.MaxIdleConns, certRef, req.Domains, req.Host, req.FollowPort, req.Http2Enabled)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	return this.Success()
 | 
						|
}
 | 
						|
 | 
						|
// FindEnabledOrigin 查找单个源站信息
 | 
						|
func (this *OriginService) FindEnabledOrigin(ctx context.Context, req *pb.FindEnabledOriginRequest) (*pb.FindEnabledOriginResponse, error) {
 | 
						|
	_, userId, err := this.ValidateAdminAndUser(ctx, true)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	var tx = this.NullTx()
 | 
						|
 | 
						|
	if userId > 0 {
 | 
						|
		err = models.SharedOriginDAO.CheckUserOrigin(tx, userId, req.OriginId)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	origin, err := models.SharedOriginDAO.FindEnabledOrigin(tx, req.OriginId)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	if origin == nil {
 | 
						|
		return &pb.FindEnabledOriginResponse{Origin: nil}, nil
 | 
						|
	}
 | 
						|
 | 
						|
	addr, err := origin.DecodeAddr()
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	return &pb.FindEnabledOriginResponse{Origin: &pb.Origin{
 | 
						|
		Id:   int64(origin.Id),
 | 
						|
		IsOn: origin.IsOn,
 | 
						|
		Name: origin.Name,
 | 
						|
		Addr: &pb.NetworkAddress{
 | 
						|
			Protocol:  addr.Protocol.String(),
 | 
						|
			Host:      addr.Host,
 | 
						|
			PortRange: addr.PortRange,
 | 
						|
		},
 | 
						|
		Description:  origin.Description,
 | 
						|
		Domains:      origin.DecodeDomains(),
 | 
						|
		FollowPort:   origin.FollowPort,
 | 
						|
		Http2Enabled: origin.Http2Enabled,
 | 
						|
	}}, nil
 | 
						|
}
 | 
						|
 | 
						|
// FindEnabledOriginConfig 查找源站配置
 | 
						|
func (this *OriginService) FindEnabledOriginConfig(ctx context.Context, req *pb.FindEnabledOriginConfigRequest) (*pb.FindEnabledOriginConfigResponse, error) {
 | 
						|
	_, userId, err := this.ValidateAdminAndUser(ctx, true)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	var tx = this.NullTx()
 | 
						|
 | 
						|
	if userId > 0 {
 | 
						|
		err = models.SharedOriginDAO.CheckUserOrigin(tx, userId, req.OriginId)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	config, err := models.SharedOriginDAO.ComposeOriginConfig(tx, req.OriginId, nil, nil)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	configData, err := json.Marshal(config)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	return &pb.FindEnabledOriginConfigResponse{OriginJSON: configData}, nil
 | 
						|
}
 |