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

222 lines
6.0 KiB
Go
Raw Normal View History

2020-09-16 20:29:18 +08:00
package services
import (
"context"
"encoding/json"
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
2022-12-29 17:16:21 +08:00
"github.com/TeaOSLab/EdgeAPI/internal/errors"
2020-09-16 20:29:18 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
2022-12-29 17:16:21 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/shared"
2020-09-16 20:29:18 +08:00
)
type HTTPHeaderPolicyService struct {
2020-11-24 17:36:47 +08:00
BaseService
2020-09-16 20:29:18 +08:00
}
2022-07-22 15:05:30 +08:00
// FindEnabledHTTPHeaderPolicyConfig 查找策略配置
2020-09-16 20:29:18 +08:00
func (this *HTTPHeaderPolicyService) FindEnabledHTTPHeaderPolicyConfig(ctx context.Context, req *pb.FindEnabledHTTPHeaderPolicyConfigRequest) (*pb.FindEnabledHTTPHeaderPolicyConfigResponse, error) {
2022-12-29 17:16:21 +08:00
_, userId, err := this.ValidateAdminAndUser(ctx, true)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2022-12-29 17:16:21 +08:00
// 检查权限
if userId > 0 {
err = models.SharedHTTPHeaderPolicyDAO.CheckUserHeaderPolicy(tx, userId, req.HttpHeaderPolicyId)
if err != nil {
return nil, err
}
}
2022-09-17 16:07:37 +08:00
2022-12-29 17:16:21 +08:00
config, err := models.SharedHTTPHeaderPolicyDAO.ComposeHeaderPolicyConfig(tx, req.HttpHeaderPolicyId)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
configData, err := json.Marshal(config)
if err != nil {
return nil, err
}
2022-12-29 17:16:21 +08:00
return &pb.FindEnabledHTTPHeaderPolicyConfigResponse{HttpHeaderPolicyJSON: configData}, nil
2020-09-16 20:29:18 +08:00
}
2022-09-17 16:07:37 +08:00
// CreateHTTPHeaderPolicy 创建策略
2020-09-16 20:29:18 +08:00
func (this *HTTPHeaderPolicyService) CreateHTTPHeaderPolicy(ctx context.Context, req *pb.CreateHTTPHeaderPolicyRequest) (*pb.CreateHTTPHeaderPolicyResponse, error) {
2022-09-17 16:07:37 +08:00
_, _, err := this.ValidateAdminAndUser(ctx, true)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
headerPolicyId, err := models.SharedHTTPHeaderPolicyDAO.CreateHeaderPolicy(tx)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2022-12-29 17:16:21 +08:00
return &pb.CreateHTTPHeaderPolicyResponse{HttpHeaderPolicyId: headerPolicyId}, nil
2020-09-16 20:29:18 +08:00
}
2022-09-17 16:07:37 +08:00
// UpdateHTTPHeaderPolicyAddingHeaders 修改AddHeaders
func (this *HTTPHeaderPolicyService) UpdateHTTPHeaderPolicyAddingHeaders(ctx context.Context, req *pb.UpdateHTTPHeaderPolicyAddingHeadersRequest) (*pb.RPCSuccess, error) {
2022-12-29 17:16:21 +08:00
_, userId, err := this.ValidateAdminAndUser(ctx, true)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2022-12-29 17:16:21 +08:00
// 检查权限
if userId > 0 {
err = models.SharedHTTPHeaderPolicyDAO.CheckUserHeaderPolicy(tx, userId, req.HttpHeaderPolicyId)
if err != nil {
return nil, err
}
}
2022-09-17 16:07:37 +08:00
2022-12-29 17:16:21 +08:00
err = models.SharedHTTPHeaderPolicyDAO.UpdateAddingHeaders(tx, req.HttpHeaderPolicyId, req.HeadersJSON)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2020-11-24 17:36:47 +08:00
return this.Success()
2020-09-16 20:29:18 +08:00
}
2022-09-17 16:07:37 +08:00
// UpdateHTTPHeaderPolicySettingHeaders 修改SetHeaders
func (this *HTTPHeaderPolicyService) UpdateHTTPHeaderPolicySettingHeaders(ctx context.Context, req *pb.UpdateHTTPHeaderPolicySettingHeadersRequest) (*pb.RPCSuccess, error) {
2022-12-29 17:16:21 +08:00
_, userId, err := this.ValidateAdminAndUser(ctx, true)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2022-12-29 17:16:21 +08:00
// 检查权限
if userId > 0 {
err = models.SharedHTTPHeaderPolicyDAO.CheckUserHeaderPolicy(tx, userId, req.HttpHeaderPolicyId)
if err != nil {
return nil, err
}
}
2022-09-17 16:07:37 +08:00
2022-12-29 17:16:21 +08:00
err = models.SharedHTTPHeaderPolicyDAO.UpdateSettingHeaders(tx, req.HttpHeaderPolicyId, req.HeadersJSON)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2020-11-24 17:36:47 +08:00
return this.Success()
2020-09-16 20:29:18 +08:00
}
2022-09-17 16:07:37 +08:00
// UpdateHTTPHeaderPolicyAddingTrailers 修改AddTrailers
func (this *HTTPHeaderPolicyService) UpdateHTTPHeaderPolicyAddingTrailers(ctx context.Context, req *pb.UpdateHTTPHeaderPolicyAddingTrailersRequest) (*pb.RPCSuccess, error) {
2022-12-29 17:16:21 +08:00
_, userId, err := this.ValidateAdminAndUser(ctx, true)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2022-12-29 17:16:21 +08:00
// 检查权限
if userId > 0 {
err = models.SharedHTTPHeaderPolicyDAO.CheckUserHeaderPolicy(tx, userId, req.HttpHeaderPolicyId)
if err != nil {
return nil, err
}
}
2022-09-17 16:07:37 +08:00
2022-12-29 17:16:21 +08:00
err = models.SharedHTTPHeaderPolicyDAO.UpdateAddingTrailers(tx, req.HttpHeaderPolicyId, req.HeadersJSON)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2020-11-24 17:36:47 +08:00
return this.Success()
2020-09-16 20:29:18 +08:00
}
2022-09-17 16:07:37 +08:00
// UpdateHTTPHeaderPolicyReplacingHeaders 修改ReplaceHeaders
func (this *HTTPHeaderPolicyService) UpdateHTTPHeaderPolicyReplacingHeaders(ctx context.Context, req *pb.UpdateHTTPHeaderPolicyReplacingHeadersRequest) (*pb.RPCSuccess, error) {
2022-12-29 17:16:21 +08:00
_, userId, err := this.ValidateAdminAndUser(ctx, true)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2022-12-29 17:16:21 +08:00
// 检查权限
if userId > 0 {
err = models.SharedHTTPHeaderPolicyDAO.CheckUserHeaderPolicy(tx, userId, req.HttpHeaderPolicyId)
if err != nil {
return nil, err
}
}
2022-09-17 16:07:37 +08:00
2022-12-29 17:16:21 +08:00
err = models.SharedHTTPHeaderPolicyDAO.UpdateReplacingHeaders(tx, req.HttpHeaderPolicyId, req.HeadersJSON)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2020-11-24 17:36:47 +08:00
return this.Success()
2020-09-16 20:29:18 +08:00
}
2022-09-17 16:07:37 +08:00
// UpdateHTTPHeaderPolicyDeletingHeaders 修改删除的Headers
func (this *HTTPHeaderPolicyService) UpdateHTTPHeaderPolicyDeletingHeaders(ctx context.Context, req *pb.UpdateHTTPHeaderPolicyDeletingHeadersRequest) (*pb.RPCSuccess, error) {
2022-12-29 17:16:21 +08:00
_, userId, err := this.ValidateAdminAndUser(ctx, true)
if err != nil {
return nil, err
}
var tx = this.NullTx()
// 检查权限
if userId > 0 {
err = models.SharedHTTPHeaderPolicyDAO.CheckUserHeaderPolicy(tx, userId, req.HttpHeaderPolicyId)
if err != nil {
return nil, err
}
}
err = models.SharedHTTPHeaderPolicyDAO.UpdateDeletingHeaders(tx, req.HttpHeaderPolicyId, req.HeaderNames)
if err != nil {
return nil, err
}
return this.Success()
}
// UpdateHTTPHeaderPolicyCORS 修改策略CORS设置
func (this *HTTPHeaderPolicyService) UpdateHTTPHeaderPolicyCORS(ctx context.Context, req *pb.UpdateHTTPHeaderPolicyCORSRequest) (*pb.RPCSuccess, error) {
_, userId, err := this.ValidateAdminAndUser(ctx, true)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2022-12-29 17:16:21 +08:00
// 检查权限
if userId > 0 {
err = models.SharedHTTPHeaderPolicyDAO.CheckUserHeaderPolicy(tx, userId, req.HttpHeaderPolicyId)
if err != nil {
return nil, err
}
}
var corsConfig = shared.NewHTTPCORSHeaderConfig()
2022-12-29 17:16:21 +08:00
err = json.Unmarshal(req.CorsJSON, corsConfig)
if err != nil {
return nil, err
}
err = corsConfig.Init()
if err != nil {
return nil, errors.New("validate CORS config failed: " + err.Error())
}
2022-09-17 16:07:37 +08:00
2022-12-29 17:16:21 +08:00
err = models.SharedHTTPHeaderPolicyDAO.UpdateHeaderPolicyCORS(tx, req.HttpHeaderPolicyId, corsConfig)
2020-09-16 20:29:18 +08:00
if err != nil {
return nil, err
}
2020-11-24 17:36:47 +08:00
return this.Success()
2020-09-16 20:29:18 +08:00
}