123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008 |
- package server
- import (
- "bytes"
- "cfTest/cloudflareApi/zone"
- "context"
- "encoding/json"
- "errors"
- "fmt"
- "github.com/cloudflare/cloudflare-go"
- "github.com/samber/lo"
- "io"
- "io/ioutil"
- "log"
- "net/http"
- "strings"
- "time"
- )
- type ZoneServer struct {
- zone.UnimplementedZoneCloudflareServer
- }
- type Subscription struct {
- ID string `json:"id"`
- RatePlan struct {
- ID string `json:"id"`
- PublicName string `json:"public_name"`
- Currency string `json:"currency"`
- Scope string `json:"scope"`
- ExternallyManaged bool `json:"externally_managed"`
- Sets []string `json:"sets"`
- IsContract bool `json:"is_contract"`
- } `json:"rate_plan"`
- ComponentValues []struct {
- Name string `json:"name"`
- Value int `json:"value"`
- Default int `json:"default,omitempty"`
- } `json:"component_values"`
- Zone struct {
- ID string `json:"id"`
- Name string `json:"name"`
- } `json:"zone"`
- Frequency string `json:"frequency"`
- Currency string `json:"currency"`
- Price int `json:"price"`
- Product struct {
- Name string `json:"name"`
- Period string `json:"period"`
- Billing string `json:"billing"`
- PublicName string `json:"public_name"`
- Duration int `json:"duration"`
- } `json:"product"`
- CancelAtPeriodEnd bool `json:"cancel_at_period_end"`
- CreatedDate time.Time `json:"created_date"`
- }
- var ArgoSubscriptionId = "argo_zone_ent_tryout"
- const TOKEN_PREFIX = "#pt"
- const TOKEN_PREFIX_LENGTH = 3
- var (
- api *cloudflare.API
- err error
- )
- func (s *ZoneServer) GetArgoSettingSubscription(ctx context.Context, request *zone.IdRequest) (*zone.ArgoSetting, error) {
- //设置HTTP请求
- client := &http.Client{}
- req, err := http.NewRequest("GET", "https://api.cloudflare.com/client/v4/zones/"+request.ZoneId+"/subscriptions", nil)
- if err != nil {
- return nil, err
- }
- if strings.HasPrefix(request.GetApiKey(), TOKEN_PREFIX) {
- req.Header.Add("Authorization", ApiToken2Authorization(request.GetApiKey()[TOKEN_PREFIX_LENGTH:]))
- } else {
- req.Header.Add("X-Auth-Key", request.GetApiKey())
- req.Header.Add("X-Auth-Email", request.GetApiEmail())
- }
- //执行HTTP请求
- resp, err := client.Do(req)
- log.Printf("Cloudflare GetArgoSettingSubscription API response: %v err:%s", resp, err)
- if err != nil {
- return nil, err
- }
- defer func(Body io.ReadCloser) {
- _ = Body.Close()
- }(resp.Body)
- body, _ := ioutil.ReadAll(resp.Body)
- type ResponseType struct {
- Errors []interface{} `json:"errors"`
- Messages []interface{} `json:"messages"`
- Result []Subscription `json:"result"`
- ResultInfo struct {
- NextPage bool `json:"next_page"`
- } `json:"result_info"`
- Success bool `json:"success"`
- }
- var r ResponseType
- err = json.Unmarshal(body, &r)
- //处理返回逻辑
- if err != nil {
- return nil, fmt.Errorf("%s: %w", "error unmarshalling the JSON response", err)
- }
- if r.Success != true {
- return nil, fmt.Errorf("%s", r.Errors)
- }
- log.Printf("Response: %v", r)
- for _, v := range r.Result {
- if v.RatePlan.ID == ArgoSubscriptionId {
- return &zone.ArgoSetting{Enabled: true}, nil
- }
- }
- return &zone.ArgoSetting{Enabled: false}, nil
- }
- func (s *ZoneServer) CreateArgoSettingSubscription(ctx context.Context, request *zone.IdRequest) (*zone.ArgoSetting, error) {
- type RequestType struct {
- RatePlan struct {
- ID string `json:"id"`
- } `json:"rate_plan"`
- Zone struct {
- ID string `json:"id"`
- Name string `json:"name"`
- } `json:"zone"`
- }
- type ResponseType struct {
- Errors []interface{} `json:"errors"`
- Messages []interface{} `json:"messages"`
- Result Subscription `json:"result"`
- Success bool `json:"success"`
- }
- bytesData, err := json.Marshal(RequestType{
- RatePlan: struct {
- ID string `json:"id"`
- }{
- ID: ArgoSubscriptionId,
- },
- Zone: struct {
- ID string `json:"id"`
- Name string `json:"name"`
- }{
- ID: request.ZoneId,
- },
- })
- if err != nil {
- return nil, err
- }
- //设置HTTP请求
- client := &http.Client{}
- req, err := http.NewRequest("POST", "https://api.cloudflare.com/client/v4/zones/"+request.ZoneId+"/subscription", bytes.NewReader(bytesData))
- if err != nil {
- return nil, err
- }
- if strings.HasPrefix(request.GetApiKey(), TOKEN_PREFIX) {
- req.Header.Add("Authorization", ApiToken2Authorization(request.GetApiKey()[TOKEN_PREFIX_LENGTH:]))
- } else {
- req.Header.Add("X-Auth-Key", request.GetApiKey())
- req.Header.Add("X-Auth-Email", request.GetApiEmail())
- }
- //执行HTTP请求
- resp, err := client.Do(req)
- log.Printf("Cloudflare CreateArgoSettingSubscription API response: %v err:%s", resp, err)
- if err != nil {
- return nil, err
- }
- defer func(Body io.ReadCloser) {
- _ = Body.Close()
- }(resp.Body)
- body, _ := ioutil.ReadAll(resp.Body)
- var r ResponseType
- err = json.Unmarshal(body, &r)
- //处理返回逻辑
- if err != nil {
- return nil, fmt.Errorf("%s: %w", "error unmarshalling the JSON response", err)
- }
- if r.Success != true {
- return nil, fmt.Errorf("%s", r.Errors)
- }
- log.Printf("Response: %v", r)
- if r.Result.RatePlan.ID == ArgoSubscriptionId {
- return &zone.ArgoSetting{Enabled: true}, nil
- }
- return &zone.ArgoSetting{Enabled: false}, nil
- }
- func (s *ZoneServer) UpdateArgoSetting(ctx context.Context, requestCloudflare *zone.UpdateArgoRequestCloudflare) (*zone.ArgoSetting, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- settingValue := Proto2GoArgoSetting(requestCloudflare.GetArgoSetting())
- setting, err := api.UpdateArgoSmartRouting(ctx, requestCloudflare.ZoneId, settingValue)
- log.Printf("Cloudflare UpdateArgoSmartRouting API response: %v err:%s", setting, err)
- if err != nil {
- return nil, err
- }
- return Go2ProtoArgoSetting(setting.Value), nil
- }
- func (s *ZoneServer) GetArgoSetting(ctx context.Context, requestCloudflare *zone.IdRequest) (*zone.ArgoSetting, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- setting, err := api.ArgoSmartRouting(ctx, requestCloudflare.ZoneId)
- log.Printf("Cloudflare ArgoSmartRouting API response: %v err:%s", setting, err)
- if err != nil {
- return nil, err
- }
- return Go2ProtoArgoSetting(setting.Value), nil
- }
- func (s *ZoneServer) ZoneIDByNameCloudflare(ctx context.Context, requestCloudflare *zone.ZoneIDByNameRequestCloudflare) (*zone.ZoneIDByNameReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- id, err := api.ZoneIDByName(requestCloudflare.ZoneName)
- log.Printf("Cloudflare ZoneIDByName API response: %v err:%s", id, err)
- if err != nil {
- return nil, err
- }
- return &zone.ZoneIDByNameReplyCloudflare{ZoneId: id}, err
- }
- func (s *ZoneServer) ZoneDetails(ctx context.Context, requestCloudflare *zone.ZoneDetailsRequestCloudflare) (*zone.ZoneDetailsReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- details, err := api.ZoneDetails(ctxAPI, requestCloudflare.GetZoneId())
- log.Printf("Cloudflare ZoneDetails API response: %v err:%s", details, err)
- if err != nil {
- return nil, err
- }
- return &zone.ZoneDetailsReplyCloudflare{
- Result: Go2ProtoZone(details),
- }, err
- }
- func (s *ZoneServer) GetZones(ctx context.Context, requestCloudflare *zone.GetZonesRequestCloudflare) (*zone.GetZonesReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- details, err := api.ListZones(ctx, "name", requestCloudflare.GetDomain())
- log.Printf("Cloudflare GetZones API response: %v err:%s", details, err)
- if err != nil {
- return nil, err
- }
- list := make([]*zone.ZoneCloudflareEntity, len(details))
- for i, detail := range details {
- list[i] = Go2ProtoZone(detail)
- }
- return &zone.GetZonesReplyCloudflare{
- Result: list,
- Success: true,
- }, err
- }
- func (s *ZoneServer) ListZones(ctx context.Context, requestCloudflare *zone.ListZonesRequestCloudflare) (*zone.ZonesList, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, fmt.Errorf("failed to initialize Cloudflare API: %w", err)
- }
- ctxAPI := context.Background()
- details, err := api.ListZones(ctxAPI)
- log.Printf("Cloudflare ListZones API response: %v err:%s", details, err)
- if err != nil {
- return nil, err
- }
- list := make([]*zone.ZoneCloudflareEntity, len(details))
- for i, detail := range details {
- list[i] = Go2ProtoZone(detail)
- }
- return &zone.ZonesList{
- Result: list,
- }, err
- }
- func (s *ZoneServer) ListZonesByAccountId(ctx context.Context, requestCloudflare *zone.ListZonesByAccountIdRequestCloudflare) (*zone.ZonesList, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- opt := cloudflare.WithZoneFilters("", requestCloudflare.AccountId, "")
- details, err := api.ListZonesContext(ctxAPI, opt)
- log.Printf("Cloudflare ListZonesByAccountId API response: %v err:%s", details, err)
- if err != nil {
- return nil, err
- }
- list := make([]*zone.ZoneCloudflareEntity, len(details.Result))
- for i, detail := range details.Result {
- list[i] = Go2ProtoZone(detail)
- }
- return &zone.ZonesList{
- Result: list,
- }, err
- }
- func (s *ZoneServer) EditZone(ctx context.Context, requestCloudflare *zone.EditZoneRequestCloudflare) (*zone.EditZoneReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- opts := cloudflare.ZoneOptions{}
- opts.Paused = requestCloudflare.Paused
- if requestCloudflare.PlanId != nil {
- opts.Plan = &cloudflare.ZonePlan{
- ZonePlanCommon: cloudflare.ZonePlanCommon{
- ID: requestCloudflare.GetPlanId(),
- },
- }
- }
- if requestCloudflare.Type != nil {
- opts.Type = requestCloudflare.GetType()
- }
- editZone, err := api.EditZone(ctxAPI, requestCloudflare.GetZoneId(), opts)
- log.Printf("Cloudflare EditZone API response: %v err:%s", editZone, err)
- if err != nil {
- return nil, err
- }
- return &zone.EditZoneReplyCloudflare{
- Result: Go2ProtoZone(editZone),
- Success: true,
- }, nil
- }
- func (s *ZoneServer) DeleteZone(ctx context.Context, requestCloudflare *zone.DeleteZoneRequestCloudflare) (*zone.DeleteZoneReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- deleteZone, err := api.DeleteZone(ctxAPI, requestCloudflare.GetZoneId())
- log.Printf("Cloudflare DeleteZone API response: %v err:%s", deleteZone, err)
- if err != nil {
- return nil, err
- }
- return &zone.DeleteZoneReplyCloudflare{
- Success: true,
- Id: deleteZone.ID,
- }, nil
- }
- func (s *ZoneServer) CreateZone(ctx context.Context, requestCloudflare *zone.CreateZoneRequestCloudflare) (*zone.CreateZoneReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- account, _, err := api.Account(ctxAPI, requestCloudflare.GetAccountId())
- log.Printf("Cloudflare Account API response: %v err:%s", account, err)
- if err != nil {
- return nil, err
- }
- createZone, err := api.CreateZone(ctxAPI, requestCloudflare.GetDomain(), false, account, "full")
- log.Printf("Cloudflare CreateZone API response: %v err:%s", createZone, err)
- if err != nil {
- return nil, err
- }
- return &zone.CreateZoneReplyCloudflare{
- Success: true,
- Id: createZone.ID,
- }, nil
- }
- func (s *ZoneServer) SetZonePlan(ctx context.Context, requestCloudflare *zone.SetZonePlanRequestCloudflare) (*zone.SetZonePlanReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- err = api.ZoneSetPlan(ctxAPI, requestCloudflare.GetZoneId(), requestCloudflare.GetZonePlan())
- log.Printf("Cloudflare SetZonePlan API err:%s", err)
- if err != nil {
- return nil, err
- }
- return &zone.SetZonePlanReplyCloudflare{
- Success: true,
- }, nil
- }
- func (s *ZoneServer) ActivationCheck(ctx context.Context, requestCloudflare *zone.ActivationCheckRequestCloudflare) (*zone.ActivationCheckReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- activationCheck, err := api.ZoneActivationCheck(ctxAPI, requestCloudflare.GetZoneId())
- log.Printf("Cloudflare ZoneActivationCheck API response: %v err:%s", activationCheck, err)
- if err != nil {
- return nil, err
- }
- return &zone.ActivationCheckReplyCloudflare{
- Success: activationCheck.Success,
- }, nil
- }
- var phaseMap = map[zone.Phase]string{
- zone.Phase_http_request_sanitize: "http_request_sanitize",
- zone.Phase_http_request_transform: "http_request_transform",
- zone.Phase_http_request_origin: "http_request_origin",
- zone.Phase_http_request_cache_settings: "http_request_cache_settings",
- zone.Phase_http_config_settings: "http_config_settings",
- //zone.Phase_http_request_dynamic_redirect: "http_request_dynamic_redirect",
- //zone.Phase_ddos_l7: "ddos_l7",
- //zone.Phase_http_request_firewall_custom: "http_request_firewall_custom",
- //zone.Phase_http_ratelimit: "http_ratelimit",
- //zone.Phase_http_request_firewall_managed: "http_request_firewall_managed",
- //zone.Phase_http_request_sbfm: "http_request_sbfm",
- //zone.Phase_http_request_redirect: "http_request_redirect",
- zone.Phase_http_request_late_transform: "http_request_late_transform",
- //zone.Phase_http_custom_errors: "http_custom_errors",
- zone.Phase_http_response_headers_transform: "http_response_headers_transform",
- //zone.Phase_http_response_firewall_managed: "http_response_firewall_managed",
- //zone.Phase_http_log_custom_fields: "http_log_custom_fields",
- }
- func (s *ZoneServer) ListZoneRuleSets(ctx context.Context, requestCloudflare *zone.ListZoneRuleSetsRequestCloudflare) (*zone.RuleSetList, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- zoneIdentifier := cloudflare.ZoneIdentifier(requestCloudflare.GetZoneId())
- ListRulesetsParams := cloudflare.ListRulesetsParams{}
- goRuleSets, err := api.ListRulesets(ctxAPI, zoneIdentifier, ListRulesetsParams)
- log.Printf("Cloudflare ListZoneRuleSets API response: %v err:%s", goRuleSets, err)
- if err != nil {
- return nil, err
- }
- filterMap := lo.FilterMap[cloudflare.Ruleset, *zone.RuleSet](goRuleSets, func(goRuleSet cloudflare.Ruleset, _ int) (*zone.RuleSet, bool) {
- protoRuleSet := Go2ProtoRuleSet(&goRuleSet)
- return protoRuleSet, true
- })
- return &zone.RuleSetList{RuleSets: filterMap}, nil
- }
- func (s *ZoneServer) CreateZoneRuleSet(ctx context.Context, requestCloudflare *zone.CreateZoneRuleSetRequestCloudflare) (*zone.CreateZoneRuleSetReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- filterMap := lo.FilterMap[*zone.Rule, cloudflare.RulesetRule](requestCloudflare.Rules, func(rule *zone.Rule, index int) (cloudflare.RulesetRule, bool) {
- ruleResult, err := Proto2GoRulesetRuleByPhase(rule, requestCloudflare.RuleSet.Phase)
- if err != nil || ruleResult == nil {
- return cloudflare.RulesetRule{}, false
- }
- return *ruleResult, true
- })
- zoneIdentifier := cloudflare.ZoneIdentifier(requestCloudflare.GetZoneId())
- createRulesetParams := cloudflare.CreateRulesetParams{
- Name: requestCloudflare.RuleSet.Name,
- Kind: requestCloudflare.RuleSet.Kind,
- Phase: phaseMap[requestCloudflare.RuleSet.Phase],
- Rules: filterMap,
- }
- _, err = api.CreateRuleset(ctxAPI, zoneIdentifier, createRulesetParams)
- log.Printf("Cloudflare CreateRuleset API err:%s", err)
- if err != nil {
- return &zone.CreateZoneRuleSetReplyCloudflare{Success: false}, err
- }
- //protoRuleSet := Go2ProtoRuleSet(&goRuleSet)
- return &zone.CreateZoneRuleSetReplyCloudflare{Success: true}, nil
- }
- func (s *ZoneServer) DeleteZoneRuleSet(ctx context.Context, requestCloudflare *zone.DeleteZoneRuleSetRequestCloudflare) (*zone.DeleteZoneRuleSetReplyCloudflare, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- zoneIdentifier := cloudflare.ZoneIdentifier(requestCloudflare.GetZoneId())
- err = api.DeleteRuleset(ctxAPI, zoneIdentifier, requestCloudflare.GetRuleSetId())
- log.Printf("Cloudflare DeleteRuleset API err:%s", err)
- if err != nil {
- return &zone.DeleteZoneRuleSetReplyCloudflare{Success: false}, err
- }
- return &zone.DeleteZoneRuleSetReplyCloudflare{Success: true}, nil
- }
- func (s *ZoneServer) UpdateRuleSetByRuleSetId(ctx context.Context, requestCloudflare *zone.UpdateRuleSetByRuleSetIdRequestCloudflare) (*zone.RuleSet, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- filterMap := lo.FilterMap[*zone.Rule, cloudflare.RulesetRule](requestCloudflare.Rules, func(rule *zone.Rule, index int) (cloudflare.RulesetRule, bool) {
- ruleResult, err := Proto2GoRulesetRuleByPhase(rule, requestCloudflare.Phase)
- if err != nil || ruleResult == nil {
- return cloudflare.RulesetRule{}, false
- }
- return *ruleResult, true
- })
- zoneIdentifier := cloudflare.ZoneIdentifier(requestCloudflare.GetZoneId())
- updateRulesetParams := cloudflare.UpdateRulesetParams{
- ID: requestCloudflare.RuleSetId,
- Rules: filterMap,
- }
- goRuleSet, err := api.UpdateRuleset(ctxAPI, zoneIdentifier, updateRulesetParams)
- log.Printf("Cloudflare UpdateRuleset API response: %v err:%s", goRuleSet, err)
- if err != nil {
- return nil, err
- }
- protoRuleSet := Go2ProtoRuleSet(&goRuleSet)
- return protoRuleSet, nil
- }
- func (s *ZoneServer) GetRuleSet(ctx context.Context, requestCloudflare *zone.GetRuleSetRequestCloudflare) (*zone.RuleList, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- switch phaseMap[requestCloudflare.Phase] {
- case "http_request_origin", "http_request_cache_settings", "http_config_settings":
- case "http_request_transform", "http_request_late_transform", "http_response_headers_transform":
- default:
- return nil, errors.New("未定义规则阶段")
- }
- zoneIdentifier := cloudflare.ZoneIdentifier(requestCloudflare.GetZoneId())
- ruleset, err := api.GetEntrypointRuleset(ctxAPI, zoneIdentifier, phaseMap[requestCloudflare.Phase])
- log.Printf("Cloudflare GetEntrypointRuleset API response: %v err:%s", ruleset, err)
- if err != nil {
- _, ok := err.(*cloudflare.NotFoundError)
- if ok {
- ruleset.Rules = make([]cloudflare.RulesetRule, 0)
- err = nil
- } else {
- return nil, err
- }
- }
- filterMap := lo.FilterMap[cloudflare.RulesetRule, *zone.Rule](ruleset.Rules, func(rule cloudflare.RulesetRule, _ int) (*zone.Rule, bool) {
- phase, err := Go2ProtoRuleRuleByPhase(&rule, ruleset.Phase)
- if err != nil {
- return nil, false
- }
- return phase, true
- })
- return &zone.RuleList{Rules: filterMap}, nil
- }
- func (s *ZoneServer) UpdateRuleSet(ctx context.Context, requestCloudflare *zone.UpdateRuleSetRequestCloudflare) (*zone.RuleList, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- phase := phaseMap[requestCloudflare.Phase]
- filterMap := lo.FilterMap[*zone.Rule, cloudflare.RulesetRule](requestCloudflare.Rules, func(rule *zone.Rule, index int) (cloudflare.RulesetRule, bool) {
- ruleResult, err := Proto2GoRulesetRuleByPhase(rule, requestCloudflare.Phase)
- if err != nil || ruleResult == nil {
- return cloudflare.RulesetRule{}, false
- }
- return *ruleResult, true
- })
- //for _, rule := range requestCloudflare.Rules {
- // ruleResult, err := Proto2GoRulesetRuleByPhase(rule, requestCloudflare.Phase)
- // if err != nil {
- // return nil, err
- // }
- // if ruleResult != nil {
- // ruleSet.Rules = append(ruleSet.Rules, *ruleResult)
- // }
- //}
- zoneIdentifier := cloudflare.ZoneIdentifier(requestCloudflare.GetZoneId())
- updateEntrypointRulesetParams := cloudflare.UpdateEntrypointRulesetParams{
- Phase: phase,
- Rules: filterMap,
- }
- ruleset, err := api.UpdateEntrypointRuleset(ctxAPI, zoneIdentifier, updateEntrypointRulesetParams)
- log.Printf("Cloudflare UpdateEntrypointRuleset API response: %v err:%s", ruleset, err)
- if err != nil {
- return nil, err
- }
- rulesReturn := lo.FilterMap[cloudflare.RulesetRule, *zone.Rule](ruleset.Rules, func(rule cloudflare.RulesetRule, _ int) (*zone.Rule, bool) {
- ruleReturn, err := Go2ProtoRuleRuleByPhase(&rule, ruleset.Phase)
- if err != nil {
- return nil, false
- }
- return ruleReturn, true
- })
- //var rulesReturn []*zone.Rule
- //for _, rule := range rulesetResult.Rules {
- // ruleReturn, err := Go2ProtoRuleRuleByPhase(&rule, rulesetResult.Phase)
- // if err != nil {
- // return nil, err
- // }
- // if ruleReturn != nil {
- // rulesReturn = append(rulesReturn, ruleReturn)
- // }
- //}
- return &zone.RuleList{Rules: rulesReturn}, nil
- }
- //func UpdateRuleSet(apiKey, apiEmail, zoneID, rulesetPhase string, ruleset cloudflare.Ruleset) (*cloudflare.Ruleset, error) {
- // api, err := cloudflare.New(apiKey, apiEmail)
- // if err != nil {
- // return nil, err
- // }
- // ctxAPI := context.Background()
- // phase, err := api.UpdateZoneRulesetPhase(ctxAPI, zoneID, rulesetPhase, ruleset)
- // if err != nil {
- // return nil, err
- // }
- // return &phase, nil
- //}
- //PageRule CURD
- func (s *ZoneServer) ListPageRule(ctx context.Context, requestCloudflare *zone.ListPageRuleRequestCloudflare) (*zone.PageRuleList, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- rules, err := api.ListPageRules(ctxAPI, requestCloudflare.GetZoneId())
- log.Printf("Cloudflare ListPageRules API response: %v err:%s", rules, err)
- if err != nil {
- return nil, err
- }
- filterMap := lo.FilterMap[cloudflare.PageRule, *zone.PageRule](rules, func(rule cloudflare.PageRule, _ int) (*zone.PageRule, bool) {
- pageRule := Go2ProtoPageRule(&rule)
- return pageRule, true
- })
- return &zone.PageRuleList{PageRules: filterMap}, nil
- }
- func (s *ZoneServer) CreatePageRule(ctx context.Context, requestCloudflare *zone.CreatePageRuleRequestCloudflare) (*zone.PageRule, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- rule, err := Proto2GoPageRule(requestCloudflare.PageRule)
- if err != nil {
- return nil, err
- }
- pageRule, err := api.CreatePageRule(ctxAPI, requestCloudflare.GetZoneId(), *rule)
- log.Printf("Cloudflare CreatePageRule API response: %v err:%s", pageRule, err)
- if err != nil {
- return nil, err
- }
- return Go2ProtoPageRule(pageRule), nil
- }
- func (s *ZoneServer) UpdatePageRule(ctx context.Context, requestCloudflare *zone.UpdatePageRuleRequestCloudflare) (*zone.PageRule, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- rule, err := Proto2GoPageRule(requestCloudflare.PageRule)
- if err != nil {
- return nil, err
- }
- err = api.UpdatePageRule(ctxAPI, requestCloudflare.GetZoneId(), rule.ID, *rule)
- log.Printf("Cloudflare UpdatePageRule API err:%s", err)
- if err != nil {
- return nil, err
- }
- return requestCloudflare.PageRule, nil
- }
- func (s *ZoneServer) DeletePageRule(ctx context.Context, requestCloudflare *zone.DeletePageRuleRequestCloudflare) (*zone.PageRule, error) {
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- api, err = cloudflare.NewWithAPIToken(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:])
- } else {
- api, err = cloudflare.New(requestCloudflare.GetApiKey(), requestCloudflare.GetApiEmail())
- }
- if err != nil {
- return nil, err
- }
- ctxAPI := context.Background()
- err = api.DeletePageRule(ctxAPI, requestCloudflare.ZoneId, requestCloudflare.PageRuleId)
- log.Printf("Cloudflare DeletePageRule API err:%s", err)
- if err != nil {
- return nil, err
- }
- return &zone.PageRule{}, nil
- }
- //func UpdatePageRule(apiKey, apiEmail, zoneID string, rule *zone.PageRule) (*zone.PageRule, error) {
- // api, err := cloudflare.New(apiKey, apiEmail)
- // if err != nil {
- // return nil, err
- // }
- //
- // ctxAPI := context.Background()
- // goPageRule, err := Proto2GoPageRule(rule)
- // if err != nil {
- // return nil, err
- // }
- // pageRule, err := api.CreatePageRule(ctxAPI, zoneID, *goPageRule)
- // if err != nil {
- // return nil, err
- // }
- //
- // protoPageRule := Go2ProtoPageRule(pageRule)
- //
- // return protoPageRule, nil
- //}
- type PageRuleActionCacheKeyFieldsQueryString struct {
- Exclude interface{} `json:"exclude"`
- Include interface{} `json:"include"`
- }
- type PageRuleActionCacheKeyFields struct {
- QueryString PageRuleActionCacheKeyFieldsQueryString `json:"query_string"`
- }
- type UpdatePageRulesPrioritiesStruct struct {
- Id string `json:"id"`
- Priority int `json:"priority"`
- }
- func (s *ZoneServer) UpdatePageRulesPriorities(ctx context.Context, requestCloudflare *zone.UpdatePageRulesPrioritiesRequestCloudflare) (*zone.PageRuleList, error) {
- //TODO 参数检查
- //设置HTTP请求
- client := &http.Client{}
- bytesData, err := json.Marshal(requestCloudflare.Data)
- if err != nil {
- return nil, err
- }
- req, err := http.NewRequest("PUT", "https://api.cloudflare.com/client/v4/zones/"+requestCloudflare.ZoneId+"/pagerules/priorities", bytes.NewReader(bytesData))
- if err != nil {
- return nil, err
- }
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- req.Header.Add("Authorization", ApiToken2Authorization(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:]))
- } else {
- req.Header.Add("X-Auth-Key", requestCloudflare.GetApiKey())
- req.Header.Add("X-Auth-Email", requestCloudflare.GetApiEmail())
- }
- //执行HTTP请求
- resp, err := client.Do(req)
- log.Printf("Cloudflare UpdatePageRulesPriorities API response: %v err:%s", resp, err)
- if err != nil {
- return nil, err
- }
- defer func(Body io.ReadCloser) {
- _ = Body.Close()
- }(resp.Body)
- body, _ := ioutil.ReadAll(resp.Body)
- //解析HTTP返回数据
- var r cloudflare.PageRulesResponse
- err = json.Unmarshal(body, &r)
- //处理返回逻辑
- if err != nil {
- return nil, fmt.Errorf("%s: %w", "error unmarshalling the JSON response", err)
- }
- if r.Success != true {
- return nil, fmt.Errorf("%s", r.Errors)
- }
- rules := r.Result
- filterMap := lo.FilterMap[cloudflare.PageRule, *zone.PageRule](rules, func(rule cloudflare.PageRule, _ int) (*zone.PageRule, bool) {
- pageRule := Go2ProtoPageRule(&rule)
- return pageRule, true
- })
- return &zone.PageRuleList{PageRules: filterMap}, nil
- }
- // 默认开启Smarttiered cache
- func (s *ZoneServer) SetSmartTieredCache(ctx context.Context, requestCloudflare *zone.SetSmartTieredCacheRequestCloudflare) (*zone.SetSmartTieredCacheReplyCloudflare, error) {
- type ResponseType struct {
- Errors []interface{} `json:"errors"`
- Messages []interface{} `json:"messages"`
- Result interface{} `json:"result"`
- Success bool `json:"success"`
- }
- //设置HTTP请求
- client := &http.Client{}
- url := "https://api.cloudflare.com/client/v4/zones/" + requestCloudflare.ZoneId + "/cache/tiered_cache_smart_topology_enable"
- payload := strings.NewReader("{\n \"value\": \"on\"\n}")
- req, err := http.NewRequest("PATCH", url, payload)
- if err != nil {
- return nil, err
- }
- req.Header.Add("Content-Type", "application/json")
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- req.Header.Add("Authorization", ApiToken2Authorization(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:]))
- } else {
- req.Header.Add("X-Auth-Key", requestCloudflare.GetApiKey())
- req.Header.Add("X-Auth-Email", requestCloudflare.GetApiEmail())
- }
- //执行HTTP请求
- resp, err := client.Do(req)
- log.Printf("Cloudflare SetSmartTieredCache API response: %v err:%s", resp, err)
- if err != nil {
- return nil, err
- }
- defer func(Body io.ReadCloser) {
- _ = Body.Close()
- }(resp.Body)
- body, _ := ioutil.ReadAll(resp.Body)
- print(body)
- //解析HTTP返回数据
- var r ResponseType
- err = json.Unmarshal(body, &r)
- if err != nil {
- return nil, fmt.Errorf("%s: %w", "error unmarshalling the JSON response", err)
- }
- if r.Success != true {
- print(fmt.Errorf("%s", r.Errors))
- }
- return &zone.SetSmartTieredCacheReplyCloudflare{Enabled: r.Success}, nil
- }
- // 开启强制使用https
- func (s *ZoneServer) UpdateAlwaysUseHttps(ctx context.Context, requestCloudflare *zone.UpdateAlwaysUseHttpsRequestCloudflare) (*zone.UpdateAlwaysUseHttpsReplyCloudflare, error) {
- type ResponseType struct {
- Errors []interface{} `json:"errors"`
- Messages []interface{} `json:"messages"`
- Result interface{} `json:"result"`
- Success bool `json:"success"`
- }
- //设置HTTP请求
- client := &http.Client{}
- url := "https://api.cloudflare.com/client/v4/zones/" + requestCloudflare.ZoneId + "/settings/always_use_https"
- var payload io.Reader
- if requestCloudflare.Enabled {
- payload = strings.NewReader("{\n \"value\": \"on\"\n}")
- } else {
- payload = strings.NewReader("{\n \"value\": \"off\"\n}")
- }
- req, err := http.NewRequest("PATCH", url, payload)
- if err != nil {
- return nil, err
- }
- req.Header.Add("Content-Type", "application/json")
- if strings.HasPrefix(requestCloudflare.GetApiKey(), TOKEN_PREFIX) {
- req.Header.Add("Authorization", ApiToken2Authorization(requestCloudflare.GetApiKey()[TOKEN_PREFIX_LENGTH:]))
- } else {
- req.Header.Add("X-Auth-Key", requestCloudflare.GetApiKey())
- req.Header.Add("X-Auth-Email", requestCloudflare.GetApiEmail())
- }
- //执行HTTP请求
- resp, err := client.Do(req)
- log.Printf("Cloudflare UpdateAlwaysUseHttps API response: %v err:%s", resp, err)
- if err != nil {
- return nil, err
- }
- defer func(Body io.ReadCloser) {
- _ = Body.Close()
- }(resp.Body)
- body, _ := ioutil.ReadAll(resp.Body)
- print(body)
- //解析HTTP返回数据
- var r ResponseType
- err = json.Unmarshal(body, &r)
- if err != nil {
- return nil, fmt.Errorf("%s: %w", "error unmarshalling the JSON response", err)
- }
- if r.Success != true {
- print(fmt.Errorf("%s", r.Errors))
- }
- return &zone.UpdateAlwaysUseHttpsReplyCloudflare{Success: r.Success}, nil
- }
|