# frozen_string_literal: true
# Copyright (c) 2017-2018 THL A29 Limited, a Tencent company. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
module TencentCloud
module Teo
module V20220901
# 中国大陆加速优化配置。
class AccelerateMainland < TencentCloud::Common::AbstractModel
# @param Switch: 是否开启中国大陆加速优化配置,取值有:
#
on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 加速类型
class AccelerateType < TencentCloud::Common::AbstractModel
# @param Switch: 加速开关。取值范围:
# on:打开;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 加速域名
class AccelerationDomain < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param DomainName: 加速域名名称。
# @type DomainName: String
# @param DomainStatus: 加速域名状态,取值有:
# online:已生效;
# process:部署中;
# offline:已停用;
# forbidden:已封禁;
# init:未生效,待激活站点;
# @type DomainStatus: String
# @param OriginDetail: 源站信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OriginDetail: :class:`Tencentcloud::Teo.v20220901.models.OriginDetail`
# @param OriginProtocol: 回源协议,取值有:
# FOLLOW: 协议跟随;
# HTTP: HTTP协议回源;
# HTTPS: HTTPS协议回源。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OriginProtocol: String
# @param Certificate: 域名证书信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Certificate: :class:`Tencentcloud::Teo.v20220901.models.AccelerationDomainCertificate`
# @param HttpOriginPort: HTTP回源端口。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type HttpOriginPort: Integer
# @param HttpsOriginPort: HTTPS回源端口。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type HttpsOriginPort: Integer
# @param IPv6Status: IPv6状态,取值有:
# follow:遵循站点IPv6配置;
# on:开启状态;
# off:关闭状态。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IPv6Status: String
# @param Cname: CNAME 地址。
# @type Cname: String
# @param IdentificationStatus: 加速域名归属权验证状态,取值有: pending:待验证; finished:已完成验证。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IdentificationStatus: String
# @param CreatedOn: 创建时间。
# @type CreatedOn: String
# @param ModifiedOn: 修改时间。
# @type ModifiedOn: String
# @param OwnershipVerification: 当域名需要进行归属权验证才能继续提供服务时,该对象会携带对应验证方式所需要的信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OwnershipVerification: :class:`Tencentcloud::Teo.v20220901.models.OwnershipVerification`
attr_accessor :ZoneId, :DomainName, :DomainStatus, :OriginDetail, :OriginProtocol, :Certificate, :HttpOriginPort, :HttpsOriginPort, :IPv6Status, :Cname, :IdentificationStatus, :CreatedOn, :ModifiedOn, :OwnershipVerification
def initialize(zoneid=nil, domainname=nil, domainstatus=nil, origindetail=nil, originprotocol=nil, certificate=nil, httporiginport=nil, httpsoriginport=nil, ipv6status=nil, cname=nil, identificationstatus=nil, createdon=nil, modifiedon=nil, ownershipverification=nil)
@ZoneId = zoneid
@DomainName = domainname
@DomainStatus = domainstatus
@OriginDetail = origindetail
@OriginProtocol = originprotocol
@Certificate = certificate
@HttpOriginPort = httporiginport
@HttpsOriginPort = httpsoriginport
@IPv6Status = ipv6status
@Cname = cname
@IdentificationStatus = identificationstatus
@CreatedOn = createdon
@ModifiedOn = modifiedon
@OwnershipVerification = ownershipverification
end
def deserialize(params)
@ZoneId = params['ZoneId']
@DomainName = params['DomainName']
@DomainStatus = params['DomainStatus']
unless params['OriginDetail'].nil?
@OriginDetail = OriginDetail.new
@OriginDetail.deserialize(params['OriginDetail'])
end
@OriginProtocol = params['OriginProtocol']
unless params['Certificate'].nil?
@Certificate = AccelerationDomainCertificate.new
@Certificate.deserialize(params['Certificate'])
end
@HttpOriginPort = params['HttpOriginPort']
@HttpsOriginPort = params['HttpsOriginPort']
@IPv6Status = params['IPv6Status']
@Cname = params['Cname']
@IdentificationStatus = params['IdentificationStatus']
@CreatedOn = params['CreatedOn']
@ModifiedOn = params['ModifiedOn']
unless params['OwnershipVerification'].nil?
@OwnershipVerification = OwnershipVerification.new
@OwnershipVerification.deserialize(params['OwnershipVerification'])
end
end
end
# 加速域名所对应的证书信息。
class AccelerationDomainCertificate < TencentCloud::Common::AbstractModel
# @param Mode: 配置证书的模式,取值有: disable:不配置证书; eofreecert:配置 EdgeOne 免费证书; sslcert:配置 SSL 证书。
# @type Mode: String
# @param List: 服务端证书列表,相关证书部署在 EO 的入口侧。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type List: Array
# @param ClientCertInfo: 在边缘双向认证场景下,该字段为客户端的 CA 证书,部署在 EO 节点内,用于 EO 节点认证客户端证书。
# @type ClientCertInfo: :class:`Tencentcloud::Teo.v20220901.models.MutualTLS`
# @param UpstreamCertInfo: 用于 EO 节点回源时携带的证书,源站启用双向认证握手时使用,用于源站认证客户端证书是否有效,确保请求来源于受信任的 EO 节点。
# @type UpstreamCertInfo: :class:`Tencentcloud::Teo.v20220901.models.UpstreamCertInfo`
attr_accessor :Mode, :List, :ClientCertInfo, :UpstreamCertInfo
def initialize(mode=nil, list=nil, clientcertinfo=nil, upstreamcertinfo=nil)
@Mode = mode
@List = list
@ClientCertInfo = clientcertinfo
@UpstreamCertInfo = upstreamcertinfo
end
def deserialize(params)
@Mode = params['Mode']
unless params['List'].nil?
@List = []
params['List'].each do |i|
certificateinfo_tmp = CertificateInfo.new
certificateinfo_tmp.deserialize(i)
@List << certificateinfo_tmp
end
end
unless params['ClientCertInfo'].nil?
@ClientCertInfo = MutualTLS.new
@ClientCertInfo.deserialize(params['ClientCertInfo'])
end
unless params['UpstreamCertInfo'].nil?
@UpstreamCertInfo = UpstreamCertInfo.new
@UpstreamCertInfo.deserialize(params['UpstreamCertInfo'])
end
end
end
# 精准防护条件
class AclCondition < TencentCloud::Common::AbstractModel
# @param MatchFrom: 匹配字段,取值有:
# host:请求域名;
# sip:客户端IP;
# ua:User-Agent;
# cookie:会话 Cookie;
# cgi:CGI 脚本;
# xff:XFF 扩展头部;
# url:请求 URL;
# accept:请求内容类型;
# method:请求方式;
# header:请求头部;
# app_proto:应用层协议;
# sip_proto:网络层协议;
# uabot:UA 特征规则,仅bot自定义规则可用;
# idcid:IDC 规则,仅bot自定义规则可用;
# sipbot:搜索引擎规则,仅bot自定义规则可用;
# portrait:画像分析,仅bot自定义规则可用;
# header_seq:请求头顺序,仅bot自定义规则可用;
# hdr:请求正文,仅Web防护自定义规则可用。
# @type MatchFrom: String
# @param MatchParam: 匹配字符串。当 MatchFrom 为 header 时,可以填入 header 的 key 作为参数。
# @type MatchParam: String
# @param Operator: 匹配关系,取值有:
# equal:字符串等于;
# not_equal:数值不等于;
# include:字符包含;
# not_include:字符不包含;
# match:ip匹配;
# not_match:ip不匹配;
# include_area:地域包含;
# is_empty:存在字段但值为空;
# not_exists:不存在关键字段;
# regexp:正则匹配;
# len_gt:数值大于;
# len_lt:数值小于;
# len_eq:数值等于;
# match_prefix:前缀匹配;
# match_suffix:后缀匹配;
# wildcard:通配符。
# @type Operator: String
# @param MatchContent: 匹配内容。
# @type MatchContent: String
attr_accessor :MatchFrom, :MatchParam, :Operator, :MatchContent
def initialize(matchfrom=nil, matchparam=nil, operator=nil, matchcontent=nil)
@MatchFrom = matchfrom
@MatchParam = matchparam
@Operator = operator
@MatchContent = matchcontent
end
def deserialize(params)
@MatchFrom = params['MatchFrom']
@MatchParam = params['MatchParam']
@Operator = params['Operator']
@MatchContent = params['MatchContent']
end
end
# ACL配置
class AclConfig < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param AclUserRules: 用户自定义规则。
# @type AclUserRules: Array
# @param Customizes: 托管定制规则
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Customizes: Array
attr_accessor :Switch, :AclUserRules, :Customizes
def initialize(switch=nil, acluserrules=nil, customizes=nil)
@Switch = switch
@AclUserRules = acluserrules
@Customizes = customizes
end
def deserialize(params)
@Switch = params['Switch']
unless params['AclUserRules'].nil?
@AclUserRules = []
params['AclUserRules'].each do |i|
acluserrule_tmp = AclUserRule.new
acluserrule_tmp.deserialize(i)
@AclUserRules << acluserrule_tmp
end
end
unless params['Customizes'].nil?
@Customizes = []
params['Customizes'].each do |i|
acluserrule_tmp = AclUserRule.new
acluserrule_tmp.deserialize(i)
@Customizes << acluserrule_tmp
end
end
end
end
# 用户自定义规则
class AclUserRule < TencentCloud::Common::AbstractModel
# @param RuleName: 规则名。
# @type RuleName: String
# @param Action: 处罚动作,取值有:
# trans:放行;
# drop:拦截;
# monitor:观察;
# ban:IP 封禁;
# redirect:重定向;
# page:指定页面;
# alg:JavaScript 挑战。
# @type Action: String
# @param RuleStatus: 规则状态,取值有:
# on:生效;
# off:失效。
# @type RuleStatus: String
# @param AclConditions: 自定义规则。
# @type AclConditions: Array
# @param RulePriority: 规则优先级,取值范围0-100。
# @type RulePriority: Integer
# @param RuleID: 规则 Id。仅出参使用。
# @type RuleID: Integer
# @param UpdateTime: 更新时间。仅出参使用。
# @type UpdateTime: String
# @param PunishTime: ip 封禁的惩罚时间。Action 是 ban 时必填,且不能为空,取值范围0-2天。
# @type PunishTime: Integer
# @param PunishTimeUnit: ip 封禁的惩罚时间单位,取值有:
# second:秒;
# minutes:分;
# hour:小时。默认为 second。
# @type PunishTimeUnit: String
# @param Name: 自定义返回页面的名称。Action 是 page 时必填,且不能为空。
# @type Name: String
# @param PageId: 自定义返回页面的实例 Id。默认为0,代表使用系统默认拦截页面。该参数已废弃。
# @type PageId: Integer
# @param CustomResponseId: 自定义响应 Id。该 Id 可通过查询自定义错误页列表接口获取。默认值为default,使用系统默认页面。Action 是 page 时必填,且不能为空。
# @type CustomResponseId: String
# @param ResponseCode: 自定义返回页面的响应码。Action 是 page 时必填,且不能为空,取值: 100~600,不支持 3xx 响应码。默认值:567。
# @type ResponseCode: Integer
# @param RedirectUrl: 重定向时候的地址。Action 是 redirect 时必填,且不能为空。
# @type RedirectUrl: String
attr_accessor :RuleName, :Action, :RuleStatus, :AclConditions, :RulePriority, :RuleID, :UpdateTime, :PunishTime, :PunishTimeUnit, :Name, :PageId, :CustomResponseId, :ResponseCode, :RedirectUrl
def initialize(rulename=nil, action=nil, rulestatus=nil, aclconditions=nil, rulepriority=nil, ruleid=nil, updatetime=nil, punishtime=nil, punishtimeunit=nil, name=nil, pageid=nil, customresponseid=nil, responsecode=nil, redirecturl=nil)
@RuleName = rulename
@Action = action
@RuleStatus = rulestatus
@AclConditions = aclconditions
@RulePriority = rulepriority
@RuleID = ruleid
@UpdateTime = updatetime
@PunishTime = punishtime
@PunishTimeUnit = punishtimeunit
@Name = name
@PageId = pageid
@CustomResponseId = customresponseid
@ResponseCode = responsecode
@RedirectUrl = redirecturl
end
def deserialize(params)
@RuleName = params['RuleName']
@Action = params['Action']
@RuleStatus = params['RuleStatus']
unless params['AclConditions'].nil?
@AclConditions = []
params['AclConditions'].each do |i|
aclcondition_tmp = AclCondition.new
aclcondition_tmp.deserialize(i)
@AclConditions << aclcondition_tmp
end
end
@RulePriority = params['RulePriority']
@RuleID = params['RuleID']
@UpdateTime = params['UpdateTime']
@PunishTime = params['PunishTime']
@PunishTimeUnit = params['PunishTimeUnit']
@Name = params['Name']
@PageId = params['PageId']
@CustomResponseId = params['CustomResponseId']
@ResponseCode = params['ResponseCode']
@RedirectUrl = params['RedirectUrl']
end
end
# 规则引擎功能项操作,对于一种功能只对应下面三种类型的其中一种,RuleAction 数组中的每一项只能是其中一个类型,更多功能项的填写规范可调用接口 [查询规则引擎的设置参数](https://cloud.tencent.com/document/product/1552/80618) 查看。
class Action < TencentCloud::Common::AbstractModel
# @param NormalAction: 常规功能操作,选择该类型的功能项有:
# 访问URL 重写(AccessUrlRedirect);
# 回源 URL 重写 (UpstreamUrlRedirect);
# QUIC(QUIC);
# WebSocket (WebSocket);
# 视频拖拽(VideoSeek);
# Token 鉴权(Authentication);
# 自定义CacheKey(CacheKey);
# 节点缓存 TTL (Cache);
# 浏览器缓存 TTL(MaxAge);
# 离线缓存(OfflineCache);
# 智能加速(SmartRouting);
# 分片回源(RangeOriginPull);
# HTTP/2 回源(UpstreamHttp2);
# Host Header 重写(HostHeader);
# 强制 HTTPS(ForceRedirect);
# 回源 HTTPS(OriginPullProtocol);
# 缓存预刷新(CachePrefresh);
# 智能压缩(Compression);
# Hsts;
# ClientIpHeader;
# SslTlsSecureConf;
# OcspStapling;
# HTTP/2 访问(Http2);
# 回源跟随重定向(UpstreamFollowRedirect);
# 修改源站(Origin)。
# 七层回源超时(HTTPUpstreamTimeout)。
# Http应答(HttpResponse)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NormalAction: :class:`Tencentcloud::Teo.v20220901.models.NormalAction`
# @param RewriteAction: 带有请求头/响应头的功能操作,选择该类型的功能项有:
# 修改 HTTP 请求头(RequestHeader);
# 修改HTTP响应头(ResponseHeader)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RewriteAction: :class:`Tencentcloud::Teo.v20220901.models.RewriteAction`
# @param CodeAction: 带有状态码的功能操作,选择该类型的功能项有:
# 自定义错误页面(ErrorPage);
# 状态码缓存 TTL(StatusCodeCache)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CodeAction: :class:`Tencentcloud::Teo.v20220901.models.CodeAction`
attr_accessor :NormalAction, :RewriteAction, :CodeAction
def initialize(normalaction=nil, rewriteaction=nil, codeaction=nil)
@NormalAction = normalaction
@RewriteAction = rewriteaction
@CodeAction = codeaction
end
def deserialize(params)
unless params['NormalAction'].nil?
@NormalAction = NormalAction.new
@NormalAction.deserialize(params['NormalAction'])
end
unless params['RewriteAction'].nil?
@RewriteAction = RewriteAction.new
@RewriteAction.deserialize(params['RewriteAction'])
end
unless params['CodeAction'].nil?
@CodeAction = CodeAction.new
@CodeAction.deserialize(params['CodeAction'])
end
end
end
# 描述键值对过滤器,用于条件过滤查询,支持模糊查询。例如过滤ID、名称、状态等。
# 若存在多个Filter时,Filter间的关系为逻辑与(AND)关系。
# 若同一个Filter存在多个Values,同一Filter下Values间的关系为逻辑或(OR)关系。
class AdvancedFilter < TencentCloud::Common::AbstractModel
# @param Name: 需要过滤的字段。
# @type Name: String
# @param Values: 字段的过滤值。
# @type Values: Array
# @param Fuzzy: 是否启用模糊查询。
# @type Fuzzy: Boolean
attr_accessor :Name, :Values, :Fuzzy
def initialize(name=nil, values=nil, fuzzy=nil)
@Name = name
@Values = values
@Fuzzy = fuzzy
end
def deserialize(params)
@Name = params['Name']
@Values = params['Values']
@Fuzzy = params['Fuzzy']
end
end
# AI规则引擎防护
class AiRule < TencentCloud::Common::AbstractModel
# @param Mode: AI规则引擎状态,取值有:
# smart_status_close:关闭;
# smart_status_open:拦截处置;
# smart_status_observe:观察处置。
# @type Mode: String
attr_accessor :Mode
def initialize(mode=nil)
@Mode = mode
end
def deserialize(params)
@Mode = params['Mode']
end
end
# Bot主动特征识别客户端行为校验。
class AlgDetectJS < TencentCloud::Common::AbstractModel
# @param Name: 操作名称。
# @type Name: String
# @param WorkLevel: 工作量证明 (proof_Of-Work)校验强度,默认low,取值有:
# low:低;
# middle:中;
# high:高。
# @type WorkLevel: String
# @param ExecuteMode: 执行方式,js延迟执行的时间。单位为ms,默认500,取值:0~1000。
# @type ExecuteMode: Integer
# @param InvalidStatTime: 客户端末启用JS(末完成检测)统计周期。单位为秒,默认10,取值:5~3600。
# @type InvalidStatTime: Integer
# @param InvalidThreshold: 客户端末启用JS(末完成检测)触发阈值。单位为次,默认300,取值:1~100000000。
# @type InvalidThreshold: Integer
# @param AlgDetectResults: Bot主动特征识别客户端行为校验结果。
# @type AlgDetectResults: Array
attr_accessor :Name, :WorkLevel, :ExecuteMode, :InvalidStatTime, :InvalidThreshold, :AlgDetectResults
def initialize(name=nil, worklevel=nil, executemode=nil, invalidstattime=nil, invalidthreshold=nil, algdetectresults=nil)
@Name = name
@WorkLevel = worklevel
@ExecuteMode = executemode
@InvalidStatTime = invalidstattime
@InvalidThreshold = invalidthreshold
@AlgDetectResults = algdetectresults
end
def deserialize(params)
@Name = params['Name']
@WorkLevel = params['WorkLevel']
@ExecuteMode = params['ExecuteMode']
@InvalidStatTime = params['InvalidStatTime']
@InvalidThreshold = params['InvalidThreshold']
unless params['AlgDetectResults'].nil?
@AlgDetectResults = []
params['AlgDetectResults'].each do |i|
algdetectresult_tmp = AlgDetectResult.new
algdetectresult_tmp.deserialize(i)
@AlgDetectResults << algdetectresult_tmp
end
end
end
end
# Bot主动特征识别校验结果。
class AlgDetectResult < TencentCloud::Common::AbstractModel
# @param Result: 校验结果,取值有:
# invalid:不合法Cookie;
# cookie_empty:末携带Cookie或Cookie己过期;
# js_empty:客户端末启用JS(末完成检测);
# low:会话速率和周期特征校验低风险;
# middle:会话速率和周期特征校验中风险;
# high:会话速率和周期特征校验高风险;
# timeout:检测超时时长;
# not_browser:不合法浏览器;
# is_bot:Bot客户端。
# @type Result: String
# @param Action: 处罚动作,取值有:
# drop:拦截;
# monitor:观察;
# silence:静默;
# shortdelay:(短时间)等待后响应;
# longdelay:(长时间)等待后响应。
# @type Action: String
attr_accessor :Result, :Action
def initialize(result=nil, action=nil)
@Result = result
@Action = action
end
def deserialize(params)
@Result = params['Result']
@Action = params['Action']
end
end
# Bot主动特征识别规则。
class AlgDetectRule < TencentCloud::Common::AbstractModel
# @param RuleID: 规则id。
# @type RuleID: Integer
# @param RuleName: 规则名。
# @type RuleName: String
# @param Switch: 规则开关。
# @type Switch: String
# @param AlgConditions: 自定义规则。
# @type AlgConditions: Array
# @param AlgDetectSession: Cookie校验和会话行为分析。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlgDetectSession: :class:`Tencentcloud::Teo.v20220901.models.AlgDetectSession`
# @param AlgDetectJS: 客户端行为校验。
# @type AlgDetectJS: Array
# @param UpdateTime: 更新时间。仅出参使用。
# @type UpdateTime: String
attr_accessor :RuleID, :RuleName, :Switch, :AlgConditions, :AlgDetectSession, :AlgDetectJS, :UpdateTime
def initialize(ruleid=nil, rulename=nil, switch=nil, algconditions=nil, algdetectsession=nil, algdetectjs=nil, updatetime=nil)
@RuleID = ruleid
@RuleName = rulename
@Switch = switch
@AlgConditions = algconditions
@AlgDetectSession = algdetectsession
@AlgDetectJS = algdetectjs
@UpdateTime = updatetime
end
def deserialize(params)
@RuleID = params['RuleID']
@RuleName = params['RuleName']
@Switch = params['Switch']
unless params['AlgConditions'].nil?
@AlgConditions = []
params['AlgConditions'].each do |i|
aclcondition_tmp = AclCondition.new
aclcondition_tmp.deserialize(i)
@AlgConditions << aclcondition_tmp
end
end
unless params['AlgDetectSession'].nil?
@AlgDetectSession = AlgDetectSession.new
@AlgDetectSession.deserialize(params['AlgDetectSession'])
end
unless params['AlgDetectJS'].nil?
@AlgDetectJS = []
params['AlgDetectJS'].each do |i|
algdetectjs_tmp = AlgDetectJS.new
algdetectjs_tmp.deserialize(i)
@AlgDetectJS << algdetectjs_tmp
end
end
@UpdateTime = params['UpdateTime']
end
end
# Cookie校验与会话跟踪。
class AlgDetectSession < TencentCloud::Common::AbstractModel
# @param Name: 操作名称。
# @type Name: String
# @param DetectMode: 校验方式,默认update_detect,取值有:
# detect:仅校验;
# update_detect:更新Cookie并校验。
# @type DetectMode: String
# @param SessionAnalyzeSwitch: 会话速率和周期特征校验开关,默认off,取值有:
# off:关闭;
# on:打开。
# @type SessionAnalyzeSwitch: String
# @param InvalidStatTime: 校验结果为未携带Cookie或Cookie已过期的统计周期。单位为秒,默认10,取值:5~3600。
# @type InvalidStatTime: Integer
# @param InvalidThreshold: 校验结果为未携带Cookie或Cookie已过期的触发阈值。单位为次,默认300,取值:1~100000000。
# @type InvalidThreshold: Integer
# @param AlgDetectResults: Cookie校验校验结果。
# @type AlgDetectResults: Array
# @param SessionBehaviors: 会话速率和周期特征校验结果。
# @type SessionBehaviors: Array
attr_accessor :Name, :DetectMode, :SessionAnalyzeSwitch, :InvalidStatTime, :InvalidThreshold, :AlgDetectResults, :SessionBehaviors
def initialize(name=nil, detectmode=nil, sessionanalyzeswitch=nil, invalidstattime=nil, invalidthreshold=nil, algdetectresults=nil, sessionbehaviors=nil)
@Name = name
@DetectMode = detectmode
@SessionAnalyzeSwitch = sessionanalyzeswitch
@InvalidStatTime = invalidstattime
@InvalidThreshold = invalidthreshold
@AlgDetectResults = algdetectresults
@SessionBehaviors = sessionbehaviors
end
def deserialize(params)
@Name = params['Name']
@DetectMode = params['DetectMode']
@SessionAnalyzeSwitch = params['SessionAnalyzeSwitch']
@InvalidStatTime = params['InvalidStatTime']
@InvalidThreshold = params['InvalidThreshold']
unless params['AlgDetectResults'].nil?
@AlgDetectResults = []
params['AlgDetectResults'].each do |i|
algdetectresult_tmp = AlgDetectResult.new
algdetectresult_tmp.deserialize(i)
@AlgDetectResults << algdetectresult_tmp
end
end
unless params['SessionBehaviors'].nil?
@SessionBehaviors = []
params['SessionBehaviors'].each do |i|
algdetectresult_tmp = AlgDetectResult.new
algdetectresult_tmp.deserialize(i)
@SessionBehaviors << algdetectresult_tmp
end
end
end
end
# 别称域名信息。
class AliasDomain < TencentCloud::Common::AbstractModel
# @param AliasName: 别称域名名称。
# @type AliasName: String
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param TargetName: 目标域名名称。
# @type TargetName: String
# @param Status: 别称域名状态,取值有:
# active:已生效;
# pending:部署中;
# conflict:被找回。
# stop:已停用;
# @type Status: String
# @param ForbidMode: 封禁模式,取值有:
# 0:未封禁;
# 11:合规封禁;
# 14:未备案封禁。
# @type ForbidMode: Integer
# @param CreatedOn: 别称域名创建时间。
# @type CreatedOn: String
# @param ModifiedOn: 别称域名修改时间。
# @type ModifiedOn: String
attr_accessor :AliasName, :ZoneId, :TargetName, :Status, :ForbidMode, :CreatedOn, :ModifiedOn
def initialize(aliasname=nil, zoneid=nil, targetname=nil, status=nil, forbidmode=nil, createdon=nil, modifiedon=nil)
@AliasName = aliasname
@ZoneId = zoneid
@TargetName = targetname
@Status = status
@ForbidMode = forbidmode
@CreatedOn = createdon
@ModifiedOn = modifiedon
end
def deserialize(params)
@AliasName = params['AliasName']
@ZoneId = params['ZoneId']
@TargetName = params['TargetName']
@Status = params['Status']
@ForbidMode = params['ForbidMode']
@CreatedOn = params['CreatedOn']
@ModifiedOn = params['ModifiedOn']
end
end
# 应用代理实例
class ApplicationProxy < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param ZoneName: 站点名称。
# @type ZoneName: String
# @param ProxyId: 代理ID。
# @type ProxyId: String
# @param ProxyName: 当ProxyType=hostname时,表示域名或子域名;
# 当ProxyType=instance时,表示代理名称。
# @type ProxyName: String
# @param ProxyType: 四层代理模式,取值有:
# hostname:表示子域名模式;
# instance:表示实例模式。
# @type ProxyType: String
# @param PlatType: 调度模式,取值有:
# ip:表示Anycast IP调度;
# domain:表示CNAME调度。
# @type PlatType: String
# @param Area: 加速区域,取值有:
# mainland:中国大陆境内;
# overseas:全球(不含中国大陆)。
# 默认值:overseas
# @type Area: String
# @param SecurityType: 是否开启安全,取值有:
# 0:关闭安全;
# 1:开启安全。
# @type SecurityType: Integer
# @param AccelerateType: 是否开启加速,取值有:
# 0:关闭加速;
# 1:开启加速。
# @type AccelerateType: Integer
# @param SessionPersistTime: 会话保持时间。
# @type SessionPersistTime: Integer
# @param Status: 状态,取值有:
# online:启用;
# offline:停用;
# progress:部署中;
# stopping:停用中;
# fail:部署失败/停用失败。
# @type Status: String
# @param BanStatus: 封禁状态,取值有:
# banned:已封禁;
# banning:封禁中;
# recover:已解封;
# recovering:解封禁中。
# @type BanStatus: String
# @param ScheduleValue: 调度信息。
# @type ScheduleValue: Array
# @param HostId: 当ProxyType=hostname时:
# 表示代理加速唯一标识。
# @type HostId: String
# @param Ipv6: Ipv6访问配置。
# @type Ipv6: :class:`Tencentcloud::Teo.v20220901.models.Ipv6`
# @param UpdateTime: 更新时间。
# @type UpdateTime: String
# @param ApplicationProxyRules: 规则列表。
# @type ApplicationProxyRules: Array
# @param AccelerateMainland: 中国大陆加速优化配置。
# @type AccelerateMainland: :class:`Tencentcloud::Teo.v20220901.models.AccelerateMainland`
attr_accessor :ZoneId, :ZoneName, :ProxyId, :ProxyName, :ProxyType, :PlatType, :Area, :SecurityType, :AccelerateType, :SessionPersistTime, :Status, :BanStatus, :ScheduleValue, :HostId, :Ipv6, :UpdateTime, :ApplicationProxyRules, :AccelerateMainland
def initialize(zoneid=nil, zonename=nil, proxyid=nil, proxyname=nil, proxytype=nil, plattype=nil, area=nil, securitytype=nil, acceleratetype=nil, sessionpersisttime=nil, status=nil, banstatus=nil, schedulevalue=nil, hostid=nil, ipv6=nil, updatetime=nil, applicationproxyrules=nil, acceleratemainland=nil)
@ZoneId = zoneid
@ZoneName = zonename
@ProxyId = proxyid
@ProxyName = proxyname
@ProxyType = proxytype
@PlatType = plattype
@Area = area
@SecurityType = securitytype
@AccelerateType = acceleratetype
@SessionPersistTime = sessionpersisttime
@Status = status
@BanStatus = banstatus
@ScheduleValue = schedulevalue
@HostId = hostid
@Ipv6 = ipv6
@UpdateTime = updatetime
@ApplicationProxyRules = applicationproxyrules
@AccelerateMainland = acceleratemainland
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ZoneName = params['ZoneName']
@ProxyId = params['ProxyId']
@ProxyName = params['ProxyName']
@ProxyType = params['ProxyType']
@PlatType = params['PlatType']
@Area = params['Area']
@SecurityType = params['SecurityType']
@AccelerateType = params['AccelerateType']
@SessionPersistTime = params['SessionPersistTime']
@Status = params['Status']
@BanStatus = params['BanStatus']
@ScheduleValue = params['ScheduleValue']
@HostId = params['HostId']
unless params['Ipv6'].nil?
@Ipv6 = Ipv6.new
@Ipv6.deserialize(params['Ipv6'])
end
@UpdateTime = params['UpdateTime']
unless params['ApplicationProxyRules'].nil?
@ApplicationProxyRules = []
params['ApplicationProxyRules'].each do |i|
applicationproxyrule_tmp = ApplicationProxyRule.new
applicationproxyrule_tmp.deserialize(i)
@ApplicationProxyRules << applicationproxyrule_tmp
end
end
unless params['AccelerateMainland'].nil?
@AccelerateMainland = AccelerateMainland.new
@AccelerateMainland.deserialize(params['AccelerateMainland'])
end
end
end
# 应用代理规则
class ApplicationProxyRule < TencentCloud::Common::AbstractModel
# @param Proto: 协议,取值有:
# TCP:TCP协议;
# UDP:UDP协议。
# @type Proto: String
# @param Port: 端口,支持格式:
# 单个端口,如:80。
# 端口段,如:81-82。表示81,82两个端口。
# 注意:一条规则最多可填写20个端口。
# @type Port: Array
# @param OriginType: 源站类型,取值有:
# custom:手动添加;
# loadbalancer:负载均衡;
# origins:源站组。
# @type OriginType: String
# @param OriginValue: 源站信息:
# 当 OriginType 为 custom 时,表示一个或多个源站,如`["8.8.8.8","9.9.9.9"]` 或 `OriginValue=["test.com"]`;
# 当 OriginType 为 loadbalancer 时,表示一个负载均衡,如`["lb-xdffsfasdfs"]`;
# 当 OriginType 为 origins 时,要求有且仅有一个元素,表示源站组ID,如`["origin-537f5b41-162a-11ed-abaa-525400c5da15"]`。
# @type OriginValue: Array
# @param RuleId: 规则ID。
# @type RuleId: String
# @param Status: 状态,取值有:
# online:启用;
# offline:停用;
# progress:部署中;
# stopping:停用中;
# fail:部署失败/停用失败。
# @type Status: String
# @param ForwardClientIp: 传递客户端IP,取值有:
# TOA:TOA(仅Proto=TCP时可选);
# PPV1:Proxy Protocol传递,协议版本V1(仅Proto=TCP时可选);
# PPV2:Proxy Protocol传递,协议版本V2;
# OFF:不传递。默认值:OFF。
# @type ForwardClientIp: String
# @param SessionPersist: 是否开启会话保持,取值有:
# true:开启;
# false:关闭。默认值:false。
# @type SessionPersist: Boolean
# @param SessionPersistTime: 会话保持的时间,只有当SessionPersist为true时,该值才会生效。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SessionPersistTime: Integer
# @param OriginPort: 源站端口,支持格式:
# 单端口,如:80。
# 端口段:81-82,表示81,82两个端口。
# @type OriginPort: String
# @param RuleTag: 规则标签。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleTag: String
attr_accessor :Proto, :Port, :OriginType, :OriginValue, :RuleId, :Status, :ForwardClientIp, :SessionPersist, :SessionPersistTime, :OriginPort, :RuleTag
def initialize(proto=nil, port=nil, origintype=nil, originvalue=nil, ruleid=nil, status=nil, forwardclientip=nil, sessionpersist=nil, sessionpersisttime=nil, originport=nil, ruletag=nil)
@Proto = proto
@Port = port
@OriginType = origintype
@OriginValue = originvalue
@RuleId = ruleid
@Status = status
@ForwardClientIp = forwardclientip
@SessionPersist = sessionpersist
@SessionPersistTime = sessionpersisttime
@OriginPort = originport
@RuleTag = ruletag
end
def deserialize(params)
@Proto = params['Proto']
@Port = params['Port']
@OriginType = params['OriginType']
@OriginValue = params['OriginValue']
@RuleId = params['RuleId']
@Status = params['Status']
@ForwardClientIp = params['ForwardClientIp']
@SessionPersist = params['SessionPersist']
@SessionPersistTime = params['SessionPersistTime']
@OriginPort = params['OriginPort']
@RuleTag = params['RuleTag']
end
end
# 站点归属信息
class AscriptionInfo < TencentCloud::Common::AbstractModel
# @param Subdomain: 主机记录。
# @type Subdomain: String
# @param RecordType: 记录类型。
# @type RecordType: String
# @param RecordValue: 记录值。
# @type RecordValue: String
attr_accessor :Subdomain, :RecordType, :RecordValue
def initialize(subdomain=nil, recordtype=nil, recordvalue=nil)
@Subdomain = subdomain
@RecordType = recordtype
@RecordValue = recordvalue
end
def deserialize(params)
@Subdomain = params['Subdomain']
@RecordType = params['RecordType']
@RecordValue = params['RecordValue']
end
end
# 计费数据项
class BillingData < TencentCloud::Common::AbstractModel
# @param Time: 时间。
# @type Time: String
# @param Value: 数值。
# @type Value: Integer
attr_accessor :Time, :Value
def initialize(time=nil, value=nil)
@Time = time
@Value = value
end
def deserialize(params)
@Time = params['Time']
@Value = params['Value']
end
end
# 计费数据过滤条件。
class BillingDataFilter < TencentCloud::Common::AbstractModel
# @param Type: 参数名称。
# @type Type: String
# @param Value: 参数值。
# @type Value: String
attr_accessor :Type, :Value
def initialize(type=nil, value=nil)
@Type = type
@Value = value
end
def deserialize(params)
@Type = params['Type']
@Value = params['Value']
end
end
# BindSecurityTemplateToEntity请求参数结构体
class BindSecurityTemplateToEntityRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 需要绑定或解绑的策略模板所属站点 ID。
# @type ZoneId: String
# @param Entities: 绑定至策略模板(或者从策略模板解绑)的域名列表。
# @type Entities: Array
# @param Operate: 绑定或解绑操作选项,取值有:
# bind:绑定域名至策略模板;
# unbind-keep-policy:将域名从策略模板解绑,解绑时保留当前策略;
# unbind-use-default:将域名从策略模板解绑,并使用默认空白策略。注意:解绑操作当前仅支持单个域名解绑。即:当 Operate 参数取值为 unbind-keep-policy 或 unbind-use-default 时,Entities 参数列表仅支持填写一个域名。
# @type Operate: String
# @param TemplateId: 指定绑定或解绑的策略模板 ID 或站点全局策略
# - 如需绑定至策略模板,或从策略模板解绑,请指定策略模板 ID。
# - 如需绑定至站点全局策略,或从站点全局策略解绑,请使用 @ZoneLevel@domain 参数值。
# 注意:解绑后,域名将使用独立策略,并单独计算规则配额,请确保解绑前套餐规则配额充足。
# @type TemplateId: String
# @param OverWrite: 如指定的域名已经绑定了策略模板,是否替换该模板。支持下列取值:
# true: 替换域名当前绑定的模板;
# false:不替换域名当前绑定的模板。注意:当选择不替换已有策略模板时,若指定域名已经绑定策略模板,API 将返回错误。
# @type OverWrite: Boolean
attr_accessor :ZoneId, :Entities, :Operate, :TemplateId, :OverWrite
def initialize(zoneid=nil, entities=nil, operate=nil, templateid=nil, overwrite=nil)
@ZoneId = zoneid
@Entities = entities
@Operate = operate
@TemplateId = templateid
@OverWrite = overwrite
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Entities = params['Entities']
@Operate = params['Operate']
@TemplateId = params['TemplateId']
@OverWrite = params['OverWrite']
end
end
# BindSecurityTemplateToEntity返回参数结构体
class BindSecurityTemplateToEntityResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# 共享 CNAME 和接入域名的绑定关系
class BindSharedCNAMEMap < TencentCloud::Common::AbstractModel
# @param SharedCNAME: 需要绑定或解绑的共享 CNAME。
# @type SharedCNAME: String
# @param DomainNames: 加速域名,可传递多个,最多20个。
# @type DomainNames: Array
attr_accessor :SharedCNAME, :DomainNames
def initialize(sharedcname=nil, domainnames=nil)
@SharedCNAME = sharedcname
@DomainNames = domainnames
end
def deserialize(params)
@SharedCNAME = params['SharedCNAME']
@DomainNames = params['DomainNames']
end
end
# BindSharedCNAME请求参数结构体
class BindSharedCNAMERequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 加速域名所属站点 ID。
# @type ZoneId: String
# @param BindType: 绑定类型,取值有:
# bind:绑定;
# unbind:解绑。
# @type BindType: String
# @param BindSharedCNAMEMaps: 接入域名与共享 CNAME 的绑定关系。
# @type BindSharedCNAMEMaps: Array
attr_accessor :ZoneId, :BindType, :BindSharedCNAMEMaps
def initialize(zoneid=nil, bindtype=nil, bindsharedcnamemaps=nil)
@ZoneId = zoneid
@BindType = bindtype
@BindSharedCNAMEMaps = bindsharedcnamemaps
end
def deserialize(params)
@ZoneId = params['ZoneId']
@BindType = params['BindType']
unless params['BindSharedCNAMEMaps'].nil?
@BindSharedCNAMEMaps = []
params['BindSharedCNAMEMaps'].each do |i|
bindsharedcnamemap_tmp = BindSharedCNAMEMap.new
bindsharedcnamemap_tmp.deserialize(i)
@BindSharedCNAMEMaps << bindsharedcnamemap_tmp
end
end
end
end
# BindSharedCNAME返回参数结构体
class BindSharedCNAMEResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# BindZoneToPlan请求参数结构体
class BindZoneToPlanRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 未绑定套餐的站点ID。
# @type ZoneId: String
# @param PlanId: 待绑定的目标套餐ID。
# @type PlanId: String
attr_accessor :ZoneId, :PlanId
def initialize(zoneid=nil, planid=nil)
@ZoneId = zoneid
@PlanId = planid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@PlanId = params['PlanId']
end
end
# BindZoneToPlan返回参数结构体
class BindZoneToPlanResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# 安全Bot配置
class BotConfig < TencentCloud::Common::AbstractModel
# @param Switch: bot开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param BotManagedRule: 通用详细基础规则。如果为null,默认使用历史配置。
# @type BotManagedRule: :class:`Tencentcloud::Teo.v20220901.models.BotManagedRule`
# @param BotPortraitRule: 用户画像规则。如果为null,默认使用历史配置。
# @type BotPortraitRule: :class:`Tencentcloud::Teo.v20220901.models.BotPortraitRule`
# @param IntelligenceRule: Bot智能分析。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IntelligenceRule: :class:`Tencentcloud::Teo.v20220901.models.IntelligenceRule`
# @param BotUserRules: Bot自定义规则。如果为null,默认使用历史配置。
# @type BotUserRules: Array
# @param AlgDetectRule: Bot主动特征识别规则。
# @type AlgDetectRule: Array
# @param Customizes: Bot托管定制策略,入参可不填,仅出参使用。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Customizes: Array
attr_accessor :Switch, :BotManagedRule, :BotPortraitRule, :IntelligenceRule, :BotUserRules, :AlgDetectRule, :Customizes
def initialize(switch=nil, botmanagedrule=nil, botportraitrule=nil, intelligencerule=nil, botuserrules=nil, algdetectrule=nil, customizes=nil)
@Switch = switch
@BotManagedRule = botmanagedrule
@BotPortraitRule = botportraitrule
@IntelligenceRule = intelligencerule
@BotUserRules = botuserrules
@AlgDetectRule = algdetectrule
@Customizes = customizes
end
def deserialize(params)
@Switch = params['Switch']
unless params['BotManagedRule'].nil?
@BotManagedRule = BotManagedRule.new
@BotManagedRule.deserialize(params['BotManagedRule'])
end
unless params['BotPortraitRule'].nil?
@BotPortraitRule = BotPortraitRule.new
@BotPortraitRule.deserialize(params['BotPortraitRule'])
end
unless params['IntelligenceRule'].nil?
@IntelligenceRule = IntelligenceRule.new
@IntelligenceRule.deserialize(params['IntelligenceRule'])
end
unless params['BotUserRules'].nil?
@BotUserRules = []
params['BotUserRules'].each do |i|
botuserrule_tmp = BotUserRule.new
botuserrule_tmp.deserialize(i)
@BotUserRules << botuserrule_tmp
end
end
unless params['AlgDetectRule'].nil?
@AlgDetectRule = []
params['AlgDetectRule'].each do |i|
algdetectrule_tmp = AlgDetectRule.new
algdetectrule_tmp.deserialize(i)
@AlgDetectRule << algdetectrule_tmp
end
end
unless params['Customizes'].nil?
@Customizes = []
params['Customizes'].each do |i|
botuserrule_tmp = BotUserRule.new
botuserrule_tmp.deserialize(i)
@Customizes << botuserrule_tmp
end
end
end
end
# Bot扩展处置方式,多处置动作组合。
class BotExtendAction < TencentCloud::Common::AbstractModel
# @param Action: 处置动作,取值有:
# monitor:观察;
# alg:JavaScript挑战;
# captcha:托管挑战;
# random:随机,按照ExtendActions分配处置动作和比例;
# silence:静默;
# shortdelay:短时响应;
# longdelay:长时响应。
# @type Action: String
# @param Percent: 处置方式的触发概率,范围0-100。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Percent: Integer
attr_accessor :Action, :Percent
def initialize(action=nil, percent=nil)
@Action = action
@Percent = percent
end
def deserialize(params)
@Action = params['Action']
@Percent = params['Percent']
end
end
# Bot 规则,下列规则ID可参考接口 DescribeBotManagedRules返回的ID信息
class BotManagedRule < TencentCloud::Common::AbstractModel
# @param Action: 触发规则后的处置方式,取值有:
# drop:拦截;
# trans:放行;
# alg:Javascript挑战;
# monitor:观察。
# @type Action: String
# @param RuleID: 本规则的ID。仅出参使用。
# @type RuleID: Integer
# @param TransManagedIds: 放行的规则ID。默认所有规则不配置放行。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TransManagedIds: Array
# @param AlgManagedIds: JS挑战的规则ID。默认所有规则不配置JS挑战。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlgManagedIds: Array
# @param CapManagedIds: 数字验证码的规则ID。默认所有规则不配置数字验证码。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CapManagedIds: Array
# @param MonManagedIds: 观察的规则ID。默认所有规则不配置观察。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MonManagedIds: Array
# @param DropManagedIds: 拦截的规则ID。默认所有规则不配置拦截。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DropManagedIds: Array
attr_accessor :Action, :RuleID, :TransManagedIds, :AlgManagedIds, :CapManagedIds, :MonManagedIds, :DropManagedIds
def initialize(action=nil, ruleid=nil, transmanagedids=nil, algmanagedids=nil, capmanagedids=nil, monmanagedids=nil, dropmanagedids=nil)
@Action = action
@RuleID = ruleid
@TransManagedIds = transmanagedids
@AlgManagedIds = algmanagedids
@CapManagedIds = capmanagedids
@MonManagedIds = monmanagedids
@DropManagedIds = dropmanagedids
end
def deserialize(params)
@Action = params['Action']
@RuleID = params['RuleID']
@TransManagedIds = params['TransManagedIds']
@AlgManagedIds = params['AlgManagedIds']
@CapManagedIds = params['CapManagedIds']
@MonManagedIds = params['MonManagedIds']
@DropManagedIds = params['DropManagedIds']
end
end
# bot 用户画像规则
class BotPortraitRule < TencentCloud::Common::AbstractModel
# @param Switch: 本功能的开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param RuleID: 本规则的ID。仅出参使用。
# @type RuleID: Integer
# @param AlgManagedIds: JS挑战的规则ID。默认所有规则不配置JS挑战。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AlgManagedIds: Array
# @param CapManagedIds: 数字验证码的规则ID。默认所有规则不配置数字验证码。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CapManagedIds: Array
# @param MonManagedIds: 观察的规则ID。默认所有规则不配置观察。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MonManagedIds: Array
# @param DropManagedIds: 拦截的规则ID。默认所有规则不配置拦截。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DropManagedIds: Array
attr_accessor :Switch, :RuleID, :AlgManagedIds, :CapManagedIds, :MonManagedIds, :DropManagedIds
def initialize(switch=nil, ruleid=nil, algmanagedids=nil, capmanagedids=nil, monmanagedids=nil, dropmanagedids=nil)
@Switch = switch
@RuleID = ruleid
@AlgManagedIds = algmanagedids
@CapManagedIds = capmanagedids
@MonManagedIds = monmanagedids
@DropManagedIds = dropmanagedids
end
def deserialize(params)
@Switch = params['Switch']
@RuleID = params['RuleID']
@AlgManagedIds = params['AlgManagedIds']
@CapManagedIds = params['CapManagedIds']
@MonManagedIds = params['MonManagedIds']
@DropManagedIds = params['DropManagedIds']
end
end
# Bot自定义规则
class BotUserRule < TencentCloud::Common::AbstractModel
# @param RuleName: 规则名,只能以英文字符,数字,下划线组合,且不能以下划线开头。
# @type RuleName: String
# @param Action: 处置动作,取值有:
# drop:拦截;
# monitor:观察;
# trans:放行;
# redirect:重定向;
# page:指定页面;
# alg:JavaScript 挑战;
# captcha:托管挑战;
# random:随机处置;
# silence:静默;
# shortdelay:短时响应;
# longdelay:长时响应。
# @type Action: String
# @param RuleStatus: 规则状态,取值有:
# on:生效;
# off:不生效。默认 on 生效。
# @type RuleStatus: String
# @param AclConditions: 规则详情。
# @type AclConditions: Array
# @param RulePriority: 规则权重,取值范围0-100。
# @type RulePriority: Integer
# @param RuleID: 规则 Id。仅出参使用。
# @type RuleID: Integer
# @param ExtendActions: 随机处置的处置方式及占比,非随机处置可不填暂不支持。
# @type ExtendActions: Array
# @param FreqFields: 过滤词,取值有:
# sip:客户端 ip。
# 默认为空字符串。
# @type FreqFields: Array
# @param UpdateTime: 更新时间。仅出参使用。
# @type UpdateTime: String
# @param FreqScope: 统计范围。取值有:
# source_to_eo:(响应)源站到 EdgeOne;
# client_to_eo:(请求)客户端到 EdgeOne。
# 默认为 source_to_eo。
# @type FreqScope: Array
# @param Name: 自定义返回页面的名称。Action 是 page 时必填,且不能为空。
# @type Name: String
# @param CustomResponseId: 自定义响应 Id。该 Id 可通过查询自定义错误页列表接口获取。默认值为default,使用系统默认页面。Action 是 page 时必填,且不能为空。
# @type CustomResponseId: String
# @param ResponseCode: 自定义返回页面的响应码。Action 是 page 时必填,且不能为空,取值: 100~600,不支持 3xx 响应码。默认值:567。
# @type ResponseCode: Integer
# @param RedirectUrl: 重定向时候的地址。Action 是 redirect 时必填,且不能为空。
# @type RedirectUrl: String
attr_accessor :RuleName, :Action, :RuleStatus, :AclConditions, :RulePriority, :RuleID, :ExtendActions, :FreqFields, :UpdateTime, :FreqScope, :Name, :CustomResponseId, :ResponseCode, :RedirectUrl
def initialize(rulename=nil, action=nil, rulestatus=nil, aclconditions=nil, rulepriority=nil, ruleid=nil, extendactions=nil, freqfields=nil, updatetime=nil, freqscope=nil, name=nil, customresponseid=nil, responsecode=nil, redirecturl=nil)
@RuleName = rulename
@Action = action
@RuleStatus = rulestatus
@AclConditions = aclconditions
@RulePriority = rulepriority
@RuleID = ruleid
@ExtendActions = extendactions
@FreqFields = freqfields
@UpdateTime = updatetime
@FreqScope = freqscope
@Name = name
@CustomResponseId = customresponseid
@ResponseCode = responsecode
@RedirectUrl = redirecturl
end
def deserialize(params)
@RuleName = params['RuleName']
@Action = params['Action']
@RuleStatus = params['RuleStatus']
unless params['AclConditions'].nil?
@AclConditions = []
params['AclConditions'].each do |i|
aclcondition_tmp = AclCondition.new
aclcondition_tmp.deserialize(i)
@AclConditions << aclcondition_tmp
end
end
@RulePriority = params['RulePriority']
@RuleID = params['RuleID']
unless params['ExtendActions'].nil?
@ExtendActions = []
params['ExtendActions'].each do |i|
botextendaction_tmp = BotExtendAction.new
botextendaction_tmp.deserialize(i)
@ExtendActions << botextendaction_tmp
end
end
@FreqFields = params['FreqFields']
@UpdateTime = params['UpdateTime']
@FreqScope = params['FreqScope']
@Name = params['Name']
@CustomResponseId = params['CustomResponseId']
@ResponseCode = params['ResponseCode']
@RedirectUrl = params['RedirectUrl']
end
end
# cc配置项。
class CC < TencentCloud::Common::AbstractModel
# @param Switch: Waf开关,取值为:
# on:开启;
# off:关闭。
# @type Switch: String
# @param PolicyId: 策略ID。
# @type PolicyId: Integer
attr_accessor :Switch, :PolicyId
def initialize(switch=nil, policyid=nil)
@Switch = switch
@PolicyId = policyid
end
def deserialize(params)
@Switch = params['Switch']
@PolicyId = params['PolicyId']
end
end
# 实时日志投递到腾讯云 CLS 的配置信息。
class CLSTopic < TencentCloud::Common::AbstractModel
# @param LogSetId: 腾讯云 CLS 日志集 ID。
# @type LogSetId: String
# @param TopicId: 腾讯云 CLS 日志主题 ID。
# @type TopicId: String
# @param LogSetRegion: 腾讯云 CLS 日志集所在的地域。
# @type LogSetRegion: String
attr_accessor :LogSetId, :TopicId, :LogSetRegion
def initialize(logsetid=nil, topicid=nil, logsetregion=nil)
@LogSetId = logsetid
@TopicId = topicid
@LogSetRegion = logsetregion
end
def deserialize(params)
@LogSetId = params['LogSetId']
@TopicId = params['TopicId']
@LogSetRegion = params['LogSetRegion']
end
end
# 缓存时间设置
class Cache < TencentCloud::Common::AbstractModel
# @param Switch: 缓存配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param CacheTime: 缓存过期时间设置。
# 单位为秒,最大可设置为 365 天。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CacheTime: Integer
# @param IgnoreCacheControl: 是否开启强制缓存,取值有:
# on:开启;
# off:关闭。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IgnoreCacheControl: String
attr_accessor :Switch, :CacheTime, :IgnoreCacheControl
extend Gem::Deprecate
deprecate :IgnoreCacheControl, :none, 2024, 11
deprecate :IgnoreCacheControl=, :none, 2024, 11
def initialize(switch=nil, cachetime=nil, ignorecachecontrol=nil)
@Switch = switch
@CacheTime = cachetime
@IgnoreCacheControl = ignorecachecontrol
end
def deserialize(params)
@Switch = params['Switch']
@CacheTime = params['CacheTime']
@IgnoreCacheControl = params['IgnoreCacheControl']
end
end
# 缓存规则配置。
class CacheConfig < TencentCloud::Common::AbstractModel
# @param Cache: 缓存配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Cache: :class:`Tencentcloud::Teo.v20220901.models.Cache`
# @param NoCache: 不缓存配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NoCache: :class:`Tencentcloud::Teo.v20220901.models.NoCache`
# @param FollowOrigin: 遵循源站配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FollowOrigin: :class:`Tencentcloud::Teo.v20220901.models.FollowOrigin`
attr_accessor :Cache, :NoCache, :FollowOrigin
def initialize(cache=nil, nocache=nil, followorigin=nil)
@Cache = cache
@NoCache = nocache
@FollowOrigin = followorigin
end
def deserialize(params)
unless params['Cache'].nil?
@Cache = Cache.new
@Cache.deserialize(params['Cache'])
end
unless params['NoCache'].nil?
@NoCache = NoCache.new
@NoCache.deserialize(params['NoCache'])
end
unless params['FollowOrigin'].nil?
@FollowOrigin = FollowOrigin.new
@FollowOrigin.deserialize(params['FollowOrigin'])
end
end
end
# 缓存键配置。
class CacheKey < TencentCloud::Common::AbstractModel
# @param FullUrlCache: 是否开启全路径缓存,取值有:
# on:开启全路径缓存(即关闭参数忽略);
# off:关闭全路径缓存(即开启参数忽略)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FullUrlCache: String
# @param IgnoreCase: 是否忽略大小写缓存,取值有:
# on:忽略;
# off:不忽略。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IgnoreCase: String
# @param QueryString: CacheKey 中包含请求参数。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type QueryString: :class:`Tencentcloud::Teo.v20220901.models.QueryString`
attr_accessor :FullUrlCache, :IgnoreCase, :QueryString
def initialize(fullurlcache=nil, ignorecase=nil, querystring=nil)
@FullUrlCache = fullurlcache
@IgnoreCase = ignorecase
@QueryString = querystring
end
def deserialize(params)
@FullUrlCache = params['FullUrlCache']
@IgnoreCase = params['IgnoreCase']
unless params['QueryString'].nil?
@QueryString = QueryString.new
@QueryString.deserialize(params['QueryString'])
end
end
end
# 缓存预刷新
class CachePrefresh < TencentCloud::Common::AbstractModel
# @param Switch: 缓存预刷新配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param Percent: 缓存预刷新百分比,取值范围:1-99。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Percent: Integer
attr_accessor :Switch, :Percent
def initialize(switch=nil, percent=nil)
@Switch = switch
@Percent = percent
end
def deserialize(params)
@Switch = params['Switch']
@Percent = params['Percent']
end
end
# 节点缓存清除类型取值为 purge_cache_tag 时附带的信息。
class CacheTag < TencentCloud::Common::AbstractModel
# @param Domains: 待清除缓存的域名列表。
# @type Domains: Array
attr_accessor :Domains
def initialize(domains=nil)
@Domains = domains
end
def deserialize(params)
@Domains = params['Domains']
end
end
# https 证书配置。
class CertificateInfo < TencentCloud::Common::AbstractModel
# @param CertId: 证书 ID。来源于 SSL 侧,您可以前往 [SSL 证书列表](https://console.cloud.tencent.com/ssl) 查看 CertId。
# @type CertId: String
# @param Alias: 证书备注名。
# @type Alias: String
# @param Type: 证书类型,取值有:
# default:默认证书;
# upload:用户上传;
# managed:腾讯云托管。
# @type Type: String
# @param ExpireTime: 证书过期时间。
# @type ExpireTime: String
# @param DeployTime: 证书部署时间。
# @type DeployTime: String
# @param SignAlgo: 签名算法。
# @type SignAlgo: String
# @param Status: 证书状态,取值有:
# deployed:已部署;
# processing:部署中;
# applying:申请中;
# failed:申请失败;
# issued:绑定失败。
# @type Status: String
attr_accessor :CertId, :Alias, :Type, :ExpireTime, :DeployTime, :SignAlgo, :Status
def initialize(certid=nil, _alias=nil, type=nil, expiretime=nil, deploytime=nil, signalgo=nil, status=nil)
@CertId = certid
@Alias = _alias
@Type = type
@ExpireTime = expiretime
@DeployTime = deploytime
@SignAlgo = signalgo
@Status = status
end
def deserialize(params)
@CertId = params['CertId']
@Alias = params['Alias']
@Type = params['Type']
@ExpireTime = params['ExpireTime']
@DeployTime = params['DeployTime']
@SignAlgo = params['SignAlgo']
@Status = params['Status']
end
end
# CheckCnameStatus请求参数结构体
class CheckCnameStatusRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param RecordNames: 加速域名列表。
# @type RecordNames: Array
attr_accessor :ZoneId, :RecordNames
def initialize(zoneid=nil, recordnames=nil)
@ZoneId = zoneid
@RecordNames = recordnames
end
def deserialize(params)
@ZoneId = params['ZoneId']
@RecordNames = params['RecordNames']
end
end
# CheckCnameStatus返回参数结构体
class CheckCnameStatusResponse < TencentCloud::Common::AbstractModel
# @param CnameStatus: 加速域名 CNAME 状态信息列表。
# @type CnameStatus: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :CnameStatus, :RequestId
def initialize(cnamestatus=nil, requestid=nil)
@CnameStatus = cnamestatus
@RequestId = requestid
end
def deserialize(params)
unless params['CnameStatus'].nil?
@CnameStatus = []
params['CnameStatus'].each do |i|
cnamestatus_tmp = CnameStatus.new
cnamestatus_tmp.deserialize(i)
@CnameStatus << cnamestatus_tmp
end
end
@RequestId = params['RequestId']
end
end
# 各个健康检查区域下源站的健康状态。
class CheckRegionHealthStatus < TencentCloud::Common::AbstractModel
# @param Region: 健康检查区域,ISO-3166-1 两位字母代码。
# @type Region: String
# @param Healthy: 单健康检查区域下探测源站的健康状态,取值有:
# Healthy:健康;
# Unhealthy:不健康;
# Undetected:未探测到数据。说明:单健康检查区域下所有源站为健康,则状态为健康,否则为不健康。
# @type Healthy: String
# @param OriginHealthStatus: 源站健康状态。
# @type OriginHealthStatus: Array
attr_accessor :Region, :Healthy, :OriginHealthStatus
def initialize(region=nil, healthy=nil, originhealthstatus=nil)
@Region = region
@Healthy = healthy
@OriginHealthStatus = originhealthstatus
end
def deserialize(params)
@Region = params['Region']
@Healthy = params['Healthy']
unless params['OriginHealthStatus'].nil?
@OriginHealthStatus = []
params['OriginHealthStatus'].each do |i|
originhealthstatus_tmp = OriginHealthStatus.new
originhealthstatus_tmp.deserialize(i)
@OriginHealthStatus << originhealthstatus_tmp
end
end
end
end
# 回源时携带客户端IP所属地域信息,值的格式为ISO-3166-1两位字母代码。
class ClientIpCountry < TencentCloud::Common::AbstractModel
# @param Switch: 配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param HeaderName: 存放客户端 IP 所属地域信息的请求头名称,当 Switch=on 时有效。
# 为空则使用默认值:EO-Client-IPCountry。
# @type HeaderName: String
attr_accessor :Switch, :HeaderName
def initialize(switch=nil, headername=nil)
@Switch = switch
@HeaderName = headername
end
def deserialize(params)
@Switch = params['Switch']
@HeaderName = params['HeaderName']
end
end
# 存储客户端请求IP的头部信息配置
class ClientIpHeader < TencentCloud::Common::AbstractModel
# @param Switch: 配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param HeaderName: 回源时,存放客户端 IP 的请求头名称。当 Switch 为 on 时,该参数必填。该参数不允许填写 X-Forwarded-For。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type HeaderName: String
attr_accessor :Switch, :HeaderName
def initialize(switch=nil, headername=nil)
@Switch = switch
@HeaderName = headername
end
def deserialize(params)
@Switch = params['Switch']
@HeaderName = params['HeaderName']
end
end
# CNAME 状态
class CnameStatus < TencentCloud::Common::AbstractModel
# @param RecordName: 记录名称。
# @type RecordName: String
# @param Cname: CNAME 地址。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Cname: String
# @param Status: Cname状态信息,取值有:
# active:生效;
# moved:不生效。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Status: String
attr_accessor :RecordName, :Cname, :Status
def initialize(recordname=nil, cname=nil, status=nil)
@RecordName = recordname
@Cname = cname
@Status = status
end
def deserialize(params)
@RecordName = params['RecordName']
@Cname = params['Cname']
@Status = params['Status']
end
end
# 规则引擎带有状态码的动作
class CodeAction < TencentCloud::Common::AbstractModel
# @param Action: 功能名称,功能名称填写规范可调用接口 [查询规则引擎的设置参数](https://cloud.tencent.com/document/product/1552/80618) 查看。
# @type Action: String
# @param Parameters: 操作参数。
# @type Parameters: Array
attr_accessor :Action, :Parameters
def initialize(action=nil, parameters=nil)
@Action = action
@Parameters = parameters
end
def deserialize(params)
@Action = params['Action']
unless params['Parameters'].nil?
@Parameters = []
params['Parameters'].each do |i|
rulecodeactionparams_tmp = RuleCodeActionParams.new
rulecodeactionparams_tmp.deserialize(i)
@Parameters << rulecodeactionparams_tmp
end
end
end
end
# 智能压缩配置。
class Compression < TencentCloud::Common::AbstractModel
# @param Switch: 智能压缩配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param Algorithms: 支持的压缩算法列表,取值有:
# brotli:brotli算法;
# gzip:gzip算法。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Algorithms: Array
attr_accessor :Switch, :Algorithms
def initialize(switch=nil, algorithms=nil)
@Switch = switch
@Algorithms = algorithms
end
def deserialize(params)
@Switch = params['Switch']
@Algorithms = params['Algorithms']
end
end
# 配置组版本信息。
class ConfigGroupVersionInfo < TencentCloud::Common::AbstractModel
# @param VersionId: 版本 ID。
# @type VersionId: String
# @param VersionNumber: 版本号。
# @type VersionNumber: String
# @param GroupId: 配置组 ID。
# @type GroupId: String
# @param GroupType: 配置组类型。取值有:
# l7_acceleration :七层加速配置组。
# edge_functions :边缘函数配置组。
# @type GroupType: String
# @param Description: 版本描述。
# @type Description: String
# @param Status: 版本状态,取值有:
# creating:创建中;
# inactive:未生效;
# active:已生效。
# @type Status: String
# @param CreateTime: 版本创建时间。时间为世界标准时间(UTC), 遵循 ISO 8601 标准的日期和时间格式。
# @type CreateTime: String
attr_accessor :VersionId, :VersionNumber, :GroupId, :GroupType, :Description, :Status, :CreateTime
def initialize(versionid=nil, versionnumber=nil, groupid=nil, grouptype=nil, description=nil, status=nil, createtime=nil)
@VersionId = versionid
@VersionNumber = versionnumber
@GroupId = groupid
@GroupType = grouptype
@Description = description
@Status = status
@CreateTime = createtime
end
def deserialize(params)
@VersionId = params['VersionId']
@VersionNumber = params['VersionNumber']
@GroupId = params['GroupId']
@GroupType = params['GroupType']
@Description = params['Description']
@Status = params['Status']
@CreateTime = params['CreateTime']
end
end
# CreateAccelerationDomain请求参数结构体
class CreateAccelerationDomainRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 加速域名所属站点 ID。
# @type ZoneId: String
# @param DomainName: 加速域名。
# @type DomainName: String
# @param OriginInfo: 源站信息。
# @type OriginInfo: :class:`Tencentcloud::Teo.v20220901.models.OriginInfo`
# @param OriginProtocol: 回源协议,取值有:
# FOLLOW: 协议跟随;
# HTTP: HTTP协议回源;
# HTTPS: HTTPS协议回源。
# 不填默认为: FOLLOW。
# @type OriginProtocol: String
# @param HttpOriginPort: HTTP回源端口,取值为1-65535,当OriginProtocol=FOLLOW/HTTP时生效, 不填默认为80。
# @type HttpOriginPort: Integer
# @param HttpsOriginPort: HTTPS回源端口,取值为1-65535,当OriginProtocol=FOLLOW/HTTPS时生效,不填默认为443。
# @type HttpsOriginPort: Integer
# @param IPv6Status: IPv6状态,取值有:
# follow:遵循站点IPv6配置;
# on:开启状态;
# off:关闭状态。
# 不填默认为:follow。
# @type IPv6Status: String
attr_accessor :ZoneId, :DomainName, :OriginInfo, :OriginProtocol, :HttpOriginPort, :HttpsOriginPort, :IPv6Status
def initialize(zoneid=nil, domainname=nil, origininfo=nil, originprotocol=nil, httporiginport=nil, httpsoriginport=nil, ipv6status=nil)
@ZoneId = zoneid
@DomainName = domainname
@OriginInfo = origininfo
@OriginProtocol = originprotocol
@HttpOriginPort = httporiginport
@HttpsOriginPort = httpsoriginport
@IPv6Status = ipv6status
end
def deserialize(params)
@ZoneId = params['ZoneId']
@DomainName = params['DomainName']
unless params['OriginInfo'].nil?
@OriginInfo = OriginInfo.new
@OriginInfo.deserialize(params['OriginInfo'])
end
@OriginProtocol = params['OriginProtocol']
@HttpOriginPort = params['HttpOriginPort']
@HttpsOriginPort = params['HttpsOriginPort']
@IPv6Status = params['IPv6Status']
end
end
# CreateAccelerationDomain返回参数结构体
class CreateAccelerationDomainResponse < TencentCloud::Common::AbstractModel
# @param OwnershipVerification: 当您的站点未进行归属权验证时,您可通过该参数返回的信息单独对域名进行归属权校验。详情参考 [站点/域名归属权验证](https://cloud.tencent.com/document/product/1552/70789)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OwnershipVerification: :class:`Tencentcloud::Teo.v20220901.models.OwnershipVerification`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :OwnershipVerification, :RequestId
def initialize(ownershipverification=nil, requestid=nil)
@OwnershipVerification = ownershipverification
@RequestId = requestid
end
def deserialize(params)
unless params['OwnershipVerification'].nil?
@OwnershipVerification = OwnershipVerification.new
@OwnershipVerification.deserialize(params['OwnershipVerification'])
end
@RequestId = params['RequestId']
end
end
# CreateAliasDomain请求参数结构体
class CreateAliasDomainRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param AliasName: 别称域名名称。
# @type AliasName: String
# @param TargetName: 目标域名名称。
# @type TargetName: String
# @param CertType: 证书配置,取值有:
# none:不配置;
# hosting:SSL托管证书。默认取值为 none。
# @type CertType: String
# @param CertId: 当 CertType 取值为 hosting 时需填入相应证书 ID。
# @type CertId: Array
attr_accessor :ZoneId, :AliasName, :TargetName, :CertType, :CertId
def initialize(zoneid=nil, aliasname=nil, targetname=nil, certtype=nil, certid=nil)
@ZoneId = zoneid
@AliasName = aliasname
@TargetName = targetname
@CertType = certtype
@CertId = certid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@AliasName = params['AliasName']
@TargetName = params['TargetName']
@CertType = params['CertType']
@CertId = params['CertId']
end
end
# CreateAliasDomain返回参数结构体
class CreateAliasDomainResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# CreateApplicationProxy请求参数结构体
class CreateApplicationProxyRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyName: 当 ProxyType=hostname 时,表示域名或子域名;
# 当 ProxyType=instance 时,表示代理名称。
# @type ProxyName: String
# @param PlatType: 调度模式,取值有:
# ip:表示Anycast IP调度;
# domain:表示CNAME调度。
# @type PlatType: String
# @param SecurityType: 是否开启安全,取值有:
# 0:关闭安全;
# 1:开启安全。
# @type SecurityType: Integer
# @param AccelerateType: 是否开启加速,取值有:
# 0:关闭加速;
# 1:开启加速。
# @type AccelerateType: Integer
# @param ProxyType: 四层代理模式,取值有: instance:表示实例模式。不填写使用默认值instance。
# @type ProxyType: String
# @param SessionPersistTime: 会话保持时间,取值范围:30-3600,单位:秒。
# 不填写使用默认值600。
# @type SessionPersistTime: Integer
# @param Ipv6: Ipv6 访问配置。
# 不填写表示关闭 Ipv6 访问。
# @type Ipv6: :class:`Tencentcloud::Teo.v20220901.models.Ipv6`
# @param ApplicationProxyRules: 规则详细信息。
# 不填写则不创建规则。
# @type ApplicationProxyRules: Array
# @param AccelerateMainland: 中国大陆加速优化配置。不填写表示关闭中国大陆加速优化。
# @type AccelerateMainland: :class:`Tencentcloud::Teo.v20220901.models.AccelerateMainland`
attr_accessor :ZoneId, :ProxyName, :PlatType, :SecurityType, :AccelerateType, :ProxyType, :SessionPersistTime, :Ipv6, :ApplicationProxyRules, :AccelerateMainland
def initialize(zoneid=nil, proxyname=nil, plattype=nil, securitytype=nil, acceleratetype=nil, proxytype=nil, sessionpersisttime=nil, ipv6=nil, applicationproxyrules=nil, acceleratemainland=nil)
@ZoneId = zoneid
@ProxyName = proxyname
@PlatType = plattype
@SecurityType = securitytype
@AccelerateType = acceleratetype
@ProxyType = proxytype
@SessionPersistTime = sessionpersisttime
@Ipv6 = ipv6
@ApplicationProxyRules = applicationproxyrules
@AccelerateMainland = acceleratemainland
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyName = params['ProxyName']
@PlatType = params['PlatType']
@SecurityType = params['SecurityType']
@AccelerateType = params['AccelerateType']
@ProxyType = params['ProxyType']
@SessionPersistTime = params['SessionPersistTime']
unless params['Ipv6'].nil?
@Ipv6 = Ipv6.new
@Ipv6.deserialize(params['Ipv6'])
end
unless params['ApplicationProxyRules'].nil?
@ApplicationProxyRules = []
params['ApplicationProxyRules'].each do |i|
applicationproxyrule_tmp = ApplicationProxyRule.new
applicationproxyrule_tmp.deserialize(i)
@ApplicationProxyRules << applicationproxyrule_tmp
end
end
unless params['AccelerateMainland'].nil?
@AccelerateMainland = AccelerateMainland.new
@AccelerateMainland.deserialize(params['AccelerateMainland'])
end
end
end
# CreateApplicationProxy返回参数结构体
class CreateApplicationProxyResponse < TencentCloud::Common::AbstractModel
# @param ProxyId: 新增的四层代理应用ID。
# @type ProxyId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ProxyId, :RequestId
def initialize(proxyid=nil, requestid=nil)
@ProxyId = proxyid
@RequestId = requestid
end
def deserialize(params)
@ProxyId = params['ProxyId']
@RequestId = params['RequestId']
end
end
# CreateApplicationProxyRule请求参数结构体
class CreateApplicationProxyRuleRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param ProxyId: 代理ID。
# @type ProxyId: String
# @param Proto: 协议,取值有:
# TCP:TCP协议;
# UDP:UDP协议。
# @type Proto: String
# @param Port: 端口,支持格式:
# 80:80端口;
# 81-90:81至90端口。
# @type Port: Array
# @param OriginType: 源站类型,取值有:
# custom:手动添加;
# loadbalancer:负载均衡;
# origins:源站组。
# @type OriginType: String
# @param OriginValue: 源站信息:
# 当 OriginType 为 custom 时,表示一个或多个源站,如`["8.8.8.8","9.9.9.9"]` 或 `OriginValue=["test.com"]`;
# 当 OriginType 为 loadbalancer 时,表示一个负载均衡,如`["lb-xdffsfasdfs"]`;
# 当 OriginType 为 origins 时,要求有且仅有一个元素,表示源站组ID,如`["origin-537f5b41-162a-11ed-abaa-525400c5da15"]`。
# @type OriginValue: Array
# @param ForwardClientIp: 传递客户端IP,取值有:
# TOA:TOA(仅Proto=TCP时可选);
# PPV1:Proxy Protocol传递,协议版本V1(仅Proto=TCP时可选);
# PPV2:Proxy Protocol传递,协议版本V2;
# OFF:不传递。默认值:OFF。
# @type ForwardClientIp: String
# @param SessionPersist: 是否开启会话保持,取值有:
# true:开启;
# false:关闭。默认值:false。
# @type SessionPersist: Boolean
# @param SessionPersistTime: 会话保持的时间,只有当SessionPersist为true时,该值才会生效。
# @type SessionPersistTime: Integer
# @param OriginPort: 源站端口,支持格式:
# 单端口:80;
# 端口段:81-90,81至90端口。
# @type OriginPort: String
# @param RuleTag: 规则标签。默认值为空字符串。
# @type RuleTag: String
attr_accessor :ZoneId, :ProxyId, :Proto, :Port, :OriginType, :OriginValue, :ForwardClientIp, :SessionPersist, :SessionPersistTime, :OriginPort, :RuleTag
def initialize(zoneid=nil, proxyid=nil, proto=nil, port=nil, origintype=nil, originvalue=nil, forwardclientip=nil, sessionpersist=nil, sessionpersisttime=nil, originport=nil, ruletag=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@Proto = proto
@Port = port
@OriginType = origintype
@OriginValue = originvalue
@ForwardClientIp = forwardclientip
@SessionPersist = sessionpersist
@SessionPersistTime = sessionpersisttime
@OriginPort = originport
@RuleTag = ruletag
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@Proto = params['Proto']
@Port = params['Port']
@OriginType = params['OriginType']
@OriginValue = params['OriginValue']
@ForwardClientIp = params['ForwardClientIp']
@SessionPersist = params['SessionPersist']
@SessionPersistTime = params['SessionPersistTime']
@OriginPort = params['OriginPort']
@RuleTag = params['RuleTag']
end
end
# CreateApplicationProxyRule返回参数结构体
class CreateApplicationProxyRuleResponse < TencentCloud::Common::AbstractModel
# @param RuleId: 规则ID
# @type RuleId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RuleId, :RequestId
def initialize(ruleid=nil, requestid=nil)
@RuleId = ruleid
@RequestId = requestid
end
def deserialize(params)
@RuleId = params['RuleId']
@RequestId = params['RequestId']
end
end
# CreateCLSIndex请求参数结构体
class CreateCLSIndexRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param TaskId: 实时日志投递任务 ID。
# @type TaskId: String
attr_accessor :ZoneId, :TaskId
def initialize(zoneid=nil, taskid=nil)
@ZoneId = zoneid
@TaskId = taskid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@TaskId = params['TaskId']
end
end
# CreateCLSIndex返回参数结构体
class CreateCLSIndexResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# CreateConfigGroupVersion请求参数结构体
class CreateConfigGroupVersionRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param GroupId: 待新建版本的配置组 ID。
# @type GroupId: String
# @param Content: 待导入的配置内容。要求采用 JSON 格式,按照 UTF-8 方式进行编码。配置文件内容可参考下方示例。
# @type Content: String
# @param Description: 版本描述,可输入最大长度为 50 个字符,可以通过本字段填写该版本的使用场景等。
# @type Description: String
attr_accessor :ZoneId, :GroupId, :Content, :Description
def initialize(zoneid=nil, groupid=nil, content=nil, description=nil)
@ZoneId = zoneid
@GroupId = groupid
@Content = content
@Description = description
end
def deserialize(params)
@ZoneId = params['ZoneId']
@GroupId = params['GroupId']
@Content = params['Content']
@Description = params['Description']
end
end
# CreateConfigGroupVersion返回参数结构体
class CreateConfigGroupVersionResponse < TencentCloud::Common::AbstractModel
# @param VersionId: 版本 ID。
# @type VersionId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :VersionId, :RequestId
def initialize(versionid=nil, requestid=nil)
@VersionId = versionid
@RequestId = requestid
end
def deserialize(params)
@VersionId = params['VersionId']
@RequestId = params['RequestId']
end
end
# CreateCustomizeErrorPage请求参数结构体
class CreateCustomizeErrorPageRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Name: 自定义错误页名称,名称为 2-30 个字符。
# @type Name: String
# @param ContentType: 自定义错误页面类型,取值有:text/html; application/json;text/plain;text/xml。
# @type ContentType: String
# @param Description: 自定义错误页面描述,描述不超过 60 个字符。
# @type Description: String
# @param Content: 自定义错误页面内容,内容不超过 2KB。
# @type Content: String
attr_accessor :ZoneId, :Name, :ContentType, :Description, :Content
def initialize(zoneid=nil, name=nil, contenttype=nil, description=nil, content=nil)
@ZoneId = zoneid
@Name = name
@ContentType = contenttype
@Description = description
@Content = content
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Name = params['Name']
@ContentType = params['ContentType']
@Description = params['Description']
@Content = params['Content']
end
end
# CreateCustomizeErrorPage返回参数结构体
class CreateCustomizeErrorPageResponse < TencentCloud::Common::AbstractModel
# @param PageId: 页面 ID。
# @type PageId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PageId, :RequestId
def initialize(pageid=nil, requestid=nil)
@PageId = pageid
@RequestId = requestid
end
def deserialize(params)
@PageId = params['PageId']
@RequestId = params['RequestId']
end
end
# CreateFunction请求参数结构体
class CreateFunctionRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Name: 函数名称,只能包含小写字母、数字、连字符,以数字或字母开头,以数字或字母结尾,最大支持 30 个字符。
# @type Name: String
# @param Content: 函数内容,当前仅支持 JavaScript 代码,最大支持 5MB 大小。
# @type Content: String
# @param Remark: 函数描述,最大支持 60 个字符。
# @type Remark: String
attr_accessor :ZoneId, :Name, :Content, :Remark
def initialize(zoneid=nil, name=nil, content=nil, remark=nil)
@ZoneId = zoneid
@Name = name
@Content = content
@Remark = remark
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Name = params['Name']
@Content = params['Content']
@Remark = params['Remark']
end
end
# CreateFunction返回参数结构体
class CreateFunctionResponse < TencentCloud::Common::AbstractModel
# @param FunctionId: 函数 ID。
# @type FunctionId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :FunctionId, :RequestId
def initialize(functionid=nil, requestid=nil)
@FunctionId = functionid
@RequestId = requestid
end
def deserialize(params)
@FunctionId = params['FunctionId']
@RequestId = params['RequestId']
end
end
# CreateFunctionRule请求参数结构体
class CreateFunctionRuleRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param FunctionRuleConditions: 规则条件列表,相同触发规则的不同条件匹配项之间为或关系。
# @type FunctionRuleConditions: Array
# @param FunctionId: 函数 ID,命中触发规则条件后执行的函数。
# @type FunctionId: String
# @param Remark: 规则描述,最大支持 60 个字符。
# @type Remark: String
attr_accessor :ZoneId, :FunctionRuleConditions, :FunctionId, :Remark
def initialize(zoneid=nil, functionruleconditions=nil, functionid=nil, remark=nil)
@ZoneId = zoneid
@FunctionRuleConditions = functionruleconditions
@FunctionId = functionid
@Remark = remark
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['FunctionRuleConditions'].nil?
@FunctionRuleConditions = []
params['FunctionRuleConditions'].each do |i|
functionrulecondition_tmp = FunctionRuleCondition.new
functionrulecondition_tmp.deserialize(i)
@FunctionRuleConditions << functionrulecondition_tmp
end
end
@FunctionId = params['FunctionId']
@Remark = params['Remark']
end
end
# CreateFunctionRule返回参数结构体
class CreateFunctionRuleResponse < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID。
# @type RuleId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RuleId, :RequestId
def initialize(ruleid=nil, requestid=nil)
@RuleId = ruleid
@RequestId = requestid
end
def deserialize(params)
@RuleId = params['RuleId']
@RequestId = params['RequestId']
end
end
# CreateL4Proxy请求参数结构体
class CreateL4ProxyRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyName: 四层代理实例名称,可输入 1-50 个字符,允许的字符为 a-z、0-9、-,且 - 不能单独注册或连续使用,不能放在开头或结尾。创建完成后不支持修改。
# @type ProxyName: String
# @param Area: 四层代理实例加速区域。
# mainland:中国大陆可用区;
# overseas:全球可用区(不含中国大陆);
# global:全球可用区。
# @type Area: String
# @param Ipv6: 是否开启 IPv6 访问,不填写时默认为 off。该配置仅在部分加速区域和安全防护配置下支持开启,详情请参考 [新建四层代理实例](https://cloud.tencent.com/document/product/1552/90025) 。取值为:
# on:开启;
# off:关闭。
# @type Ipv6: String
# @param StaticIp: 是否开启固定 IP,不填写时默认为 off。该配置仅在部分加速区域和安全防护配置下支持开启,详情请参考 [新建四层代理实例](https://cloud.tencent.com/document/product/1552/90025) 。取值为:
# on:开启;
# off:关闭。
# @type StaticIp: String
# @param AccelerateMainland: 是否开启中国大陆网络优化,不填写时默认为 off。该配置仅在部分加速区域和安全防护配置下支持开启,详情请参考 [新建四层代理实例](https://cloud.tencent.com/document/product/1552/90025) 。取值为:
# on:开启;
# off:关闭。
# @type AccelerateMainland: String
# @param DDosProtectionConfig: L3/L4 DDoS 防护配置,不填写时默认使用平台默认防护选项。详情参考 [独立 DDoS 防护](https://cloud.tencent.com/document/product/1552/95994)。
# @type DDosProtectionConfig: :class:`Tencentcloud::Teo.v20220901.models.DDosProtectionConfig`
attr_accessor :ZoneId, :ProxyName, :Area, :Ipv6, :StaticIp, :AccelerateMainland, :DDosProtectionConfig
def initialize(zoneid=nil, proxyname=nil, area=nil, ipv6=nil, staticip=nil, acceleratemainland=nil, ddosprotectionconfig=nil)
@ZoneId = zoneid
@ProxyName = proxyname
@Area = area
@Ipv6 = ipv6
@StaticIp = staticip
@AccelerateMainland = acceleratemainland
@DDosProtectionConfig = ddosprotectionconfig
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyName = params['ProxyName']
@Area = params['Area']
@Ipv6 = params['Ipv6']
@StaticIp = params['StaticIp']
@AccelerateMainland = params['AccelerateMainland']
unless params['DDosProtectionConfig'].nil?
@DDosProtectionConfig = DDosProtectionConfig.new
@DDosProtectionConfig.deserialize(params['DDosProtectionConfig'])
end
end
end
# CreateL4Proxy返回参数结构体
class CreateL4ProxyResponse < TencentCloud::Common::AbstractModel
# @param ProxyId: 四层实例 ID。
# @type ProxyId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ProxyId, :RequestId
def initialize(proxyid=nil, requestid=nil)
@ProxyId = proxyid
@RequestId = requestid
end
def deserialize(params)
@ProxyId = params['ProxyId']
@RequestId = params['RequestId']
end
end
# CreateL4ProxyRules请求参数结构体
class CreateL4ProxyRulesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
# @param L4ProxyRules: 转发规则列表。单次最多支持 200 条转发规则。
# 注意:L4ProxyRule 在此处使用时,Protocol、PortRange、OriginType、OriginValue、OriginPortRange 为必填字段;ClientIPPassThroughMode、SessionPersist、SessionPersistTime、RuleTag 均为选填字段;RuleId、Status 请勿填写。
# @type L4ProxyRules: Array
attr_accessor :ZoneId, :ProxyId, :L4ProxyRules
def initialize(zoneid=nil, proxyid=nil, l4proxyrules=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@L4ProxyRules = l4proxyrules
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
unless params['L4ProxyRules'].nil?
@L4ProxyRules = []
params['L4ProxyRules'].each do |i|
l4proxyrule_tmp = L4ProxyRule.new
l4proxyrule_tmp.deserialize(i)
@L4ProxyRules << l4proxyrule_tmp
end
end
end
end
# CreateL4ProxyRules返回参数结构体
class CreateL4ProxyRulesResponse < TencentCloud::Common::AbstractModel
# @param L4ProxyRuleIds: 新增转发规则的 ID,以数组的形式返回。
# @type L4ProxyRuleIds: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :L4ProxyRuleIds, :RequestId
def initialize(l4proxyruleids=nil, requestid=nil)
@L4ProxyRuleIds = l4proxyruleids
@RequestId = requestid
end
def deserialize(params)
@L4ProxyRuleIds = params['L4ProxyRuleIds']
@RequestId = params['RequestId']
end
end
# CreateLoadBalancer请求参数结构体
class CreateLoadBalancerRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Name: 实例名称,可输入 1-200 个字符,允许字符为 a-z,A-Z,0-9,_,-。
# @type Name: String
# @param Type: 实例类型,取值有:
# HTTP:HTTP 专用型,支持添加 HTTP 专用型和通用型源站组,仅支持被站点加速相关服务引用(如域名服务和规则引擎);
# GENERAL:通用型,仅支持添加通用型源站组,能被站点加速服务(如域名服务和规则引擎)和四层代理引用。
# @type Type: String
# @param OriginGroups: 源站组列表及其对应的容灾调度优先级。详情请参考 [快速创建负载均衡实例](https://cloud.tencent.com/document/product/1552/104223) 中的示例场景。
# @type OriginGroups: Array
# @param HealthChecker: 健康检查策略。详情请参考 [健康检查策略介绍](https://cloud.tencent.com/document/product/1552/104228)。不填写时,默认为不启用健康检查。
# @type HealthChecker: :class:`Tencentcloud::Teo.v20220901.models.HealthChecker`
# @param SteeringPolicy: 源站组间的流量调度策略,取值有:
# Pritory:按优先级顺序进行故障转移。默认值为 Pritory。
# @type SteeringPolicy: String
# @param FailoverPolicy: 实际访问某源站失败时的请求重试策略,详情请参考 [请求重试策略介绍](https://cloud.tencent.com/document/product/1552/104227),取值有:
# OtherOriginGroup:单次请求失败后,请求优先重试下一优先级源站组;
# OtherRecordInOriginGroup:单次请求失败后,请求优先重试同源站组内的其他源站。默认值为 OtherRecordInOriginGroup。
# @type FailoverPolicy: String
attr_accessor :ZoneId, :Name, :Type, :OriginGroups, :HealthChecker, :SteeringPolicy, :FailoverPolicy
def initialize(zoneid=nil, name=nil, type=nil, origingroups=nil, healthchecker=nil, steeringpolicy=nil, failoverpolicy=nil)
@ZoneId = zoneid
@Name = name
@Type = type
@OriginGroups = origingroups
@HealthChecker = healthchecker
@SteeringPolicy = steeringpolicy
@FailoverPolicy = failoverpolicy
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Name = params['Name']
@Type = params['Type']
unless params['OriginGroups'].nil?
@OriginGroups = []
params['OriginGroups'].each do |i|
origingroupinloadbalancer_tmp = OriginGroupInLoadBalancer.new
origingroupinloadbalancer_tmp.deserialize(i)
@OriginGroups << origingroupinloadbalancer_tmp
end
end
unless params['HealthChecker'].nil?
@HealthChecker = HealthChecker.new
@HealthChecker.deserialize(params['HealthChecker'])
end
@SteeringPolicy = params['SteeringPolicy']
@FailoverPolicy = params['FailoverPolicy']
end
end
# CreateLoadBalancer返回参数结构体
class CreateLoadBalancerResponse < TencentCloud::Common::AbstractModel
# @param InstanceId: 负载均衡实例 ID。
# @type InstanceId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :InstanceId, :RequestId
def initialize(instanceid=nil, requestid=nil)
@InstanceId = instanceid
@RequestId = requestid
end
def deserialize(params)
@InstanceId = params['InstanceId']
@RequestId = params['RequestId']
end
end
# CreateOriginGroup请求参数结构体
class CreateOriginGroupRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID
# @type ZoneId: String
# @param Name: 源站组名称,可输入1 - 200个字符,允许的字符为 a - z, A - Z, 0 - 9, _, - 。
# @type Name: String
# @param Type: 源站组类型,此参数必填,取值有:
# GENERAL:通用型源站组,仅支持添加 IP/域名 源站,可以被域名服务、规则引擎、四层代理、通用型负载均衡、HTTP 专用型负载均衡引用;
# HTTP: HTTP 专用型源站组,支持添加 IP/域名、对象存储源站作为源站,无法被四层代理引用,仅支持被添加加速域名、规则引擎-修改源站、HTTP 专用型负载均衡引用。
# @type Type: String
# @param Records: 源站记录信息,此参数必填。
# @type Records: Array
# @param HostHeader: 回源 Host Header,仅 Type = HTTP 时传入生效,规则引擎修改 Host Header 配置优先级高于源站组的 Host Header。
# @type HostHeader: String
attr_accessor :ZoneId, :Name, :Type, :Records, :HostHeader
def initialize(zoneid=nil, name=nil, type=nil, records=nil, hostheader=nil)
@ZoneId = zoneid
@Name = name
@Type = type
@Records = records
@HostHeader = hostheader
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Name = params['Name']
@Type = params['Type']
unless params['Records'].nil?
@Records = []
params['Records'].each do |i|
originrecord_tmp = OriginRecord.new
originrecord_tmp.deserialize(i)
@Records << originrecord_tmp
end
end
@HostHeader = params['HostHeader']
end
end
# CreateOriginGroup返回参数结构体
class CreateOriginGroupResponse < TencentCloud::Common::AbstractModel
# @param OriginGroupId: 源站组ID。
# @type OriginGroupId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :OriginGroupId, :RequestId
def initialize(origingroupid=nil, requestid=nil)
@OriginGroupId = origingroupid
@RequestId = requestid
end
def deserialize(params)
@OriginGroupId = params['OriginGroupId']
@RequestId = params['RequestId']
end
end
# CreatePlanForZone请求参数结构体
class CreatePlanForZoneRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param PlanType: 所要购买套餐的类型,取值有:
# sta: 全球内容分发网络(不包括中国大陆)标准版套餐;
# sta_with_bot: 全球内容分发网络(不包括中国大陆)标准版套餐附带bot管理;
# sta_cm: 中国大陆内容分发网络标准版套餐;
# sta_cm_with_bot: 中国大陆内容分发网络标准版套餐附带bot管理;
# sta_global :全球内容分发网络(包括中国大陆)标准版套餐;
# sta_global_with_bot :全球内容分发网络(包括中国大陆)标准版套餐附带bot管理;
# ent: 全球内容分发网络(不包括中国大陆)企业版套餐;
# ent_with_bot: 全球内容分发网络(不包括中国大陆)企业版套餐附带bot管理;
# ent_cm: 中国大陆内容分发网络企业版套餐;
# ent_cm_with_bot: 中国大陆内容分发网络企业版套餐附带bot管理。
# ent_global :全球内容分发网络(包括中国大陆)企业版套餐;
# ent_global_with_bot :全球内容分发网络(包括中国大陆)企业版套餐附带bot管理。当前账户可购买套餐类型请以DescribeAvailablePlans返回为准。
# @type PlanType: String
attr_accessor :ZoneId, :PlanType
def initialize(zoneid=nil, plantype=nil)
@ZoneId = zoneid
@PlanType = plantype
end
def deserialize(params)
@ZoneId = params['ZoneId']
@PlanType = params['PlanType']
end
end
# CreatePlanForZone返回参数结构体
class CreatePlanForZoneResponse < TencentCloud::Common::AbstractModel
# @param ResourceNames: 购买的资源名字列表。
# @type ResourceNames: Array
# @param DealNames: 购买的订单号列表。
# @type DealNames: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ResourceNames, :DealNames, :RequestId
def initialize(resourcenames=nil, dealnames=nil, requestid=nil)
@ResourceNames = resourcenames
@DealNames = dealnames
@RequestId = requestid
end
def deserialize(params)
@ResourceNames = params['ResourceNames']
@DealNames = params['DealNames']
@RequestId = params['RequestId']
end
end
# CreatePlan请求参数结构体
class CreatePlanRequest < TencentCloud::Common::AbstractModel
# @param PlanType: 订阅的套餐类型,取值有: personal:个人版套餐,预付费套餐; basic:基础版套餐,预付费套餐; standard:标准版套餐,预付费套餐; enterprise:企业版套餐,后付费套餐。订阅预付费套餐时,请确保账号内有足够余额,余额不足会产生一个待支付的订单。
# 计费概述参考 [Edgeone计费概述](https://cloud.tencent.com/document/product/1552/94156)
# 不同套餐区别参考 [Edgeone计费套餐选型对比](https://cloud.tencent.com/document/product/1552/94165)
# @type PlanType: String
# @param AutoUseVoucher: 是否自动使用代金券,取值有: true:是; false:否。该参数仅在 PlanType 为 personal, basic, standard 时有效。
# 不填写使用默认值 false。
# @type AutoUseVoucher: String
# @param PrepaidPlanParam: 订阅预付费套餐参数,PlanType 为 personal, basic, standard 时,可以选填该参数,用于传入套餐的订阅时长和是否开启自动续费。
# 不填该参数时,默认开通套餐时长为 1 个月,不开启自动续费。
# @type PrepaidPlanParam: :class:`Tencentcloud::Teo.v20220901.models.PrepaidPlanParam`
attr_accessor :PlanType, :AutoUseVoucher, :PrepaidPlanParam
def initialize(plantype=nil, autousevoucher=nil, prepaidplanparam=nil)
@PlanType = plantype
@AutoUseVoucher = autousevoucher
@PrepaidPlanParam = prepaidplanparam
end
def deserialize(params)
@PlanType = params['PlanType']
@AutoUseVoucher = params['AutoUseVoucher']
unless params['PrepaidPlanParam'].nil?
@PrepaidPlanParam = PrepaidPlanParam.new
@PrepaidPlanParam.deserialize(params['PrepaidPlanParam'])
end
end
end
# CreatePlan返回参数结构体
class CreatePlanResponse < TencentCloud::Common::AbstractModel
# @param PlanId: 套餐 ID,形如 edgeone-2unuvzjmmn2q。
# @type PlanId: String
# @param DealName: 订单号。
# @type DealName: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PlanId, :DealName, :RequestId
def initialize(planid=nil, dealname=nil, requestid=nil)
@PlanId = planid
@DealName = dealname
@RequestId = requestid
end
def deserialize(params)
@PlanId = params['PlanId']
@DealName = params['DealName']
@RequestId = params['RequestId']
end
end
# CreatePrefetchTask请求参数结构体
class CreatePrefetchTaskRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Targets: 要预热的资源列表,每个元素格式类似如下:
# http://www.example.com/example.txt。参数值当前必填。
# 注意:提交任务数受计费套餐配额限制,请查看 [EO计费套餐](https://cloud.tencent.com/document/product/1552/77380)。
# @type Targets: Array
# @param EncodeUrl: 是否对url进行encode,若内容含有非 ASCII 字符集的字符,请开启此开关进行编码转换(编码规则遵循 RFC3986)。
# @type EncodeUrl: Boolean
# @param Headers: 附带的http头部信息。
# @type Headers: Array
attr_accessor :ZoneId, :Targets, :EncodeUrl, :Headers
def initialize(zoneid=nil, targets=nil, encodeurl=nil, headers=nil)
@ZoneId = zoneid
@Targets = targets
@EncodeUrl = encodeurl
@Headers = headers
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Targets = params['Targets']
@EncodeUrl = params['EncodeUrl']
unless params['Headers'].nil?
@Headers = []
params['Headers'].each do |i|
header_tmp = Header.new
header_tmp.deserialize(i)
@Headers << header_tmp
end
end
end
end
# CreatePrefetchTask返回参数结构体
class CreatePrefetchTaskResponse < TencentCloud::Common::AbstractModel
# @param JobId: 任务 ID。
# @type JobId: String
# @param FailedList: 失败的任务列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FailedList: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :JobId, :FailedList, :RequestId
def initialize(jobid=nil, failedlist=nil, requestid=nil)
@JobId = jobid
@FailedList = failedlist
@RequestId = requestid
end
def deserialize(params)
@JobId = params['JobId']
unless params['FailedList'].nil?
@FailedList = []
params['FailedList'].each do |i|
failreason_tmp = FailReason.new
failreason_tmp.deserialize(i)
@FailedList << failreason_tmp
end
end
@RequestId = params['RequestId']
end
end
# CreatePurgeTask请求参数结构体
class CreatePurgeTaskRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Type: 节点缓存清除类型,取值有:
# purge_url:URL刷新;
# purge_prefix:目录刷新;
# purge_host:Hostname 刷新;
# purge_all:站点下全部缓存刷新;
# purge_cache_tag:cache-tag 刷新。缓存清除类型详情请查看[清除缓存](https://cloud.tencent.com/document/product/1552/70759)。
# @type Type: String
# @param Method: 节点缓存清除方法,针对目录刷新、Hostname刷新以及刷新全部缓存类型有效,取值有: invalidate:仅刷新目录下产生了更新的资源; delete:无论目录下资源是否更新都刷新节点资源。默认值: invalidate。
# @type Method: String
# @param Targets: 要清除缓存的资源列表。每个元素格式依据清除缓存类型而定,可参考接口示例。单次提交的任务数受计费套餐配额限制,请查看 [EO计费套餐](https://cloud.tencent.com/document/product/1552/77380)。
# @type Targets: Array
# @param EncodeUrl: 若有编码转换,仅清除编码转换后匹配的资源。
# 若内容含有非 ASCII 字符集的字符,请开启此开关进行编码转换(编码规则遵循 RFC3986)。
# @type EncodeUrl: Boolean
# @param CacheTag: 节点缓存清除类型取值为 purge_cache_tag 时附带的信息。
# @type CacheTag: :class:`Tencentcloud::Teo.v20220901.models.CacheTag`
attr_accessor :ZoneId, :Type, :Method, :Targets, :EncodeUrl, :CacheTag
extend Gem::Deprecate
deprecate :EncodeUrl, :none, 2024, 11
deprecate :EncodeUrl=, :none, 2024, 11
def initialize(zoneid=nil, type=nil, method=nil, targets=nil, encodeurl=nil, cachetag=nil)
@ZoneId = zoneid
@Type = type
@Method = method
@Targets = targets
@EncodeUrl = encodeurl
@CacheTag = cachetag
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Type = params['Type']
@Method = params['Method']
@Targets = params['Targets']
@EncodeUrl = params['EncodeUrl']
unless params['CacheTag'].nil?
@CacheTag = CacheTag.new
@CacheTag.deserialize(params['CacheTag'])
end
end
end
# CreatePurgeTask返回参数结构体
class CreatePurgeTaskResponse < TencentCloud::Common::AbstractModel
# @param JobId: 任务 ID。
# @type JobId: String
# @param FailedList: 失败的任务列表及原因。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FailedList: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :JobId, :FailedList, :RequestId
def initialize(jobid=nil, failedlist=nil, requestid=nil)
@JobId = jobid
@FailedList = failedlist
@RequestId = requestid
end
def deserialize(params)
@JobId = params['JobId']
unless params['FailedList'].nil?
@FailedList = []
params['FailedList'].each do |i|
failreason_tmp = FailReason.new
failreason_tmp.deserialize(i)
@FailedList << failreason_tmp
end
end
@RequestId = params['RequestId']
end
end
# CreateRealtimeLogDeliveryTask请求参数结构体
class CreateRealtimeLogDeliveryTaskRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param TaskName: 实时日志投递任务的名称,格式为数字、英文、-和_组合,最多 200 个字符。
# @type TaskName: String
# @param TaskType: 实时日志投递任务类型,取值有:
# cls: 推送到腾讯云 CLS;
# custom_endpoint:推送到自定义 HTTP(S) 地址;
# s3:推送到 AWS S3 兼容存储桶地址。
# @type TaskType: String
# @param EntityList: 实时日志投递任务对应的实体(七层域名或者四层代理实例)列表。取值示例如下:
# 七层域名:domain.example.com;
# 四层代理实例:sid-2s69eb5wcms7。
# @type EntityList: Array
# @param LogType: 数据投递类型,取值有:
# domain:站点加速日志;
# application:四层代理日志;
# web-rateLiming:速率限制和 CC 攻击防护日志;
# web-attack:托管规则日志;
# web-rule:自定义规则日志;
# web-bot:Bot管理日志。
# @type LogType: String
# @param Area: 数据投递区域,取值有:
# mainland:中国大陆境内;
# overseas:全球(不含中国大陆)。
# @type Area: String
# @param Fields: 投递的预设字段列表。
# @type Fields: Array
# @param CustomFields: 投递的自定义字段列表,支持在 HTTP 请求头、响应头、Cookie、请求正文中提取指定内容。自定义字段名称不能重复,且最多不能超过 200 个字段。单个实时日志推送任务最多添加 5 个请求正文类型的自定义字段。目前仅站点加速日志(LogType=domain)支持添加自定义字段。
# @type CustomFields: Array
# @param DeliveryConditions: 日志投递的过滤条件,不填表示投递全量日志。
# @type DeliveryConditions: Array
# @param Sample: 采样比例,采用千分制,取值范围为1-1000,例如:填写 605 表示采样比例为 60.5%。不填表示采样比例为 100%。
# @type Sample: Integer
# @param LogFormat: 日志投递的输出格式。不填表示为默认格式,默认格式逻辑如下:
# 当 TaskType 取值为 custom_endpoint 时,默认格式为多个 JSON 对象组成的数组,每个 JSON 对象为一条日志;
# 当 TaskType 取值为 s3 时,默认格式为 JSON Lines;特别地,当 TaskType 取值为 cls 时,LogFormat.FormatType 的值只能为 json,且 LogFormat 中其他参数将被忽略,建议不传 LogFormat。
# @type LogFormat: :class:`Tencentcloud::Teo.v20220901.models.LogFormat`
# @param CLS: CLS 的配置信息。当 TaskType 取值为 cls 时,该参数必填。
# @type CLS: :class:`Tencentcloud::Teo.v20220901.models.CLSTopic`
# @param CustomEndpoint: 自定义 HTTP 服务的配置信息。当 TaskType 取值为 custom_endpoint 时,该参数必填。
# @type CustomEndpoint: :class:`Tencentcloud::Teo.v20220901.models.CustomEndpoint`
# @param S3: AWS S3 兼容存储桶的配置信息。当 TaskType 取值为 s3 时,该参数必填。
# @type S3: :class:`Tencentcloud::Teo.v20220901.models.S3`
attr_accessor :ZoneId, :TaskName, :TaskType, :EntityList, :LogType, :Area, :Fields, :CustomFields, :DeliveryConditions, :Sample, :LogFormat, :CLS, :CustomEndpoint, :S3
def initialize(zoneid=nil, taskname=nil, tasktype=nil, entitylist=nil, logtype=nil, area=nil, fields=nil, customfields=nil, deliveryconditions=nil, sample=nil, logformat=nil, cls=nil, customendpoint=nil, s3=nil)
@ZoneId = zoneid
@TaskName = taskname
@TaskType = tasktype
@EntityList = entitylist
@LogType = logtype
@Area = area
@Fields = fields
@CustomFields = customfields
@DeliveryConditions = deliveryconditions
@Sample = sample
@LogFormat = logformat
@CLS = cls
@CustomEndpoint = customendpoint
@S3 = s3
end
def deserialize(params)
@ZoneId = params['ZoneId']
@TaskName = params['TaskName']
@TaskType = params['TaskType']
@EntityList = params['EntityList']
@LogType = params['LogType']
@Area = params['Area']
@Fields = params['Fields']
unless params['CustomFields'].nil?
@CustomFields = []
params['CustomFields'].each do |i|
customfield_tmp = CustomField.new
customfield_tmp.deserialize(i)
@CustomFields << customfield_tmp
end
end
unless params['DeliveryConditions'].nil?
@DeliveryConditions = []
params['DeliveryConditions'].each do |i|
deliverycondition_tmp = DeliveryCondition.new
deliverycondition_tmp.deserialize(i)
@DeliveryConditions << deliverycondition_tmp
end
end
@Sample = params['Sample']
unless params['LogFormat'].nil?
@LogFormat = LogFormat.new
@LogFormat.deserialize(params['LogFormat'])
end
unless params['CLS'].nil?
@CLS = CLSTopic.new
@CLS.deserialize(params['CLS'])
end
unless params['CustomEndpoint'].nil?
@CustomEndpoint = CustomEndpoint.new
@CustomEndpoint.deserialize(params['CustomEndpoint'])
end
unless params['S3'].nil?
@S3 = S3.new
@S3.deserialize(params['S3'])
end
end
end
# CreateRealtimeLogDeliveryTask返回参数结构体
class CreateRealtimeLogDeliveryTaskResponse < TencentCloud::Common::AbstractModel
# @param TaskId: 创建成功的任务ID。
# @type TaskId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TaskId, :RequestId
def initialize(taskid=nil, requestid=nil)
@TaskId = taskid
@RequestId = requestid
end
def deserialize(params)
@TaskId = params['TaskId']
@RequestId = params['RequestId']
end
end
# CreateRule请求参数结构体
class CreateRuleRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param RuleName: 规则名称,名称字符串长度 1~255。
# @type RuleName: String
# @param Status: 规则状态,取值有:
# enable: 启用;
# disable: 未启用。
# @type Status: String
# @param Rules: 规则内容。
# @type Rules: Array
# @param Tags: 规则标签。
# @type Tags: Array
attr_accessor :ZoneId, :RuleName, :Status, :Rules, :Tags
def initialize(zoneid=nil, rulename=nil, status=nil, rules=nil, tags=nil)
@ZoneId = zoneid
@RuleName = rulename
@Status = status
@Rules = rules
@Tags = tags
end
def deserialize(params)
@ZoneId = params['ZoneId']
@RuleName = params['RuleName']
@Status = params['Status']
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
rule_tmp = Rule.new
rule_tmp.deserialize(i)
@Rules << rule_tmp
end
end
@Tags = params['Tags']
end
end
# CreateRule返回参数结构体
class CreateRuleResponse < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID。
# @type RuleId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RuleId, :RequestId
def initialize(ruleid=nil, requestid=nil)
@RuleId = ruleid
@RequestId = requestid
end
def deserialize(params)
@RuleId = params['RuleId']
@RequestId = params['RequestId']
end
end
# CreateSecurityIPGroup请求参数结构体
class CreateSecurityIPGroupRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 Id。
# @type ZoneId: String
# @param IPGroup: IP 组信息。
# @type IPGroup: :class:`Tencentcloud::Teo.v20220901.models.IPGroup`
attr_accessor :ZoneId, :IPGroup
def initialize(zoneid=nil, ipgroup=nil)
@ZoneId = zoneid
@IPGroup = ipgroup
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['IPGroup'].nil?
@IPGroup = IPGroup.new
@IPGroup.deserialize(params['IPGroup'])
end
end
end
# CreateSecurityIPGroup返回参数结构体
class CreateSecurityIPGroupResponse < TencentCloud::Common::AbstractModel
# @param GroupId: IP 组 Id。
# @type GroupId: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :GroupId, :RequestId
def initialize(groupid=nil, requestid=nil)
@GroupId = groupid
@RequestId = requestid
end
def deserialize(params)
@GroupId = params['GroupId']
@RequestId = params['RequestId']
end
end
# CreateSharedCNAME请求参数结构体
class CreateSharedCNAMERequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 共享 CNAME 所属站点的 ID。
# @type ZoneId: String
# @param SharedCNAMEPrefix: 共享 CNAME 前缀。请输入合法的域名前缀,例如"test-api"、"test-api.com",限制输入 50 个字符。
# 共享 CNAME 完整格式为:`<自定义前缀>++share.dnse[0-5].com`。
# 例如前缀传入 example.com,EO 会为您创建共享 CNAME:example.com.sai2ig51kaa5.share.dnse2.com。
# @type SharedCNAMEPrefix: String
# @param Description: 描述。可输入 1-50 个任意字符。
# @type Description: String
attr_accessor :ZoneId, :SharedCNAMEPrefix, :Description
def initialize(zoneid=nil, sharedcnameprefix=nil, description=nil)
@ZoneId = zoneid
@SharedCNAMEPrefix = sharedcnameprefix
@Description = description
end
def deserialize(params)
@ZoneId = params['ZoneId']
@SharedCNAMEPrefix = params['SharedCNAMEPrefix']
@Description = params['Description']
end
end
# CreateSharedCNAME返回参数结构体
class CreateSharedCNAMEResponse < TencentCloud::Common::AbstractModel
# @param SharedCNAME: 共享 CNAME。格式为:`<自定义前缀>++share.dnse[0-5].com`。
# @type SharedCNAME: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :SharedCNAME, :RequestId
def initialize(sharedcname=nil, requestid=nil)
@SharedCNAME = sharedcname
@RequestId = requestid
end
def deserialize(params)
@SharedCNAME = params['SharedCNAME']
@RequestId = params['RequestId']
end
end
# CreateZone请求参数结构体
class CreateZoneRequest < TencentCloud::Common::AbstractModel
# @param Type: 站点接入类型。该参数取值如下,不填写时默认为 partial:
# partial:CNAME 接入;
# full:NS 接入;
# noDomainAccess:无域名接入;
# dnsPodAccess:DNSPod 托管接入,该接入模式要求您的域名已托管在 DNSPod 内。
# @type Type: String
# @param ZoneName: 站点名称。CNAME/NS 接入的时,请传入二级域名(example.com)作为站点名称;无域名接入时,该值请保留为空。
# @type ZoneName: String
# @param Area: Type 取值为 partial/full 时,七层域名的加速区域。以下为该参数取值,不填写时该值默认为 overseas。Type 取值为 noDomainAccess 时该值请保留为空:
# global: 全球可用区;
# mainland: 中国大陆可用区;
# overseas: 全球可用区(不含中国大陆)。
# @type Area: String
# @param PlanId: 待绑定的目标套餐 ID。当您账号下已存在套餐时,可以填写此参数,直接将站点绑定至该套餐。若您当前没有可绑定的套餐时,请前往控制台购买套餐完成站点创建。
# @type PlanId: String
# @param AliasZoneName: 同名站点标识。限制输入数字、英文、- 和 _ 组合,长度 20 个字符以内。详情参考 [同名站点标识](https://cloud.tencent.com/document/product/1552/70202),无此使用场景时,该字段保留为空即可。
# @type AliasZoneName: String
# @param Tags: 标签。该参数用于对站点进行分权限管控、分账。需要先前往 [标签控制台](https://console.cloud.tencent.com/tag/taglist) 创建对应的标签才可以在此处传入对应的标签键和标签值。
# @type Tags: Array
# @param AllowDuplicates: 是否允许重复接入。
# true:允许重复接入;
# false:不允许重复接入。不填写使用默认值false。
# @type AllowDuplicates: Boolean
# @param JumpStart: 是否跳过站点现有的DNS记录扫描。默认值:false。
# @type JumpStart: Boolean
attr_accessor :Type, :ZoneName, :Area, :PlanId, :AliasZoneName, :Tags, :AllowDuplicates, :JumpStart
extend Gem::Deprecate
deprecate :AllowDuplicates, :none, 2024, 11
deprecate :AllowDuplicates=, :none, 2024, 11
deprecate :JumpStart, :none, 2024, 11
deprecate :JumpStart=, :none, 2024, 11
def initialize(type=nil, zonename=nil, area=nil, planid=nil, aliaszonename=nil, tags=nil, allowduplicates=nil, jumpstart=nil)
@Type = type
@ZoneName = zonename
@Area = area
@PlanId = planid
@AliasZoneName = aliaszonename
@Tags = tags
@AllowDuplicates = allowduplicates
@JumpStart = jumpstart
end
def deserialize(params)
@Type = params['Type']
@ZoneName = params['ZoneName']
@Area = params['Area']
@PlanId = params['PlanId']
@AliasZoneName = params['AliasZoneName']
unless params['Tags'].nil?
@Tags = []
params['Tags'].each do |i|
tag_tmp = Tag.new
tag_tmp.deserialize(i)
@Tags << tag_tmp
end
end
@AllowDuplicates = params['AllowDuplicates']
@JumpStart = params['JumpStart']
end
end
# CreateZone返回参数结构体
class CreateZoneResponse < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param OwnershipVerification: 站点归属权验证信息。站点完成创建后,您还需要完成归属权校验,站点才能正常服务。
# Type = partial 时,您需要参考 [站点/域名归属权验证](https://cloud.tencent.com/document/product/1552/70789) 前往您的域名解析服务商添加 TXT 记录或者前往根域名服务器添加文件,再调用接口 [VerifyOwnership]() 完成验证;
# Type = full 时,您需要参考 [修改 DNS 服务器](https://cloud.tencent.com/document/product/1552/90452) 切换 DNS 服务器即可,可通过接口 [VerifyOwnership]() 查询 DNS 是否切换成功;
# Type = noDomainAccess 时,该值为空,不需要进行任何操作。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OwnershipVerification: :class:`Tencentcloud::Teo.v20220901.models.OwnershipVerification`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ZoneId, :OwnershipVerification, :RequestId
def initialize(zoneid=nil, ownershipverification=nil, requestid=nil)
@ZoneId = zoneid
@OwnershipVerification = ownershipverification
@RequestId = requestid
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['OwnershipVerification'].nil?
@OwnershipVerification = OwnershipVerification.new
@OwnershipVerification.deserialize(params['OwnershipVerification'])
end
@RequestId = params['RequestId']
end
end
# 实时日志投递到自定义 HTTP(S) 接口的配置信息。
class CustomEndpoint < TencentCloud::Common::AbstractModel
# @param Url: 实时日志投递的自定义 HTTP 接口地址,暂仅支持 HTTP/HTTPS 协议。
# @type Url: String
# @param AccessId: 填写自定义的 SecretId 用于生成加密签名,如果源站需要鉴权此参数必填。
# @type AccessId: String
# @param AccessKey: 填写自定义的 SecretKey 用于生成加密签名,如果源站需要鉴权此参数必填。
# @type AccessKey: String
# @param CompressType: 数据压缩类型,取值有: gzip:使用 gzip 方式压缩。不填表示不启用压缩。
# @type CompressType: String
# @param Protocol: POST 请求投递日志时,使用的应用层协议类型,取值有:
# http:HTTP 协议;
# https:HTTPS 协议。如果不填默认根据填写的 URL 地址解析出协议类型。
# @type Protocol: String
# @param Headers: 投递日志时携带的自定义请求头。若您填写的头部名称为 Content-Type 等 EdgeOne 日志推送默认携带的头部,那么您填写的头部值将覆盖默认值。头部值引用单个变量${batchSize},以获取每次 POST 请求中包含的日志条数。
# @type Headers: Array
attr_accessor :Url, :AccessId, :AccessKey, :CompressType, :Protocol, :Headers
def initialize(url=nil, accessid=nil, accesskey=nil, compresstype=nil, protocol=nil, headers=nil)
@Url = url
@AccessId = accessid
@AccessKey = accesskey
@CompressType = compresstype
@Protocol = protocol
@Headers = headers
end
def deserialize(params)
@Url = params['Url']
@AccessId = params['AccessId']
@AccessKey = params['AccessKey']
@CompressType = params['CompressType']
@Protocol = params['Protocol']
unless params['Headers'].nil?
@Headers = []
params['Headers'].each do |i|
header_tmp = Header.new
header_tmp.deserialize(i)
@Headers << header_tmp
end
end
end
end
# 自定义错误码页面结构体。
class CustomErrorPage < TencentCloud::Common::AbstractModel
# @param PageId: 自定义错误页面 ID。
# @type PageId: String
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Name: 自定义错误页面名称。
# @type Name: String
# @param ContentType: 自定义错误页面类型。
# @type ContentType: String
# @param Description: 自定义错误页面描述。
# @type Description: String
# @param Content: 自定义错误页面内容。
# @type Content: String
# @param References: 自定义错误页面引用。
# @type References: Array
attr_accessor :PageId, :ZoneId, :Name, :ContentType, :Description, :Content, :References
def initialize(pageid=nil, zoneid=nil, name=nil, contenttype=nil, description=nil, content=nil, references=nil)
@PageId = pageid
@ZoneId = zoneid
@Name = name
@ContentType = contenttype
@Description = description
@Content = content
@References = references
end
def deserialize(params)
@PageId = params['PageId']
@ZoneId = params['ZoneId']
@Name = params['Name']
@ContentType = params['ContentType']
@Description = params['Description']
@Content = params['Content']
unless params['References'].nil?
@References = []
params['References'].each do |i|
errorpagereference_tmp = ErrorPageReference.new
errorpagereference_tmp.deserialize(i)
@References << errorpagereference_tmp
end
end
end
end
# 实时日志投递任务中的自定义日志字段。
class CustomField < TencentCloud::Common::AbstractModel
# @param Name: 自定义日志字段类型。从 HTTP 请求和响应中的指定位置提取数据,取值有:
# ReqHeader:从 HTTP 请求头中提取指定字段值;
# RspHeader:从 HTTP 响应头中提取指定字段值;
# Cookie: 从 Cookie 中提取指定字段值;
# ReqBody: 从 HTTP 请求正文中通过 Google RE2 正则表达式提取指定内容。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param Value: 根据字段类型(Name)填入字段值的定义。需要区分大小写。
# 当字段类型为 ReqHeader、RspHeader、Cookie 时,填入需要提取值的参数名称,例如:Accept-Language。可输入 1-100 个字符,允许的字符开头为字母,中间为字母、数字、-,结尾为字母、数字;
# 当字段类型为 ReqBody 时,填入 Google RE2 正则表达式,正则表达式长度上限为 4KB。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Value: String
# @param Enabled: 是否投递该字段,不填表示不投递此字段。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Enabled: Boolean
attr_accessor :Name, :Value, :Enabled
def initialize(name=nil, value=nil, enabled=nil)
@Name = name
@Value = value
@Enabled = enabled
end
def deserialize(params)
@Name = params['Name']
@Value = params['Value']
@Enabled = params['Enabled']
end
end
# 负载均衡实例 HTTP/HTTPS 健康检查策略下可配置的自定义头部。
class CustomizedHeader < TencentCloud::Common::AbstractModel
# @param Key: 自定义头部 Key。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Key: String
# @param Value: 自定义头部 Value。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Value: String
attr_accessor :Key, :Value
def initialize(key=nil, value=nil)
@Key = key
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Value = params['Value']
end
end
# DDoS配置
class DDoS < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# DDoS攻击事件对象
class DDoSAttackEvent < TencentCloud::Common::AbstractModel
# @param EventId: 事件ID。
# @type EventId: String
# @param AttackType: 攻击类型(对应交互事件名称)。
# @type AttackType: String
# @param AttackStatus: 攻击状态。
# @type AttackStatus: Integer
# @param AttackMaxBandWidth: 攻击最大带宽。
# @type AttackMaxBandWidth: Integer
# @param AttackPacketMaxRate: 攻击包速率峰值。
# @type AttackPacketMaxRate: Integer
# @param AttackStartTime: 攻击开始时间,单位为s。
# @type AttackStartTime: Integer
# @param AttackEndTime: 攻击结束时间,单位为s。
# @type AttackEndTime: Integer
# @param PolicyId: DDoS策略组ID。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PolicyId: Integer
# @param ZoneId: 站点ID。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ZoneId: String
# @param Area: 攻击事件所属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Area: String
# @param DDoSBlockData: 封禁解封信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DDoSBlockData: Array
attr_accessor :EventId, :AttackType, :AttackStatus, :AttackMaxBandWidth, :AttackPacketMaxRate, :AttackStartTime, :AttackEndTime, :PolicyId, :ZoneId, :Area, :DDoSBlockData
def initialize(eventid=nil, attacktype=nil, attackstatus=nil, attackmaxbandwidth=nil, attackpacketmaxrate=nil, attackstarttime=nil, attackendtime=nil, policyid=nil, zoneid=nil, area=nil, ddosblockdata=nil)
@EventId = eventid
@AttackType = attacktype
@AttackStatus = attackstatus
@AttackMaxBandWidth = attackmaxbandwidth
@AttackPacketMaxRate = attackpacketmaxrate
@AttackStartTime = attackstarttime
@AttackEndTime = attackendtime
@PolicyId = policyid
@ZoneId = zoneid
@Area = area
@DDoSBlockData = ddosblockdata
end
def deserialize(params)
@EventId = params['EventId']
@AttackType = params['AttackType']
@AttackStatus = params['AttackStatus']
@AttackMaxBandWidth = params['AttackMaxBandWidth']
@AttackPacketMaxRate = params['AttackPacketMaxRate']
@AttackStartTime = params['AttackStartTime']
@AttackEndTime = params['AttackEndTime']
@PolicyId = params['PolicyId']
@ZoneId = params['ZoneId']
@Area = params['Area']
unless params['DDoSBlockData'].nil?
@DDoSBlockData = []
params['DDoSBlockData'].each do |i|
ddosblockdata_tmp = DDoSBlockData.new
ddosblockdata_tmp.deserialize(i)
@DDoSBlockData << ddosblockdata_tmp
end
end
end
end
# DDoS封禁解封信息
class DDoSBlockData < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间,采用unix时间戳。
# @type StartTime: Integer
# @param EndTime: 结束时间,采用unix时间戳, 为0表示还处于封禁中。
# @type EndTime: Integer
# @param BlockArea: 封禁受影响区域。
# @type BlockArea: String
attr_accessor :StartTime, :EndTime, :BlockArea
def initialize(starttime=nil, endtime=nil, blockarea=nil)
@StartTime = starttime
@EndTime = endtime
@BlockArea = blockarea
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@BlockArea = params['BlockArea']
end
end
# 适用于四层代理或 Web 站点服务的独立 DDoS 防护规格配置。
class DDosProtectionConfig < TencentCloud::Common::AbstractModel
# @param LevelMainland: 中国大陆地区独立 DDoS 防护的规格。详情请参考 [独立 DDoS 防护相关费用](https://cloud.tencent.com/document/product/1552/94162)
# PLATFORM:平台默认防护,即不开启独立 DDoS 防护;
# BASE30_MAX300:开启独立 DDoS 防护,提供 30 Gbps 保底防护带宽以及 300 Gbps 弹性防护带宽;
# BASE60_MAX600:开启独立 DDoS 防护,提供 60 Gbps 保底防护带宽以及 600 Gbps 弹性防护带宽。不填写参数时,取默认值 PLATFORM。
# @type LevelMainland: String
# @param MaxBandwidthMainland: 中国大陆地区独立 DDoS 防护的弹性防护带宽配置。
# 仅当开启中国大陆区域独立 DDos 防护时有效(详见 LevelMainland 参数配置),且取值范围有如下限制:
# 开启中国大陆地区独立 DDoS 防护,使用 30 Gbps 保底防护带宽规格时( LevelMainland 参数值为 BASE30_MAX300 ):有效取值范围为 30 至 300,单位为 Gbps;
# 开启中国大陆地区独立 DDoS 防护,使用 60 Gbps 保底防护带宽规格时( LevelMainland 参数值为 BASE60_MAX600 ):有效取值范围为 60 至 600,单位为 Gbps;
# 使用平台默认防护( LevelMainland 参数值为 PLATFORM ):不支持配置,本参数值无效。
# @type MaxBandwidthMainland: Integer
# @param LevelOverseas: 全球(除中国大陆以外)地区独立 DDoS 防护的规格。
# PLATFORM:平台默认防护,即不开启独立 DDoS 防护;
# ANYCAST300:开启独立 DDoS 防护,提供 300 Gbps 防护带宽;
# ANYCAST_ALLIN:开启独立 DDoS 防护,使用全部可用防护资源进行防护。不填写参数时,取默认值 PLATFORM。
# @type LevelOverseas: String
attr_accessor :LevelMainland, :MaxBandwidthMainland, :LevelOverseas
def initialize(levelmainland=nil, maxbandwidthmainland=nil, leveloverseas=nil)
@LevelMainland = levelmainland
@MaxBandwidthMainland = maxbandwidthmainland
@LevelOverseas = leveloverseas
end
def deserialize(params)
@LevelMainland = params['LevelMainland']
@MaxBandwidthMainland = params['MaxBandwidthMainland']
@LevelOverseas = params['LevelOverseas']
end
end
# https 服务端证书配置
class DefaultServerCertInfo < TencentCloud::Common::AbstractModel
# @param CertId: 服务器证书 ID。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CertId: String
# @param Alias: 证书备注名。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Alias: String
# @param Type: 证书类型,取值有:
# default: 默认证书;
# upload:用户上传;
# managed:腾讯云托管。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param ExpireTime: 证书过期时间。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExpireTime: String
# @param EffectiveTime: 证书生效时间。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EffectiveTime: String
# @param CommonName: 证书公用名。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CommonName: String
# @param SubjectAltName: 证书SAN域名。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SubjectAltName: Array
# @param Status: 部署状态,取值有:
# processing: 部署中;
# deployed: 已部署;
# failed: 部署失败。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Status: String
# @param Message: Status为失败时,此字段返回失败原因。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Message: String
# @param SignAlgo: 证书算法。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SignAlgo: String
attr_accessor :CertId, :Alias, :Type, :ExpireTime, :EffectiveTime, :CommonName, :SubjectAltName, :Status, :Message, :SignAlgo
def initialize(certid=nil, _alias=nil, type=nil, expiretime=nil, effectivetime=nil, commonname=nil, subjectaltname=nil, status=nil, message=nil, signalgo=nil)
@CertId = certid
@Alias = _alias
@Type = type
@ExpireTime = expiretime
@EffectiveTime = effectivetime
@CommonName = commonname
@SubjectAltName = subjectaltname
@Status = status
@Message = message
@SignAlgo = signalgo
end
def deserialize(params)
@CertId = params['CertId']
@Alias = params['Alias']
@Type = params['Type']
@ExpireTime = params['ExpireTime']
@EffectiveTime = params['EffectiveTime']
@CommonName = params['CommonName']
@SubjectAltName = params['SubjectAltName']
@Status = params['Status']
@Message = params['Message']
@SignAlgo = params['SignAlgo']
end
end
# DeleteAccelerationDomains请求参数结构体
class DeleteAccelerationDomainsRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 加速域名所属站点ID。
# @type ZoneId: String
# @param DomainNames: 需要删除的加速域名ID列表。
# @type DomainNames: Array
# @param Force: 是否强制删除。当域名存在关联资源(如马甲域名、流量调度功能)时,是否强制删除该域名,取值有:
# true:删除该域名及所有关联资源;
# false:当该加速域名存在关联资源时,不允许删除。不填写,默认值为:false。
# @type Force: Boolean
attr_accessor :ZoneId, :DomainNames, :Force
def initialize(zoneid=nil, domainnames=nil, force=nil)
@ZoneId = zoneid
@DomainNames = domainnames
@Force = force
end
def deserialize(params)
@ZoneId = params['ZoneId']
@DomainNames = params['DomainNames']
@Force = params['Force']
end
end
# DeleteAccelerationDomains返回参数结构体
class DeleteAccelerationDomainsResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteAliasDomain请求参数结构体
class DeleteAliasDomainRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param AliasNames: 待删除别称域名名称。如果为空,则不执行删除操作。
# @type AliasNames: Array
attr_accessor :ZoneId, :AliasNames
def initialize(zoneid=nil, aliasnames=nil)
@ZoneId = zoneid
@AliasNames = aliasnames
end
def deserialize(params)
@ZoneId = params['ZoneId']
@AliasNames = params['AliasNames']
end
end
# DeleteAliasDomain返回参数结构体
class DeleteAliasDomainResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteApplicationProxy请求参数结构体
class DeleteApplicationProxyRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param ProxyId: 代理ID。
# @type ProxyId: String
attr_accessor :ZoneId, :ProxyId
def initialize(zoneid=nil, proxyid=nil)
@ZoneId = zoneid
@ProxyId = proxyid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
end
end
# DeleteApplicationProxy返回参数结构体
class DeleteApplicationProxyResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteApplicationProxyRule请求参数结构体
class DeleteApplicationProxyRuleRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param ProxyId: 代理ID。
# @type ProxyId: String
# @param RuleId: 规则ID。
# @type RuleId: String
attr_accessor :ZoneId, :ProxyId, :RuleId
def initialize(zoneid=nil, proxyid=nil, ruleid=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@RuleId = ruleid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@RuleId = params['RuleId']
end
end
# DeleteApplicationProxyRule返回参数结构体
class DeleteApplicationProxyRuleResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteCustomErrorPage请求参数结构体
class DeleteCustomErrorPageRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param PageId: 自定义页面 ID。
# @type PageId: String
attr_accessor :ZoneId, :PageId
def initialize(zoneid=nil, pageid=nil)
@ZoneId = zoneid
@PageId = pageid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@PageId = params['PageId']
end
end
# DeleteCustomErrorPage返回参数结构体
class DeleteCustomErrorPageResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteFunction请求参数结构体
class DeleteFunctionRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param FunctionId: 函数 ID。
# @type FunctionId: String
attr_accessor :ZoneId, :FunctionId
def initialize(zoneid=nil, functionid=nil)
@ZoneId = zoneid
@FunctionId = functionid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@FunctionId = params['FunctionId']
end
end
# DeleteFunction返回参数结构体
class DeleteFunctionResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteFunctionRules请求参数结构体
class DeleteFunctionRulesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param RuleIds: 规则 ID 列表。
# @type RuleIds: Array
attr_accessor :ZoneId, :RuleIds
def initialize(zoneid=nil, ruleids=nil)
@ZoneId = zoneid
@RuleIds = ruleids
end
def deserialize(params)
@ZoneId = params['ZoneId']
@RuleIds = params['RuleIds']
end
end
# DeleteFunctionRules返回参数结构体
class DeleteFunctionRulesResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteL4Proxy请求参数结构体
class DeleteL4ProxyRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
attr_accessor :ZoneId, :ProxyId
def initialize(zoneid=nil, proxyid=nil)
@ZoneId = zoneid
@ProxyId = proxyid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
end
end
# DeleteL4Proxy返回参数结构体
class DeleteL4ProxyResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteL4ProxyRules请求参数结构体
class DeleteL4ProxyRulesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
# @param RuleIds: 转发规则 ID 列表。单次最多支持 200 条转发规则。
# @type RuleIds: Array
attr_accessor :ZoneId, :ProxyId, :RuleIds
def initialize(zoneid=nil, proxyid=nil, ruleids=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@RuleIds = ruleids
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@RuleIds = params['RuleIds']
end
end
# DeleteL4ProxyRules返回参数结构体
class DeleteL4ProxyRulesResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteLoadBalancer请求参数结构体
class DeleteLoadBalancerRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param InstanceId: 负载均衡实例 ID。
# @type InstanceId: String
attr_accessor :ZoneId, :InstanceId
def initialize(zoneid=nil, instanceid=nil)
@ZoneId = zoneid
@InstanceId = instanceid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@InstanceId = params['InstanceId']
end
end
# DeleteLoadBalancer返回参数结构体
class DeleteLoadBalancerResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteOriginGroup请求参数结构体
class DeleteOriginGroupRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID
# @type ZoneId: String
# @param GroupId: 源站组 ID,此参数必填。
# @type GroupId: String
attr_accessor :ZoneId, :GroupId
def initialize(zoneid=nil, groupid=nil)
@ZoneId = zoneid
@GroupId = groupid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@GroupId = params['GroupId']
end
end
# DeleteOriginGroup返回参数结构体
class DeleteOriginGroupResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteRealtimeLogDeliveryTask请求参数结构体
class DeleteRealtimeLogDeliveryTaskRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param TaskId: 实时日志投递任务 ID。
# @type TaskId: String
attr_accessor :ZoneId, :TaskId
def initialize(zoneid=nil, taskid=nil)
@ZoneId = zoneid
@TaskId = taskid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@TaskId = params['TaskId']
end
end
# DeleteRealtimeLogDeliveryTask返回参数结构体
class DeleteRealtimeLogDeliveryTaskResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteRules请求参数结构体
class DeleteRulesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param RuleIds: 指定删除的规则 ID 列表。
# @type RuleIds: Array
attr_accessor :ZoneId, :RuleIds
def initialize(zoneid=nil, ruleids=nil)
@ZoneId = zoneid
@RuleIds = ruleids
end
def deserialize(params)
@ZoneId = params['ZoneId']
@RuleIds = params['RuleIds']
end
end
# DeleteRules返回参数结构体
class DeleteRulesResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteSecurityIPGroup请求参数结构体
class DeleteSecurityIPGroupRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 Id。
# @type ZoneId: String
# @param GroupId: IP 组 Id。
# @type GroupId: Integer
attr_accessor :ZoneId, :GroupId
def initialize(zoneid=nil, groupid=nil)
@ZoneId = zoneid
@GroupId = groupid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@GroupId = params['GroupId']
end
end
# DeleteSecurityIPGroup返回参数结构体
class DeleteSecurityIPGroupResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteSharedCNAME请求参数结构体
class DeleteSharedCNAMERequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 共享 CNAME 所属站点 ID。
# @type ZoneId: String
# @param SharedCNAME: 需要删除的共享 CNAME。
# @type SharedCNAME: String
attr_accessor :ZoneId, :SharedCNAME
def initialize(zoneid=nil, sharedcname=nil)
@ZoneId = zoneid
@SharedCNAME = sharedcname
end
def deserialize(params)
@ZoneId = params['ZoneId']
@SharedCNAME = params['SharedCNAME']
end
end
# DeleteSharedCNAME返回参数结构体
class DeleteSharedCNAMEResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# DeleteZone请求参数结构体
class DeleteZoneRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
attr_accessor :ZoneId
def initialize(zoneid=nil)
@ZoneId = zoneid
end
def deserialize(params)
@ZoneId = params['ZoneId']
end
end
# DeleteZone返回参数结构体
class DeleteZoneResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# 实时日志投递条件,用于定义投递日志范围。DeliveryCondition 数组内多个项的关系为“或”,内层 Conditions 数组内多个项的关系为“且”。
class DeliveryCondition < TencentCloud::Common::AbstractModel
# @param Conditions: 日志过滤条件,详细的过滤条件如下:
# EdgeResponseStatusCode:按照 EdgeOne 节点响应返回给客户端的状态码进行过滤。
支持运算符:equal、great、less、great_equal、less_equal
取值范围:任意大于等于 0 的整数
# OriginResponseStatusCode:按照源站响应状态码进行过滤。
支持运算符:equal、great、less、great_equal、less_equal
取值范围:任意大于等于 -1 的整数
# SecurityAction:按照请求命中安全规则后的最终处置动作进行过滤。
支持运算符:equal
可选项如下:
-:未知/未命中
Monitor:观察
JSChallenge:JavaScript 挑战
Deny:拦截
Allow:放行
BlockIP:IP 封禁
Redirect:重定向
ReturnCustomPage:返回自定义页面
ManagedChallenge:托管挑战
Silence:静默
LongDelay:长时间等待后响应
ShortDelay:短时间等待后响应
# SecurityModule:按照最终处置请求的安全模块名称进行过滤。
支持运算符:equal
可选项如下:
-:未知/未命中
CustomRule:Web防护 - 自定义规则
RateLimitingCustomRule:Web防护 - 速率限制规则
ManagedRule:Web防护 - 托管规则
L7DDoS:Web防护 - CC攻击防护
BotManagement:Bot管理 - Bot基础管理
BotClientReputation:Bot管理 - 客户端画像分析
BotBehaviorAnalysis:Bot管理 - Bot智能分析
BotCustomRule:Bot管理 - 自定义Bot规则
BotActiveDetection:Bot管理 - 主动特征识别
# @type Conditions: Array
attr_accessor :Conditions
def initialize(conditions=nil)
@Conditions = conditions
end
def deserialize(params)
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
querycondition_tmp = QueryCondition.new
querycondition_tmp.deserialize(i)
@Conditions << querycondition_tmp
end
end
end
end
# DeployConfigGroupVersion请求参数结构体
class DeployConfigGroupVersionRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param EnvId: 环境 ID。请填写版本需要发布到的环境 ID。
# @type EnvId: String
# @param ConfigGroupVersionInfos: 需要发布的版本信息。可以同时变更多个不同配置组的版本,每个配置组一次仅支持变更一个版本。
# @type ConfigGroupVersionInfos: Array
# @param Description: 变更说明。用于描述此次变更的内容、原因,最大支持 100 个字符。
# @type Description: String
attr_accessor :ZoneId, :EnvId, :ConfigGroupVersionInfos, :Description
def initialize(zoneid=nil, envid=nil, configgroupversioninfos=nil, description=nil)
@ZoneId = zoneid
@EnvId = envid
@ConfigGroupVersionInfos = configgroupversioninfos
@Description = description
end
def deserialize(params)
@ZoneId = params['ZoneId']
@EnvId = params['EnvId']
unless params['ConfigGroupVersionInfos'].nil?
@ConfigGroupVersionInfos = []
params['ConfigGroupVersionInfos'].each do |i|
configgroupversioninfo_tmp = ConfigGroupVersionInfo.new
configgroupversioninfo_tmp.deserialize(i)
@ConfigGroupVersionInfos << configgroupversioninfo_tmp
end
end
@Description = params['Description']
end
end
# DeployConfigGroupVersion返回参数结构体
class DeployConfigGroupVersionResponse < TencentCloud::Common::AbstractModel
# @param RecordId: 发布记录 ID。
# @type RecordId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RecordId, :RequestId
def initialize(recordid=nil, requestid=nil)
@RecordId = recordid
@RequestId = requestid
end
def deserialize(params)
@RecordId = params['RecordId']
@RequestId = params['RequestId']
end
end
# 配置组版本发布记录详情。
class DeployRecord < TencentCloud::Common::AbstractModel
# @param ConfigGroupVersionInfos: 发布版本的详细信息。
# @type ConfigGroupVersionInfos: Array
# @param DeployTime: 发布时间。时间为世界标准时间(UTC), 遵循 ISO 8601 标准的日期和时间格式。
# @type DeployTime: String
# @param Status: 发布状态,取值有:
# deploying :发布中;
# failure :发布失败;
# success: 发布成功。
# @type Status: String
# @param Message: 发布结果信息。
# @type Message: String
# @param RecordId: 发布记录 ID。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RecordId: String
# @param Description: 变更说明。
# @type Description: String
attr_accessor :ConfigGroupVersionInfos, :DeployTime, :Status, :Message, :RecordId, :Description
def initialize(configgroupversioninfos=nil, deploytime=nil, status=nil, message=nil, recordid=nil, description=nil)
@ConfigGroupVersionInfos = configgroupversioninfos
@DeployTime = deploytime
@Status = status
@Message = message
@RecordId = recordid
@Description = description
end
def deserialize(params)
unless params['ConfigGroupVersionInfos'].nil?
@ConfigGroupVersionInfos = []
params['ConfigGroupVersionInfos'].each do |i|
configgroupversioninfo_tmp = ConfigGroupVersionInfo.new
configgroupversioninfo_tmp.deserialize(i)
@ConfigGroupVersionInfos << configgroupversioninfo_tmp
end
end
@DeployTime = params['DeployTime']
@Status = params['Status']
@Message = params['Message']
@RecordId = params['RecordId']
@Description = params['Description']
end
end
# DescribeAccelerationDomains请求参数结构体
class DescribeAccelerationDomainsRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 加速域名所属站点 ID。
# @type ZoneId: String
# @param Offset: 分页查询偏移量,默认为 0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目,默认值:20,上限:200。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values 的上限为 20。该参数不填写时,返回当前 zone-id 下所有域名信息。详细的过滤条件如下:
# domain-name:按照加速域名进行过滤;
# origin-type:按照源站类型进行过滤;
# origin:按照主源站地址进行过滤;
# backup-origin: 按照备用源站地址进行过滤;
# domain-cname:按照 CNAME 进行过滤;
# share-cname:按照共享 CNAME 进行过滤;
# @type Filters: Array
# @param Order: 可根据该字段对返回结果进行排序,取值有:
# created_on:加速域名创建时间;
# domain-name:加速域名。不填写时,默认对返回结果按照 domain-name 排序。
# @type Order: String
# @param Direction: 排序方向,如果是字段值为数字,则根据数字大小排序;如果字段值为文本,则根据 ascill 码的大小排序。取值有:
# asc:升序排列;
# desc:降序排列。不填写使用默认值 asc。
# @type Direction: String
# @param Match: 匹配方式,取值有:
# all:返回匹配所有查询条件的加速域名;
# any:返回匹配任意一个查询条件的加速域名。不填写时默认值为 all。
# @type Match: String
attr_accessor :ZoneId, :Offset, :Limit, :Filters, :Order, :Direction, :Match
def initialize(zoneid=nil, offset=nil, limit=nil, filters=nil, order=nil, direction=nil, match=nil)
@ZoneId = zoneid
@Offset = offset
@Limit = limit
@Filters = filters
@Order = order
@Direction = direction
@Match = match
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
@Order = params['Order']
@Direction = params['Direction']
@Match = params['Match']
end
end
# DescribeAccelerationDomains返回参数结构体
class DescribeAccelerationDomainsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 符合查询条件的加速域名个数。
# @type TotalCount: Integer
# @param AccelerationDomains: 符合查询条件的所有加速域名的信息。
# @type AccelerationDomains: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :AccelerationDomains, :RequestId
def initialize(totalcount=nil, accelerationdomains=nil, requestid=nil)
@TotalCount = totalcount
@AccelerationDomains = accelerationdomains
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['AccelerationDomains'].nil?
@AccelerationDomains = []
params['AccelerationDomains'].each do |i|
accelerationdomain_tmp = AccelerationDomain.new
accelerationdomain_tmp.deserialize(i)
@AccelerationDomains << accelerationdomain_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeAliasDomains请求参数结构体
class DescribeAliasDomainsRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Offset: 分页查询偏移量。默认值:0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:1000。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values的上限为20。详细的过滤条件如下:
# target-name:目标域名名称进行过滤;
# alias-name:按照别称域名名称进行过滤。模糊查询时仅支持过滤字段名为 alias-name。
# @type Filters: Array
attr_accessor :ZoneId, :Offset, :Limit, :Filters
def initialize(zoneid=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
end
end
# DescribeAliasDomains返回参数结构体
class DescribeAliasDomainsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 符合条件的别称域名个数。
# @type TotalCount: Integer
# @param AliasDomains: 别称域名详细信息列表。
# @type AliasDomains: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :AliasDomains, :RequestId
def initialize(totalcount=nil, aliasdomains=nil, requestid=nil)
@TotalCount = totalcount
@AliasDomains = aliasdomains
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['AliasDomains'].nil?
@AliasDomains = []
params['AliasDomains'].each do |i|
aliasdomain_tmp = AliasDomain.new
aliasdomain_tmp.deserialize(i)
@AliasDomains << aliasdomain_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeApplicationProxies请求参数结构体
class DescribeApplicationProxiesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。该参数必填。
# @type ZoneId: String
# @param Filters: 过滤条件,Filters.Values的上限为20。详细的过滤条件如下:proxy-id
按照【代理ID】进行过滤。代理ID形如:proxy-ev2sawbwfd。
类型:String
必选:否zone-id
按照【站点ID】进行过滤。站点ID形如:zone-vawer2vadg。
类型:String
必选:否rule-tag
按照【规则标签】对应用代理下的规则进行过滤。规则标签形如:rule-service-1。
类型:String
必选:否
# @type Filters: Array
# @param Offset: 分页查询偏移量。默认为0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:1000。
# @type Limit: Integer
attr_accessor :ZoneId, :Filters, :Offset, :Limit
def initialize(zoneid=nil, filters=nil, offset=nil, limit=nil)
@ZoneId = zoneid
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeApplicationProxies返回参数结构体
class DescribeApplicationProxiesResponse < TencentCloud::Common::AbstractModel
# @param ApplicationProxies: 应用代理列表。
# @type ApplicationProxies: Array
# @param TotalCount: 记录总数。
# @type TotalCount: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ApplicationProxies, :TotalCount, :RequestId
def initialize(applicationproxies=nil, totalcount=nil, requestid=nil)
@ApplicationProxies = applicationproxies
@TotalCount = totalcount
@RequestId = requestid
end
def deserialize(params)
unless params['ApplicationProxies'].nil?
@ApplicationProxies = []
params['ApplicationProxies'].each do |i|
applicationproxy_tmp = ApplicationProxy.new
applicationproxy_tmp.deserialize(i)
@ApplicationProxies << applicationproxy_tmp
end
end
@TotalCount = params['TotalCount']
@RequestId = params['RequestId']
end
end
# DescribeAvailablePlans请求参数结构体
class DescribeAvailablePlansRequest < TencentCloud::Common::AbstractModel
def initialize()
end
def deserialize(params)
end
end
# DescribeAvailablePlans返回参数结构体
class DescribeAvailablePlansResponse < TencentCloud::Common::AbstractModel
# @param PlanInfo: 当前账户可购买套餐类型及相关信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PlanInfo: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PlanInfo, :RequestId
def initialize(planinfo=nil, requestid=nil)
@PlanInfo = planinfo
@RequestId = requestid
end
def deserialize(params)
unless params['PlanInfo'].nil?
@PlanInfo = []
params['PlanInfo'].each do |i|
planinfo_tmp = PlanInfo.new
planinfo_tmp.deserialize(i)
@PlanInfo << planinfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeBillingData请求参数结构体
class DescribeBillingDataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 起始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param ZoneIds: 站点 ID 集合,此参数必填。
# @type ZoneIds: Array
# @param MetricName: 指标列表,取值有:
# acc_flux: 内容加速流量,单位为 Byte;
# smt_flux: 智能加速流量,单位为 Byte;
# l4_flux: 四层加速流量,单位为 Byte;
# sec_flux: 独立防护流量,单位为 Byte;
# zxctg_flux: 中国大陆网络优化流量,单位为 Byte;
# acc_bandwidth: 内容加速带宽,单位为 bps;
# smt_bandwidth: 智能加速带宽,单位为 bps;
# l4_bandwidth: 四层加速带宽,单位为 bps;
# sec_bandwidth: 独立防护带宽,单位为 bps;
# zxctg_bandwidth: 中国大陆网络优化带宽,单位为 bps;
# sec_request_clean: HTTP/HTTPS 请求,单位为次;
# smt_request_clean: 智能加速请求,单位为次;
# quic_request: QUIC 请求,单位为次;
# bot_request_clean: Bot 请求,单位为次;
# cls_count: 实时日志推送条数,单位为条;
# ddos_bandwidth: 弹性 DDoS 防护带宽,单位为 bps。
# @type MetricName: String
# @param Interval: 查询时间粒度,取值有:
# 5min:5 分钟粒度;
# hour:1 小时粒度;
# day:1 天粒度。
# @type Interval: String
# @param Filters: 过滤条件,详细的过滤条件取值如下:
# host:按照域名进行过滤。示例值:test.example.com。
# proxy-id:按照四层代理实例 ID 进行过滤。示例值:sid-2rugn89bkla9。
# region-id:按照计费大区进行过滤。可选项如下:
CH:中国大陆境内
AF:非洲
AS1:亚太一区
AS2:亚太二区
AS3:亚太三区
EU:欧洲
MidEast:中东
NA:北美
SA:南美
# @type Filters: Array
attr_accessor :StartTime, :EndTime, :ZoneIds, :MetricName, :Interval, :Filters
def initialize(starttime=nil, endtime=nil, zoneids=nil, metricname=nil, interval=nil, filters=nil)
@StartTime = starttime
@EndTime = endtime
@ZoneIds = zoneids
@MetricName = metricname
@Interval = interval
@Filters = filters
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@ZoneIds = params['ZoneIds']
@MetricName = params['MetricName']
@Interval = params['Interval']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
billingdatafilter_tmp = BillingDataFilter.new
billingdatafilter_tmp.deserialize(i)
@Filters << billingdatafilter_tmp
end
end
end
end
# DescribeBillingData返回参数结构体
class DescribeBillingDataResponse < TencentCloud::Common::AbstractModel
# @param Data: 数据点列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Data, :RequestId
def initialize(data=nil, requestid=nil)
@Data = data
@RequestId = requestid
end
def deserialize(params)
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
billingdata_tmp = BillingData.new
billingdata_tmp.deserialize(i)
@Data << billingdata_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeConfigGroupVersionDetail请求参数结构体
class DescribeConfigGroupVersionDetailRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param VersionId: 版本 ID。
# @type VersionId: String
attr_accessor :ZoneId, :VersionId
def initialize(zoneid=nil, versionid=nil)
@ZoneId = zoneid
@VersionId = versionid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@VersionId = params['VersionId']
end
end
# DescribeConfigGroupVersionDetail返回参数结构体
class DescribeConfigGroupVersionDetailResponse < TencentCloud::Common::AbstractModel
# @param ConfigGroupVersionInfo: 版本信息。
# @type ConfigGroupVersionInfo: :class:`Tencentcloud::Teo.v20220901.models.ConfigGroupVersionInfo`
# @param Content: 版本文件的内容。以 JSON 格式返回。
# @type Content: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ConfigGroupVersionInfo, :Content, :RequestId
def initialize(configgroupversioninfo=nil, content=nil, requestid=nil)
@ConfigGroupVersionInfo = configgroupversioninfo
@Content = content
@RequestId = requestid
end
def deserialize(params)
unless params['ConfigGroupVersionInfo'].nil?
@ConfigGroupVersionInfo = ConfigGroupVersionInfo.new
@ConfigGroupVersionInfo.deserialize(params['ConfigGroupVersionInfo'])
end
@Content = params['Content']
@RequestId = params['RequestId']
end
end
# DescribeConfigGroupVersions请求参数结构体
class DescribeConfigGroupVersionsRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param GroupId: 配置组 ID。
# @type GroupId: String
# @param Filters: 过滤条件,Filters.Values 的上限为 20,该参数不填写时,返回所选配置组下的所有版本信息。详细的过滤条件如下:
# version-id:按照版本 ID 进行过滤;
# @type Filters: Array
# @param Offset: 分页查询偏移量。默认值为 0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值为 20,最大值为 100。
# @type Limit: Integer
attr_accessor :ZoneId, :GroupId, :Filters, :Offset, :Limit
def initialize(zoneid=nil, groupid=nil, filters=nil, offset=nil, limit=nil)
@ZoneId = zoneid
@GroupId = groupid
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
@ZoneId = params['ZoneId']
@GroupId = params['GroupId']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeConfigGroupVersions返回参数结构体
class DescribeConfigGroupVersionsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 版本总数。
# @type TotalCount: Integer
# @param ConfigGroupVersionInfos: 版本信息列表。
# @type ConfigGroupVersionInfos: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :ConfigGroupVersionInfos, :RequestId
def initialize(totalcount=nil, configgroupversioninfos=nil, requestid=nil)
@TotalCount = totalcount
@ConfigGroupVersionInfos = configgroupversioninfos
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['ConfigGroupVersionInfos'].nil?
@ConfigGroupVersionInfos = []
params['ConfigGroupVersionInfos'].each do |i|
configgroupversioninfo_tmp = ConfigGroupVersionInfo.new
configgroupversioninfo_tmp.deserialize(i)
@ConfigGroupVersionInfos << configgroupversioninfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeContentQuota请求参数结构体
class DescribeContentQuotaRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
attr_accessor :ZoneId
def initialize(zoneid=nil)
@ZoneId = zoneid
end
def deserialize(params)
@ZoneId = params['ZoneId']
end
end
# DescribeContentQuota返回参数结构体
class DescribeContentQuotaResponse < TencentCloud::Common::AbstractModel
# @param PurgeQuota: 刷新相关配额。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PurgeQuota: Array
# @param PrefetchQuota: 预热相关配额。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PrefetchQuota: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PurgeQuota, :PrefetchQuota, :RequestId
def initialize(purgequota=nil, prefetchquota=nil, requestid=nil)
@PurgeQuota = purgequota
@PrefetchQuota = prefetchquota
@RequestId = requestid
end
def deserialize(params)
unless params['PurgeQuota'].nil?
@PurgeQuota = []
params['PurgeQuota'].each do |i|
quota_tmp = Quota.new
quota_tmp.deserialize(i)
@PurgeQuota << quota_tmp
end
end
unless params['PrefetchQuota'].nil?
@PrefetchQuota = []
params['PrefetchQuota'].each do |i|
quota_tmp = Quota.new
quota_tmp.deserialize(i)
@PrefetchQuota << quota_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeCustomErrorPages请求参数结构体
class DescribeCustomErrorPagesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Filters: 过滤条件,Filters.Values 的上限为20,详细的过滤条件Name值如下:
# page-id: 按照页面 ID 进行过滤;
# name: 按照页面名称进行过滤;
# description:按照页面描述过滤;
# content-type:按照页面类型过滤。
# @type Filters: Array
# @param Offset: 分页查询偏移量。默认值:0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:1000。
# @type Limit: Integer
attr_accessor :ZoneId, :Filters, :Offset, :Limit
def initialize(zoneid=nil, filters=nil, offset=nil, limit=nil)
@ZoneId = zoneid
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeCustomErrorPages返回参数结构体
class DescribeCustomErrorPagesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 自定义错误页面总数。
# @type TotalCount: Integer
# @param ErrorPages: 自定义错误页面数据列表。
# @type ErrorPages: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :ErrorPages, :RequestId
def initialize(totalcount=nil, errorpages=nil, requestid=nil)
@TotalCount = totalcount
@ErrorPages = errorpages
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['ErrorPages'].nil?
@ErrorPages = []
params['ErrorPages'].each do |i|
customerrorpage_tmp = CustomErrorPage.new
customerrorpage_tmp.deserialize(i)
@ErrorPages << customerrorpage_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeDDoSAttackData请求参数结构体
class DescribeDDoSAttackDataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param MetricNames: 统计指标列表,取值有:
# ddos_attackMaxBandwidth:攻击带宽峰值;
# ddos_attackMaxPackageRate:攻击包速率峰值 ;
# ddos_attackBandwidth:攻击带宽曲线;
# ddos_attackPackageRate:攻击包速率曲线。
# @type MetricNames: Array
# @param ZoneIds: 站点集合,此参数必填。
# @type ZoneIds: Array
# @param PolicyIds: DDoS策略组ID列表,不填默认选择全部策略ID。
# @type PolicyIds: Array
# @param Interval: 查询时间粒度,取值有:
# min:1分钟;
# 5min:5分钟;
# hour:1小时;
# day:1天。不填将根据开始时间与结束时间的间隔自动推算粒度,具体为:1小时范围内以min粒度查询,2天范围内以5min粒度查询,7天范围内以hour粒度查询,超过7天以day粒度查询。
# @type Interval: String
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据;
# global:全球数据。不填默认取值为global。
# @type Area: String
attr_accessor :StartTime, :EndTime, :MetricNames, :ZoneIds, :PolicyIds, :Interval, :Area
def initialize(starttime=nil, endtime=nil, metricnames=nil, zoneids=nil, policyids=nil, interval=nil, area=nil)
@StartTime = starttime
@EndTime = endtime
@MetricNames = metricnames
@ZoneIds = zoneids
@PolicyIds = policyids
@Interval = interval
@Area = area
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MetricNames = params['MetricNames']
@ZoneIds = params['ZoneIds']
@PolicyIds = params['PolicyIds']
@Interval = params['Interval']
@Area = params['Area']
end
end
# DescribeDDoSAttackData返回参数结构体
class DescribeDDoSAttackDataResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: DDoS攻击数据内容列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
secentry_tmp = SecEntry.new
secentry_tmp.deserialize(i)
@Data << secentry_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeDDoSAttackEvent请求参数结构体
class DescribeDDoSAttackEventRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间,时间范围为 30 天。
# @type StartTime: String
# @param EndTime: 结束时间,时间范围为 30 天。
# @type EndTime: String
# @param PolicyIds: ddos策略组集合,不填默认选择全部策略。
# @type PolicyIds: Array
# @param ZoneIds: 站点集合,此参数必填。
# @type ZoneIds: Array
# @param Limit: 分页查询的限制数目,默认值为20,最大查询条目为1000。
# @type Limit: Integer
# @param Offset: 分页的偏移量,默认值为0。
# @type Offset: Integer
# @param ShowDetail: 展示攻击详情的参数,若填false,默认只返回攻击次数,不返回攻击详情;若填true,返回攻击详情。
# @type ShowDetail: Boolean
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据;
# global:全球数据;不填默认取值为global。
# @type Area: String
# @param OrderBy: 排序字段,取值有:
# MaxBandWidth:带宽峰值;
# AttackStartTime:攻击开始时间。不填默认值为:AttackStartTime。
# @type OrderBy: String
# @param OrderType: 排序方式,取值有:
# asc:升序方式;
# desc:降序方式。不填默认值为:desc。
# @type OrderType: String
attr_accessor :StartTime, :EndTime, :PolicyIds, :ZoneIds, :Limit, :Offset, :ShowDetail, :Area, :OrderBy, :OrderType
def initialize(starttime=nil, endtime=nil, policyids=nil, zoneids=nil, limit=nil, offset=nil, showdetail=nil, area=nil, orderby=nil, ordertype=nil)
@StartTime = starttime
@EndTime = endtime
@PolicyIds = policyids
@ZoneIds = zoneids
@Limit = limit
@Offset = offset
@ShowDetail = showdetail
@Area = area
@OrderBy = orderby
@OrderType = ordertype
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@PolicyIds = params['PolicyIds']
@ZoneIds = params['ZoneIds']
@Limit = params['Limit']
@Offset = params['Offset']
@ShowDetail = params['ShowDetail']
@Area = params['Area']
@OrderBy = params['OrderBy']
@OrderType = params['OrderType']
end
end
# DescribeDDoSAttackEvent返回参数结构体
class DescribeDDoSAttackEventResponse < TencentCloud::Common::AbstractModel
# @param Data: DDOS攻击事件数据列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Data, :TotalCount, :RequestId
def initialize(data=nil, totalcount=nil, requestid=nil)
@Data = data
@TotalCount = totalcount
@RequestId = requestid
end
def deserialize(params)
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
ddosattackevent_tmp = DDoSAttackEvent.new
ddosattackevent_tmp.deserialize(i)
@Data << ddosattackevent_tmp
end
end
@TotalCount = params['TotalCount']
@RequestId = params['RequestId']
end
end
# DescribeDDoSAttackTopData请求参数结构体
class DescribeDDoSAttackTopDataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param MetricName: 查询的统计指标,取值有:
# ddos_attackFlux_protocol:按各协议的攻击流量排行;
# ddos_attackPackageNum_protocol:按各协议的攻击包量排行;
# ddos_attackNum_attackType:按各攻击类型的攻击数量排行;
# ddos_attackNum_sregion:按攻击源地区的攻击数量排行;
# ddos_attackFlux_sip:按攻击源IP的攻击数量排行;
# ddos_attackFlux_sregion:按攻击源地区的攻击数量排行。
# @type MetricName: String
# @param ZoneIds: 站点ID集合,此参数必填。
# @type ZoneIds: Array
# @param PolicyIds: DDoS策略组ID集合,不填默认选择全部策略ID。
# @type PolicyIds: Array
# @param AttackType: 攻击类型,取值有:
# flood:洪泛攻击;
# icmpFlood:icmp洪泛攻击;
# all:所有的攻击类型。不填默认为all,表示查询全部攻击类型。
# @type AttackType: String
# @param ProtocolType: 协议类型,取值有:
# tcp:tcp协议;
# udp:udp协议;
# all:所有的协议类型。不填默认为all,表示查询所有协议。
# @type ProtocolType: String
# @param Port: 端口号。
# @type Port: Integer
# @param Limit: 查询前多少个数据,不填默认默认为10, 表示查询前top 10的数据。
# @type Limit: Integer
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据。不填将根据用户所在地智能选择地区。
# @type Area: String
attr_accessor :StartTime, :EndTime, :MetricName, :ZoneIds, :PolicyIds, :AttackType, :ProtocolType, :Port, :Limit, :Area
def initialize(starttime=nil, endtime=nil, metricname=nil, zoneids=nil, policyids=nil, attacktype=nil, protocoltype=nil, port=nil, limit=nil, area=nil)
@StartTime = starttime
@EndTime = endtime
@MetricName = metricname
@ZoneIds = zoneids
@PolicyIds = policyids
@AttackType = attacktype
@ProtocolType = protocoltype
@Port = port
@Limit = limit
@Area = area
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MetricName = params['MetricName']
@ZoneIds = params['ZoneIds']
@PolicyIds = params['PolicyIds']
@AttackType = params['AttackType']
@ProtocolType = params['ProtocolType']
@Port = params['Port']
@Limit = params['Limit']
@Area = params['Area']
end
end
# DescribeDDoSAttackTopData返回参数结构体
class DescribeDDoSAttackTopDataResponse < TencentCloud::Common::AbstractModel
# @param Data: DDoS攻击Top数据列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Data, :TotalCount, :RequestId
def initialize(data=nil, totalcount=nil, requestid=nil)
@Data = data
@TotalCount = totalcount
@RequestId = requestid
end
def deserialize(params)
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
topentry_tmp = TopEntry.new
topentry_tmp.deserialize(i)
@Data << topentry_tmp
end
end
@TotalCount = params['TotalCount']
@RequestId = params['RequestId']
end
end
# DescribeDefaultCertificates请求参数结构体
class DescribeDefaultCertificatesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Filters: 过滤条件,Filters.Values的上限为5。详细的过滤条件如下:
# zone-id
按照【站点ID】进行过滤。站点ID形如:zone-xxx。
类型:String
必选:是
# @type Filters: Array
# @param Offset: 分页查询偏移量。默认值:0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:100。
# @type Limit: Integer
attr_accessor :ZoneId, :Filters, :Offset, :Limit
def initialize(zoneid=nil, filters=nil, offset=nil, limit=nil)
@ZoneId = zoneid
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeDefaultCertificates返回参数结构体
class DescribeDefaultCertificatesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 证书总数。
# @type TotalCount: Integer
# @param DefaultServerCertInfo: 默认证书列表。
# @type DefaultServerCertInfo: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :DefaultServerCertInfo, :RequestId
def initialize(totalcount=nil, defaultservercertinfo=nil, requestid=nil)
@TotalCount = totalcount
@DefaultServerCertInfo = defaultservercertinfo
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['DefaultServerCertInfo'].nil?
@DefaultServerCertInfo = []
params['DefaultServerCertInfo'].each do |i|
defaultservercertinfo_tmp = DefaultServerCertInfo.new
defaultservercertinfo_tmp.deserialize(i)
@DefaultServerCertInfo << defaultservercertinfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeDeployHistory请求参数结构体
class DescribeDeployHistoryRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param EnvId: 环境 ID。
# @type EnvId: String
# @param Filters: 过滤条件,Filters.Values 的上限为 20,详细的过滤条件如下:
# record-id:按照发布记录 ID 进行过滤进行过滤。
# @type Filters: Array
attr_accessor :ZoneId, :EnvId, :Filters
def initialize(zoneid=nil, envid=nil, filters=nil)
@ZoneId = zoneid
@EnvId = envid
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@EnvId = params['EnvId']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
end
end
# DescribeDeployHistory返回参数结构体
class DescribeDeployHistoryResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 发布记录总数。
# @type TotalCount: Integer
# @param Records: 发布记录详情。
# @type Records: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Records, :RequestId
def initialize(totalcount=nil, records=nil, requestid=nil)
@TotalCount = totalcount
@Records = records
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Records'].nil?
@Records = []
params['Records'].each do |i|
deployrecord_tmp = DeployRecord.new
deployrecord_tmp.deserialize(i)
@Records << deployrecord_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeEnvironments请求参数结构体
class DescribeEnvironmentsRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
attr_accessor :ZoneId
def initialize(zoneid=nil)
@ZoneId = zoneid
end
def deserialize(params)
@ZoneId = params['ZoneId']
end
end
# DescribeEnvironments返回参数结构体
class DescribeEnvironmentsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 环境总数。
# @type TotalCount: Integer
# @param EnvInfos: 环境列表。
# @type EnvInfos: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :EnvInfos, :RequestId
def initialize(totalcount=nil, envinfos=nil, requestid=nil)
@TotalCount = totalcount
@EnvInfos = envinfos
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['EnvInfos'].nil?
@EnvInfos = []
params['EnvInfos'].each do |i|
envinfo_tmp = EnvInfo.new
envinfo_tmp.deserialize(i)
@EnvInfos << envinfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeFunctionRules请求参数结构体
class DescribeFunctionRulesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Filters: 过滤条件列表,多个条件为且关系,Filters.Values 的上限为 20。详细的过滤条件如下:
# rule-id:按照【规则 ID】进行精确匹配。
# function-id:按照【函数 ID】进行精确匹配。
# remark:按照【规则描述】进行模糊匹配。
# @type Filters: Array
attr_accessor :ZoneId, :Filters
def initialize(zoneid=nil, filters=nil)
@ZoneId = zoneid
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribeFunctionRules返回参数结构体
class DescribeFunctionRulesResponse < TencentCloud::Common::AbstractModel
# @param FunctionRules: 规则详情列表。
# @type FunctionRules: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :FunctionRules, :RequestId
def initialize(functionrules=nil, requestid=nil)
@FunctionRules = functionrules
@RequestId = requestid
end
def deserialize(params)
unless params['FunctionRules'].nil?
@FunctionRules = []
params['FunctionRules'].each do |i|
functionrule_tmp = FunctionRule.new
functionrule_tmp.deserialize(i)
@FunctionRules << functionrule_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeFunctionRuntimeEnvironment请求参数结构体
class DescribeFunctionRuntimeEnvironmentRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param FunctionId: 函数 ID。
# @type FunctionId: String
attr_accessor :ZoneId, :FunctionId
def initialize(zoneid=nil, functionid=nil)
@ZoneId = zoneid
@FunctionId = functionid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@FunctionId = params['FunctionId']
end
end
# DescribeFunctionRuntimeEnvironment返回参数结构体
class DescribeFunctionRuntimeEnvironmentResponse < TencentCloud::Common::AbstractModel
# @param EnvironmentVariables: 环境变量列表。
# @type EnvironmentVariables: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :EnvironmentVariables, :RequestId
def initialize(environmentvariables=nil, requestid=nil)
@EnvironmentVariables = environmentvariables
@RequestId = requestid
end
def deserialize(params)
unless params['EnvironmentVariables'].nil?
@EnvironmentVariables = []
params['EnvironmentVariables'].each do |i|
functionenvironmentvariable_tmp = FunctionEnvironmentVariable.new
functionenvironmentvariable_tmp.deserialize(i)
@EnvironmentVariables << functionenvironmentvariable_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeFunctions请求参数结构体
class DescribeFunctionsRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param FunctionIds: 按照函数 ID 列表过滤。
# @type FunctionIds: Array
# @param Filters: 过滤条件列表,多个条件为且关系,Filters.Values 的上限为 20。详细的过滤条件如下:
# name:按照【函数名称】进行模糊匹配。
# remark:按照【函数描述】进行模糊匹配。
# @type Filters: Array
# @param Offset: 分页查询偏移量。默认值:0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:200。
# @type Limit: Integer
attr_accessor :ZoneId, :FunctionIds, :Filters, :Offset, :Limit
def initialize(zoneid=nil, functionids=nil, filters=nil, offset=nil, limit=nil)
@ZoneId = zoneid
@FunctionIds = functionids
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
@ZoneId = params['ZoneId']
@FunctionIds = params['FunctionIds']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeFunctions返回参数结构体
class DescribeFunctionsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 符合查询条件的函数总数。
# @type TotalCount: Integer
# @param Functions: 符合查询条件的所有函数信息。
# @type Functions: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Functions, :RequestId
def initialize(totalcount=nil, functions=nil, requestid=nil)
@TotalCount = totalcount
@Functions = functions
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Functions'].nil?
@Functions = []
params['Functions'].each do |i|
function_tmp = Function.new
function_tmp.deserialize(i)
@Functions << function_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeHostsSetting请求参数结构体
class DescribeHostsSettingRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param Offset: 分页查询偏移量。默认值: 0,最小值:0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值: 100,最大值:1000。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values的上限为20。详细的过滤条件如下:
# host:按照域名进行过滤。
# @type Filters: Array
attr_accessor :ZoneId, :Offset, :Limit, :Filters
def initialize(zoneid=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribeHostsSetting返回参数结构体
class DescribeHostsSettingResponse < TencentCloud::Common::AbstractModel
# @param DetailHosts: 域名列表。
# @type DetailHosts: Array
# @param TotalNumber: 域名数量。
# @type TotalNumber: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :DetailHosts, :TotalNumber, :RequestId
def initialize(detailhosts=nil, totalnumber=nil, requestid=nil)
@DetailHosts = detailhosts
@TotalNumber = totalnumber
@RequestId = requestid
end
def deserialize(params)
unless params['DetailHosts'].nil?
@DetailHosts = []
params['DetailHosts'].each do |i|
detailhost_tmp = DetailHost.new
detailhost_tmp.deserialize(i)
@DetailHosts << detailhost_tmp
end
end
@TotalNumber = params['TotalNumber']
@RequestId = params['RequestId']
end
end
# DescribeIPRegion请求参数结构体
class DescribeIPRegionRequest < TencentCloud::Common::AbstractModel
# @param IPs: 待查询的 IP 列表,支持 IPV4 和 IPV6,最大可查询 100 条。
# @type IPs: Array
attr_accessor :IPs
def initialize(ips=nil)
@IPs = ips
end
def deserialize(params)
@IPs = params['IPs']
end
end
# DescribeIPRegion返回参数结构体
class DescribeIPRegionResponse < TencentCloud::Common::AbstractModel
# @param IPRegionInfo: IP 归属信息列表。
# @type IPRegionInfo: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :IPRegionInfo, :RequestId
def initialize(ipregioninfo=nil, requestid=nil)
@IPRegionInfo = ipregioninfo
@RequestId = requestid
end
def deserialize(params)
unless params['IPRegionInfo'].nil?
@IPRegionInfo = []
params['IPRegionInfo'].each do |i|
ipregioninfo_tmp = IPRegionInfo.new
ipregioninfo_tmp.deserialize(i)
@IPRegionInfo << ipregioninfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeIdentifications请求参数结构体
class DescribeIdentificationsRequest < TencentCloud::Common::AbstractModel
# @param Filters: 过滤条件,Filters.Values的上限为20。详细的过滤条件如下:
# zone-name:按照站点名称进行过滤。
# @type Filters: Array
# @param Offset: 分页查询偏移量。默认值:0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:1000。
# @type Limit: Integer
attr_accessor :Filters, :Offset, :Limit
def initialize(filters=nil, offset=nil, limit=nil)
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeIdentifications返回参数结构体
class DescribeIdentificationsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 符合条件的站点个数。
# @type TotalCount: Integer
# @param Identifications: 站点验证信息列表。
# @type Identifications: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Identifications, :RequestId
def initialize(totalcount=nil, identifications=nil, requestid=nil)
@TotalCount = totalcount
@Identifications = identifications
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Identifications'].nil?
@Identifications = []
params['Identifications'].each do |i|
identification_tmp = Identification.new
identification_tmp.deserialize(i)
@Identifications << identification_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeL4Proxy请求参数结构体
class DescribeL4ProxyRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 四层代理实例所属站点的 ID。
# @type ZoneId: String
# @param Offset: 分页查询偏移量,不填写时默认为 0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:1000。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values 的上限为 20。该参数不填写时,返回当前 zone-id 下所有四层代理实例信息。详细的过滤条件如下:
# proxy-id:按照四层代理实例 ID 进行过滤;
# ddos-protection-type:按照安全防护类型进行过滤。
# @type Filters: Array
attr_accessor :ZoneId, :Offset, :Limit, :Filters
def initialize(zoneid=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribeL4Proxy返回参数结构体
class DescribeL4ProxyResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 四层代理实例的数量。
# @type TotalCount: Integer
# @param L4Proxies: 四层代理实例列表。
# @type L4Proxies: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :L4Proxies, :RequestId
def initialize(totalcount=nil, l4proxies=nil, requestid=nil)
@TotalCount = totalcount
@L4Proxies = l4proxies
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['L4Proxies'].nil?
@L4Proxies = []
params['L4Proxies'].each do |i|
l4proxy_tmp = L4Proxy.new
l4proxy_tmp.deserialize(i)
@L4Proxies << l4proxy_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeL4ProxyRules请求参数结构体
class DescribeL4ProxyRulesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
# @param Offset: 分页查询偏移量,不填写时默认为 0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:1000。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values的上限为20。不填写时返回当前四层实例下所有的规则信息,详细的过滤条件如下: rule-id:按照规则 ID 对四层代理实例下的规则进行过滤。规则 ID 形如:rule-31vv7qig0vjy; rule-tag:按照规则标签对四层代理实例下的规则进行过滤。
# @type Filters: Array
attr_accessor :ZoneId, :ProxyId, :Offset, :Limit, :Filters
def initialize(zoneid=nil, proxyid=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribeL4ProxyRules返回参数结构体
class DescribeL4ProxyRulesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 转发规则总数。
# @type TotalCount: Integer
# @param L4ProxyRules: 转发规则列表。
# @type L4ProxyRules: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :L4ProxyRules, :RequestId
def initialize(totalcount=nil, l4proxyrules=nil, requestid=nil)
@TotalCount = totalcount
@L4ProxyRules = l4proxyrules
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['L4ProxyRules'].nil?
@L4ProxyRules = []
params['L4ProxyRules'].each do |i|
l4proxyrule_tmp = L4ProxyRule.new
l4proxyrule_tmp.deserialize(i)
@L4ProxyRules << l4proxyrule_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeLoadBalancerList请求参数结构体
class DescribeLoadBalancerListRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Offset: 分页查询偏移量,默认为 0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目,默认值:20,最大值:100。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values 的上限为 20。该参数不填写时,返回当前 zone-id 下所有负载均衡实例信息。详细的过滤条件如下:
# InstanceName:按照负载均衡实例名称进行过滤;
# InstanceId:按照负载均衡实例 ID 进行过滤。
# @type Filters: Array
attr_accessor :ZoneId, :Offset, :Limit, :Filters
def initialize(zoneid=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribeLoadBalancerList返回参数结构体
class DescribeLoadBalancerListResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 负载均衡实例总数。
# @type TotalCount: Integer
# @param LoadBalancerList: 负载均衡实例列表。
# @type LoadBalancerList: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :LoadBalancerList, :RequestId
def initialize(totalcount=nil, loadbalancerlist=nil, requestid=nil)
@TotalCount = totalcount
@LoadBalancerList = loadbalancerlist
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['LoadBalancerList'].nil?
@LoadBalancerList = []
params['LoadBalancerList'].each do |i|
loadbalancer_tmp = LoadBalancer.new
loadbalancer_tmp.deserialize(i)
@LoadBalancerList << loadbalancer_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeOriginGroupHealthStatus请求参数结构体
class DescribeOriginGroupHealthStatusRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param LBInstanceId: 负载均衡实例 ID。
# @type LBInstanceId: String
# @param OriginGroupIds: 源站组 ID。不填写时默认获取负载均衡下所有源站组的健康状态。
# @type OriginGroupIds: Array
attr_accessor :ZoneId, :LBInstanceId, :OriginGroupIds
def initialize(zoneid=nil, lbinstanceid=nil, origingroupids=nil)
@ZoneId = zoneid
@LBInstanceId = lbinstanceid
@OriginGroupIds = origingroupids
end
def deserialize(params)
@ZoneId = params['ZoneId']
@LBInstanceId = params['LBInstanceId']
@OriginGroupIds = params['OriginGroupIds']
end
end
# DescribeOriginGroupHealthStatus返回参数结构体
class DescribeOriginGroupHealthStatusResponse < TencentCloud::Common::AbstractModel
# @param OriginGroupHealthStatusList: 源站组下源站的健康状态。
# @type OriginGroupHealthStatusList: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :OriginGroupHealthStatusList, :RequestId
def initialize(origingrouphealthstatuslist=nil, requestid=nil)
@OriginGroupHealthStatusList = origingrouphealthstatuslist
@RequestId = requestid
end
def deserialize(params)
unless params['OriginGroupHealthStatusList'].nil?
@OriginGroupHealthStatusList = []
params['OriginGroupHealthStatusList'].each do |i|
origingrouphealthstatusdetail_tmp = OriginGroupHealthStatusDetail.new
origingrouphealthstatusdetail_tmp.deserialize(i)
@OriginGroupHealthStatusList << origingrouphealthstatusdetail_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeOriginGroup请求参数结构体
class DescribeOriginGroupRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID,此参数必填。
# @type ZoneId: String
# @param Offset: 分页查询偏移量,不填默认为0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目,不填默认为20,取值:1-1000。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values的上限为20。详细的过滤条件如下:
# origin-group-id
按照【源站组ID】进行过滤。源站组ID形如:origin-2ccgtb24-7dc5-46s2-9r3e-95825d53dwe3a
模糊查询:不支持origin-group-name
按照【源站组名称】进行过滤
模糊查询:支持。使用模糊查询时,仅支持填写一个源站组名称
# @type Filters: Array
attr_accessor :ZoneId, :Offset, :Limit, :Filters
def initialize(zoneid=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
end
end
# DescribeOriginGroup返回参数结构体
class DescribeOriginGroupResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 记录总数。
# @type TotalCount: Integer
# @param OriginGroups: 源站组信息。
# @type OriginGroups: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :OriginGroups, :RequestId
def initialize(totalcount=nil, origingroups=nil, requestid=nil)
@TotalCount = totalcount
@OriginGroups = origingroups
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['OriginGroups'].nil?
@OriginGroups = []
params['OriginGroups'].each do |i|
origingroup_tmp = OriginGroup.new
origingroup_tmp.deserialize(i)
@OriginGroups << origingroup_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeOriginProtection请求参数结构体
class DescribeOriginProtectionRequest < TencentCloud::Common::AbstractModel
# @param ZoneIds: 查询的站点ID集合。该参数必填。
# @type ZoneIds: Array
# @param Filters: 过滤条件,Filters.Values的上限为20。详细的过滤条件如下:
# need-update
按照【站点是否需要更新源站防护IP白名单】进行过滤。
类型:String
必选:否
可选项:
true:需要更新
false:无需更新
# plan-support
按照【站点套餐是否支持源站防护】进行过滤。
类型:String
必选:否
可选项:
true:支持
false:不支持
# @type Filters: Array
# @param Offset: 分页查询偏移量,默认为0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:1000。
# @type Limit: Integer
attr_accessor :ZoneIds, :Filters, :Offset, :Limit
def initialize(zoneids=nil, filters=nil, offset=nil, limit=nil)
@ZoneIds = zoneids
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
@ZoneIds = params['ZoneIds']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeOriginProtection返回参数结构体
class DescribeOriginProtectionResponse < TencentCloud::Common::AbstractModel
# @param OriginProtectionInfo: 源站防护信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OriginProtectionInfo: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :OriginProtectionInfo, :RequestId
def initialize(originprotectioninfo=nil, requestid=nil)
@OriginProtectionInfo = originprotectioninfo
@RequestId = requestid
end
def deserialize(params)
unless params['OriginProtectionInfo'].nil?
@OriginProtectionInfo = []
params['OriginProtectionInfo'].each do |i|
originprotectioninfo_tmp = OriginProtectionInfo.new
originprotectioninfo_tmp.deserialize(i)
@OriginProtectionInfo << originprotectioninfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeOverviewL7Data请求参数结构体
class DescribeOverviewL7DataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param MetricNames: 查询的指标,取值有:
# l7Flow_outFlux: Edegone响应流量;
# l7Flow_inFlux: Edgeone请求流量;
# l7Flow_outBandwidth: Edegone响应带宽;
# l7Flow_inBandwidth: Edegone请求带宽;
# l7Flow_hit_outFlux: 缓存命中流量;
# l7Flow_request: 访问请求数;
# l7Flow_flux: 访问请求上行+下行流量;
# l7Flow_bandwidth:访问请求上行+下行带宽。
# @type MetricNames: Array
# @param ZoneIds: 站点 ID 集合,此参数必填。
# @type ZoneIds: Array
# @param Domains: 查询的域名集合,此参数已经废弃。
# @type Domains: Array
# @param Protocol: 查询的协议类型,取值有:
# http: http协议;
# https: https协议;
# http2: http2协议;
# all: 所有协议。不填默认为all,此参数暂未生效。
# @type Protocol: String
# @param Interval: 查询时间粒度,取值有:
# min:1分钟;
# 5min:5分钟;
# hour:1小时;
# day:1天。不填将根据开始时间跟结束时间的间距自动推算粒度,具体为:1小时范围内以min粒度查询,2天范围内以5min粒度查询,7天范围内以hour粒度查询,超过7天以day粒度查询。
# @type Interval: String
# @param Filters: 过滤条件,详细的过滤条件Key值如下:
# socket
按照【HTTP协议类型】进行过滤。
对应的Value可选项如下:
HTTP:HTTP 协议;
HTTPS:HTTPS协议;
QUIC:QUIC协议。
# domain
按照【域名】进行过滤。
# tagKey
按照【标签Key】进行过滤。
# tagValue
按照【标签Value】进行过滤。
# @type Filters: Array
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据;
# global:全球数据。不填默认取值为global。
# @type Area: String
attr_accessor :StartTime, :EndTime, :MetricNames, :ZoneIds, :Domains, :Protocol, :Interval, :Filters, :Area
def initialize(starttime=nil, endtime=nil, metricnames=nil, zoneids=nil, domains=nil, protocol=nil, interval=nil, filters=nil, area=nil)
@StartTime = starttime
@EndTime = endtime
@MetricNames = metricnames
@ZoneIds = zoneids
@Domains = domains
@Protocol = protocol
@Interval = interval
@Filters = filters
@Area = area
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MetricNames = params['MetricNames']
@ZoneIds = params['ZoneIds']
@Domains = params['Domains']
@Protocol = params['Protocol']
@Interval = params['Interval']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
querycondition_tmp = QueryCondition.new
querycondition_tmp.deserialize(i)
@Filters << querycondition_tmp
end
end
@Area = params['Area']
end
end
# DescribeOverviewL7Data返回参数结构体
class DescribeOverviewL7DataResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: 七层监控类时序流量数据列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
timingdatarecord_tmp = TimingDataRecord.new
timingdatarecord_tmp.deserialize(i)
@Data << timingdatarecord_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePrefetchTasks请求参数结构体
class DescribePrefetchTasksRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。该参数必填。
# @type ZoneId: String
# @param StartTime: 查询起始时间,时间与 job-id 必填一个。
# @type StartTime: String
# @param EndTime: 查询结束时间,时间与 job-id 必填一个。
# @type EndTime: String
# @param Offset: 分页查询偏移量,默认为 0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目,默认值:20,上限:1000。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values 的上限为 20。详细的过滤条件如下:job-id:按照任务 ID 进行过滤。job-id 形如:1379afjk91u32h,暂不支持多值,不支持模糊查询;target:按照目标资源信息进行过滤。target 形如:http://www.qq.com/1.txt,暂不支持多值,不支持模糊查询;domains:按照域名行过滤。domains 形如:www.qq.com,不支持模糊查询;statuses:按照任务状态进行过滤,不支持模糊查询。可选项:
processing:处理中
success:成功
failed:失败
timeout:超时
invalid:无效。即源站响应非 2xx 状态码,请检查源站服务。
# @type Filters: Array
attr_accessor :ZoneId, :StartTime, :EndTime, :Offset, :Limit, :Filters
def initialize(zoneid=nil, starttime=nil, endtime=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@StartTime = starttime
@EndTime = endtime
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
end
end
# DescribePrefetchTasks返回参数结构体
class DescribePrefetchTasksResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 该查询条件总共条目数。
# @type TotalCount: Integer
# @param Tasks: 任务结果列表。
# @type Tasks: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Tasks, :RequestId
def initialize(totalcount=nil, tasks=nil, requestid=nil)
@TotalCount = totalcount
@Tasks = tasks
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Tasks'].nil?
@Tasks = []
params['Tasks'].each do |i|
task_tmp = Task.new
task_tmp.deserialize(i)
@Tasks << task_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribePurgeTasks请求参数结构体
class DescribePurgeTasksRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。该参数必填。
# @type ZoneId: String
# @param StartTime: 查询起始时间,时间与 job-id 必填一个。
# @type StartTime: String
# @param EndTime: 查询结束时间,时间与 job-id 必填一个。
# @type EndTime: String
# @param Offset: 分页查询偏移量,默认为 0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目,默认值:20,最大值:1000。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values的上限为20。详细的过滤条件如下:
# job-id:按照任务 ID 进行过滤。job-id 形如:1379afjk91u32h,暂不支持多值,不支持模糊查询;
# target:按照目标资源信息进行过滤,target 形如:http://www.qq.com/1.txt 或者 tag1,暂不支持多值,支持模糊查询;
# domains:按照域名进行过滤,形如:www.qq.com,不支持模糊查询;
# statuses:按照任务状态进行过滤,不支持模糊查询。可选项:
processing:处理中
success:成功
failed:失败
timeout:超时
# type:按照清除缓存类型进行过滤,暂不支持多值,不支持模糊查询。可选项:
purge_url:URL
purge_prefix:前缀
purge_all:全部缓存内容
purge_host:Hostname
purge_cache_tag:CacheTag
# @type Filters: Array
attr_accessor :ZoneId, :StartTime, :EndTime, :Offset, :Limit, :Filters
def initialize(zoneid=nil, starttime=nil, endtime=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@StartTime = starttime
@EndTime = endtime
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
end
end
# DescribePurgeTasks返回参数结构体
class DescribePurgeTasksResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 该查询条件总共条目数。
# @type TotalCount: Integer
# @param Tasks: 任务结果列表。
# @type Tasks: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Tasks, :RequestId
def initialize(totalcount=nil, tasks=nil, requestid=nil)
@TotalCount = totalcount
@Tasks = tasks
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Tasks'].nil?
@Tasks = []
params['Tasks'].each do |i|
task_tmp = Task.new
task_tmp.deserialize(i)
@Tasks << task_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeRealtimeLogDeliveryTasks请求参数结构体
class DescribeRealtimeLogDeliveryTasksRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Offset: 分页查询偏移量。默认值:0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:1000。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values 的上限为 20。该参数不填写时,返回当前 zone-id 下所有实时日志投递任务信息。详细的过滤条件如下:
# task-id:按照实时日志投递任务 ID进行过滤。不支持模糊查询。
# task-name:按照实时日志投递任务名称进行过滤。支持模糊查询,使用模糊查询时,仅支持填写一个实时日志投递任务名称。
# entity-list:按照实时日志投递任务对应的实体进行过滤。不支持模糊查询。示例值:domain.example.com 或者 sid-2s69eb5wcms7。
# task-type:按照实时日志投递任务类型进行过滤。不支持模糊查询。可选项如下:
cls: 推送到腾讯云 CLS;
custom_endpoint:推送到自定义 HTTP(S) 地址;
s3:推送到 AWS S3 兼容存储桶地址。
# @type Filters: Array
attr_accessor :ZoneId, :Offset, :Limit, :Filters
def initialize(zoneid=nil, offset=nil, limit=nil, filters=nil)
@ZoneId = zoneid
@Offset = offset
@Limit = limit
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
end
end
# DescribeRealtimeLogDeliveryTasks返回参数结构体
class DescribeRealtimeLogDeliveryTasksResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 符合查询条件的实时日志投递任务个数。
# @type TotalCount: Integer
# @param RealtimeLogDeliveryTasks: 符合查询条件的所有实时日志投递任务列表。
# @type RealtimeLogDeliveryTasks: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :RealtimeLogDeliveryTasks, :RequestId
def initialize(totalcount=nil, realtimelogdeliverytasks=nil, requestid=nil)
@TotalCount = totalcount
@RealtimeLogDeliveryTasks = realtimelogdeliverytasks
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['RealtimeLogDeliveryTasks'].nil?
@RealtimeLogDeliveryTasks = []
params['RealtimeLogDeliveryTasks'].each do |i|
realtimelogdeliverytask_tmp = RealtimeLogDeliveryTask.new
realtimelogdeliverytask_tmp.deserialize(i)
@RealtimeLogDeliveryTasks << realtimelogdeliverytask_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeRules请求参数结构体
class DescribeRulesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Filters: 过滤条件,Filters.Values的上限为20。详细的过滤条件如下:
# rule-id
按照【规则ID】进行过滤。
类型:string
必选:否
# @type Filters: Array
attr_accessor :ZoneId, :Filters
def initialize(zoneid=nil, filters=nil)
@ZoneId = zoneid
@Filters = filters
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
end
end
# DescribeRules返回参数结构体
class DescribeRulesResponse < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param RuleItems: 规则列表,按规则执行顺序从先往后排序。
# @type RuleItems: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ZoneId, :RuleItems, :RequestId
def initialize(zoneid=nil, ruleitems=nil, requestid=nil)
@ZoneId = zoneid
@RuleItems = ruleitems
@RequestId = requestid
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['RuleItems'].nil?
@RuleItems = []
params['RuleItems'].each do |i|
ruleitem_tmp = RuleItem.new
ruleitem_tmp.deserialize(i)
@RuleItems << ruleitem_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeRulesSetting请求参数结构体
class DescribeRulesSettingRequest < TencentCloud::Common::AbstractModel
def initialize()
end
def deserialize(params)
end
end
# DescribeRulesSetting返回参数结构体
class DescribeRulesSettingResponse < TencentCloud::Common::AbstractModel
# @param Actions: 规则引擎可应用匹配请求的设置列表及其详细建议配置信息。
# @type Actions: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Actions, :RequestId
def initialize(actions=nil, requestid=nil)
@Actions = actions
@RequestId = requestid
end
def deserialize(params)
unless params['Actions'].nil?
@Actions = []
params['Actions'].each do |i|
rulessettingaction_tmp = RulesSettingAction.new
rulessettingaction_tmp.deserialize(i)
@Actions << rulessettingaction_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeSecurityIPGroupInfo请求参数结构体
class DescribeSecurityIPGroupInfoRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点的 ID ,用于指定查询的站点范围。
# @type ZoneId: String
# @param Limit: 单次返回的最大条目数。默认值为 20 ,最大查询条目为 1000 。
# @type Limit: Integer
# @param Offset: 分页查询的起始条目偏移量。默认值为 0 。
# @type Offset: Integer
attr_accessor :ZoneId, :Limit, :Offset
def initialize(zoneid=nil, limit=nil, offset=nil)
@ZoneId = zoneid
@Limit = limit
@Offset = offset
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Limit = params['Limit']
@Offset = params['Offset']
end
end
# DescribeSecurityIPGroupInfo返回参数结构体
class DescribeSecurityIPGroupInfoResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 返回的满足条件的 IP 组数量。
# @type TotalCount: Integer
# @param IPGroups: IP 组的详细配置信息。包含每个 IP 组的 ID 、名称和 IP /网段列表信息。
# @type IPGroups: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :IPGroups, :RequestId
def initialize(totalcount=nil, ipgroups=nil, requestid=nil)
@TotalCount = totalcount
@IPGroups = ipgroups
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['IPGroups'].nil?
@IPGroups = []
params['IPGroups'].each do |i|
ipgroup_tmp = IPGroup.new
ipgroup_tmp.deserialize(i)
@IPGroups << ipgroup_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeSecurityIPGroup请求参数结构体
class DescribeSecurityIPGroupRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID ,用于指定查询的站点范围。
# @type ZoneId: String
# @param GroupIds: 指定安全 IP 组 ID。
# 提供该参数时,仅查询指定 ID 的安全 IP 组配置;
# 不传递参数时,返回站点下所有安全 IP 组信息。
# @type GroupIds: Array
attr_accessor :ZoneId, :GroupIds
def initialize(zoneid=nil, groupids=nil)
@ZoneId = zoneid
@GroupIds = groupids
end
def deserialize(params)
@ZoneId = params['ZoneId']
@GroupIds = params['GroupIds']
end
end
# DescribeSecurityIPGroup返回参数结构体
class DescribeSecurityIPGroupResponse < TencentCloud::Common::AbstractModel
# @param IPGroups: 安全 IP 组的详细配置信息。包含每个安全 IP 组的 ID 、名称和 IP / 网段列表信息。
# @type IPGroups: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :IPGroups, :RequestId
def initialize(ipgroups=nil, requestid=nil)
@IPGroups = ipgroups
@RequestId = requestid
end
def deserialize(params)
unless params['IPGroups'].nil?
@IPGroups = []
params['IPGroups'].each do |i|
ipgroup_tmp = IPGroup.new
ipgroup_tmp.deserialize(i)
@IPGroups << ipgroup_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeSecurityTemplateBindings请求参数结构体
class DescribeSecurityTemplateBindingsRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 要查询的站点 ID。
# @type ZoneId: String
# @param TemplateId: 要查询的策略模板 ID。
# @type TemplateId: Array
attr_accessor :ZoneId, :TemplateId
def initialize(zoneid=nil, templateid=nil)
@ZoneId = zoneid
@TemplateId = templateid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@TemplateId = params['TemplateId']
end
end
# DescribeSecurityTemplateBindings返回参数结构体
class DescribeSecurityTemplateBindingsResponse < TencentCloud::Common::AbstractModel
# @param SecurityTemplate: 指定策略模板的绑定关系列表。
# 当某个站点中的域名包含在指定策略模板的绑定关系中时,绑定关系列表 `TemplateScope` 中会包含该站点的 `ZoneId`,和该站点下的和该策略模板有关的域名绑定关系。
# 注意:当没有任何域名正在绑定或已经绑定到指定策略模板时,绑定关系为空。即:返回结构体中,`TemplateScope` 数组长度为 0。
# 绑定关系中,同一域名可能在 `EntityStatus` 列表中重复出现,并标记为不同 `Status` 。例如,正在被绑定到其他策略模板的域名,会同时标记为 `online` 和 `pending` 。
# @type SecurityTemplate: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :SecurityTemplate, :RequestId
def initialize(securitytemplate=nil, requestid=nil)
@SecurityTemplate = securitytemplate
@RequestId = requestid
end
def deserialize(params)
unless params['SecurityTemplate'].nil?
@SecurityTemplate = []
params['SecurityTemplate'].each do |i|
securitytemplatebinding_tmp = SecurityTemplateBinding.new
securitytemplatebinding_tmp.deserialize(i)
@SecurityTemplate << securitytemplatebinding_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeTimingL4Data请求参数结构体
class DescribeTimingL4DataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param MetricNames: 查询指标,取值有:
# l4Flow_connections: 访问连接数;
# l4Flow_flux: 访问总流量;
# l4Flow_inFlux: 访问入流量;
# l4Flow_outFlux: 访问出流量。
# @type MetricNames: Array
# @param ZoneIds: 站点 ID 集合,此参数必填。
# @type ZoneIds: Array
# @param ProxyIds: 四层实例列表, 不填表示选择全部实例。
# @type ProxyIds: Array
# @param Interval: 查询时间粒度,取值有:
# min: 1分钟 ;
# 5min: 5分钟 ;
# hour: 1小时 ;
# day: 1天 。不填将根据开始时间跟结束时间的间距自动推算粒度,具体为:1小时范围内以min粒度查询,2天范围内以5min粒度查询,7天范围内以hour粒度查询,超过7天以day粒度查询。
# @type Interval: String
# @param Filters: 过滤条件,详细的过滤条件Key值如下:
# ruleId:按照转发规则 ID 进行过滤。
# proxyId:按照四层代理实例 ID 进行过滤。
# @type Filters: Array
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据;
# global:全球数据。不填默认取值为global。
# @type Area: String
attr_accessor :StartTime, :EndTime, :MetricNames, :ZoneIds, :ProxyIds, :Interval, :Filters, :Area
def initialize(starttime=nil, endtime=nil, metricnames=nil, zoneids=nil, proxyids=nil, interval=nil, filters=nil, area=nil)
@StartTime = starttime
@EndTime = endtime
@MetricNames = metricnames
@ZoneIds = zoneids
@ProxyIds = proxyids
@Interval = interval
@Filters = filters
@Area = area
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MetricNames = params['MetricNames']
@ZoneIds = params['ZoneIds']
@ProxyIds = params['ProxyIds']
@Interval = params['Interval']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
querycondition_tmp = QueryCondition.new
querycondition_tmp.deserialize(i)
@Filters << querycondition_tmp
end
end
@Area = params['Area']
end
end
# DescribeTimingL4Data返回参数结构体
class DescribeTimingL4DataResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: 四层时序流量数据列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
timingdatarecord_tmp = TimingDataRecord.new
timingdatarecord_tmp.deserialize(i)
@Data << timingdatarecord_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeTimingL7AnalysisData请求参数结构体
class DescribeTimingL7AnalysisDataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param MetricNames: 指标列表,取值有:
# l7Flow_outFlux: L7 EdgeOne 响应流量;
# l7Flow_inFlux: L7 客户端请求流量;
# l7Flow_flux: L7 访问总流量(EdgeOne 响应+客户端请求);
# l7Flow_outBandwidth: L7 EdgeOne 响应带宽;
# l7Flow_inBandwidth:L7 客户端请求带宽;
# l7Flow_bandwidth:L7 访问总带宽(EdgeOne 响应+客户端请求);
# l7Flow_request: L7 访问请求数。
# @type MetricNames: Array
# @param ZoneIds: 站点 ID 集合,此参数必填。
# @type ZoneIds: Array
# @param Interval: 查询时间粒度,取值有:
# min: 1分钟;
# 5min: 5分钟;
# hour: 1小时;
# day: 1天。不填将根据开始时间跟结束时间的间距自动推算粒度,具体为:2 小时范围内以 min 粒度查询,2 天范围内以 5min 粒度查询,7 天范围内以 hour 粒度查询,超过 7 天以 day 粒度查询。
# @type Interval: String
# @param Filters: 过滤条件,详细的过滤条件 Key 值如下:
# country:按照国家/地区进行过滤,国家/地区遵循 ISO 3166-1 alpha-2 规范。示例值:CN。
# province:按照省份进行过滤,此参数只支持服务区域为中国大陆。省份代码参考境内省份映射表,示例值:22。
# isp:按照运营商进行过滤,此参数只支持服务区域为中国大陆。对应的 Value 可选项如下:
2:中国电信;
26:中国联通;
1046:中国移动;
3947:中国铁通;
38:教育网;
43:长城宽带;
0:其他运营商。
# domain:按照子域名进行过滤,示例值: www.example.com。
# url:按照 URL Path 进行过滤,示例值:/content 或 /content/test.jpg。若填写 url 参数,则最多可查询近 30 天的数据。
# referer:按照 Referer 请求头部进行过滤,示例值:http://www.example.com/。若填写 referer 参数,则最多可查询近 30 天的数据;
# resourceType:按照资源类型进行过滤,资源类型一般是文件后缀,示例值:.jpg。若填写 resourceType 参数,则最多可查询近 30 天的数据;
# protocol:按照 HTTP 协议版本进行过滤。对应的 Value 可选项如下:
HTTP/1.0;
HTTP/1.1;
HTTP/2.0;
HTTP/3;
WebSocket。
# socket:按照 HTTP协议类型进行过滤。对应的 Value 可选项如下:
HTTP:HTTP 协议;
HTTPS:HTTPS 协议;
QUIC:QUIC 协议。
# statusCode:按照边缘状态码进行过滤。若填写 statusCode 参数,则最多可查询近 30 天的数据。对应的 Value 可选项如下:
1XX:1xx类型的状态码;
2XX:2xx类型的状态码;
3XX:3xx类型的状态码;
4XX:4xx类型的状态码;
5XX:5xx类型的状态码;
在 [0,600) 范围内的整数。
# browserType:按照浏览器类型进行过滤。若填写 browserType 参数,则最多可查询近 30 天的数据。对应 Value 的可选项如下:
Firefox:Firefox浏览器;
Chrome:Chrome浏览器;
Safari:Safari浏览器;
Other:其他浏览器类型;
Empty:浏览器类型为空;
Bot:搜索引擎爬虫;
MicrosoftEdge:MicrosoftEdge浏览器;
IE:IE浏览器;
Opera:Opera浏览器;
QQBrowser:QQ浏览器;
LBBrowser:LB浏览器;
MaxthonBrowser:Maxthon浏览器;
SouGouBrowser:搜狗浏览器;
BIDUBrowser:百度浏览器;
TaoBrowser:淘浏览器;
UBrowser:UC浏览器。
# deviceType:按照设备类型进行过滤。若填写 deviceType 参数,则最多可查询近 30 天的数据。对应 Value 的可选项如下:
TV:TV设备;
Tablet:Tablet设备;
Mobile:Mobile设备;
Desktop:Desktop设备;
Other:其他设备类型;
Empty:设备类型为空。
# operatingSystemType:按照操作系统类型进行过滤。若填写 operatingSystemType 参数,则最多可查询近 30 天的数据。对应 Value 的可选项如下:
Linux:Linux操作系统;
MacOS:MacOs操作系统;
Android:Android操作系统;
IOS:IOS操作系统;
Windows:Windows操作系统;
NetBSD:NetBSD;
ChromiumOS:ChromiumOS;
Bot:搜索引擎爬虫;
Other:其他类型的操作系统;
Empty:操作系统为空。
# tlsVersion:按照 TLS 版本进行过滤。若填写 tlsVersion 参数,则最多可查询近 30 天的数据。对应 Value 的可选项如下:
TLS1.0;
TLS1.1;
TLS1.2;
TLS1.3。
# ipVersion:按照 IP 版本进行过滤。对应 Value 的可选项如下:
4:IPv4;
6:IPv6。
# cacheType:按照缓存状态进行过滤。对应 Value 的可选项如下:
hit:请求命中 EdgeOne 节点缓存,资源由节点缓存提供。资源部分命中缓存也会记录为 hit。
miss:请求未命中 EdgeOne 节点缓存,资源由源站提供。
dynamic:请求的资源无法缓存/未配置被节点缓存,资源由源站提供。
other:无法被识别的缓存状态。边缘函数响应的请求会记录为 other。
# clientIp:按照客户端 IP 进行过滤。
# @type Filters: Array
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据;
# global:全球数据。
# 不填默认取值为 global。
# @type Area: String
attr_accessor :StartTime, :EndTime, :MetricNames, :ZoneIds, :Interval, :Filters, :Area
def initialize(starttime=nil, endtime=nil, metricnames=nil, zoneids=nil, interval=nil, filters=nil, area=nil)
@StartTime = starttime
@EndTime = endtime
@MetricNames = metricnames
@ZoneIds = zoneids
@Interval = interval
@Filters = filters
@Area = area
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MetricNames = params['MetricNames']
@ZoneIds = params['ZoneIds']
@Interval = params['Interval']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
querycondition_tmp = QueryCondition.new
querycondition_tmp.deserialize(i)
@Filters << querycondition_tmp
end
end
@Area = params['Area']
end
end
# DescribeTimingL7AnalysisData返回参数结构体
class DescribeTimingL7AnalysisDataResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: 时序流量数据列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
timingdatarecord_tmp = TimingDataRecord.new
timingdatarecord_tmp.deserialize(i)
@Data << timingdatarecord_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeTimingL7CacheData请求参数结构体
class DescribeTimingL7CacheDataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param MetricNames: 查询的指标,取值有:
# l7Cache_outFlux:响应流量;
# l7Cache_request:响应请求数;
# l7Cache_outBandwidth:响应带宽。
# @type MetricNames: Array
# @param ZoneIds: 站点 ID 集合,此参数必填。
# @type ZoneIds: Array
# @param Filters: 过滤条件,详细的过滤条件如下:
# domain
按照【子域名】进行过滤,子域名形如: test.example.com。
类型:String
必选:否
# url
按照【URL】进行过滤,此参数只支持30天的时间范围,URL形如:/content。
类型:String
必选:否
# resourceType
按照【资源类型】进行过滤,此参数只支持30天的时间范围,资源类型形如:jpg,png。
类型:String
必选:否
# cacheType
按照【缓存类型】进行过滤。
类型:String
必选:否
可选项:
hit:命中缓存;
dynamic:资源不可缓存;
miss:未命中缓存。
# statusCode
按照【状态码】进行过滤,此参数只支持30天的时间范围。
类型:String
必选:否
可选项:
1XX:1xx类型的状态码;
100:100状态码;
101:101状态码;
102:102状态码;
2XX:2xx类型的状态码;
200:200状态码;
201:201状态码;
202:202状态码;
203:203状态码;
204:204状态码;
100:100状态码;
206:206状态码;
207:207状态码;
3XX:3xx类型的状态码;
300:300状态码;
301:301状态码;
302:302状态码;
303:303状态码;
304:304状态码;
305:305状态码;
307:307状态码;
4XX:4xx类型的状态码;
400:400状态码;
401:401状态码;
402:402状态码;
403:403状态码;
404:404状态码;
405:405状态码;
406:406状态码;
407:407状态码;
408:408状态码;
409:409状态码;
410:410状态码;
411:411状态码;
412:412状态码;
412:413状态码;
414:414状态码;
415:415状态码;
416:416状态码;
417:417状态码;
422:422状态码;
423:423状态码;
424:424状态码;
426:426状态码;
451:451状态码;
5XX:5xx类型的状态码;
500:500状态码;
501:501状态码;
502:502状态码;
503:503状态码;
504:504状态码;
505:505状态码;
506:506状态码;
507:507状态码;
510:510状态码;
514:514状态码;
544:544状态码。
# tagKey
按照【标签Key】进行过滤。
类型:String
必选:否
# tagValue
按照【标签Value】进行过滤。
类型:String
必选:否
# @type Filters: Array
# @param Interval: 查询时间粒度,可选的值有:
# min:1分钟的时间粒度;
# 5min:5分钟的时间粒度;
# hour:1小时的时间粒度;
# day:1天的时间粒度。不填将根据开始时间跟结束时间的间距自动推算粒度,具体为:一小时范围内以min粒度查询,两天范围内以5min粒度查询,七天范围内以hour粒度查询,超过七天以day粒度查询。
# @type Interval: String
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据;
# global:全球数据。不填默认取值为global。
# @type Area: String
attr_accessor :StartTime, :EndTime, :MetricNames, :ZoneIds, :Filters, :Interval, :Area
def initialize(starttime=nil, endtime=nil, metricnames=nil, zoneids=nil, filters=nil, interval=nil, area=nil)
@StartTime = starttime
@EndTime = endtime
@MetricNames = metricnames
@ZoneIds = zoneids
@Filters = filters
@Interval = interval
@Area = area
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MetricNames = params['MetricNames']
@ZoneIds = params['ZoneIds']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
querycondition_tmp = QueryCondition.new
querycondition_tmp.deserialize(i)
@Filters << querycondition_tmp
end
end
@Interval = params['Interval']
@Area = params['Area']
end
end
# DescribeTimingL7CacheData返回参数结构体
class DescribeTimingL7CacheDataResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: 七层缓存分析时序类流量数据列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
timingdatarecord_tmp = TimingDataRecord.new
timingdatarecord_tmp.deserialize(i)
@Data << timingdatarecord_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeTopL7AnalysisData请求参数结构体
class DescribeTopL7AnalysisDataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param MetricName: 查询的指标,取值有:
# l7Flow_outFlux_country:按国家/地区维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_province:按中国大陆境内省份维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_statusCode:按状态码维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_domain:按域名维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_url:按 URL Path 维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_resourceType:按资源类型维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_sip:按客户端 IP 维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_referers:按 Referer 维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_ua_device:按设备类型维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_ua_browser:按浏览器类型维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_outFlux_us_os:按操作系统类型维度统计 L7 EdgeOne 响应流量指标;
# l7Flow_request_country:按国家/地区维度统计 L7 访问请求数指标;
# l7Flow_request_province:按中国大陆境内省份维度统计 L7 访问请求数指标;
# l7Flow_request_statusCode:按状态码维度统计 L7 访问请求数指标;
# l7Flow_request_domain:按域名维度统计 L7 访问请求数指标;
# l7Flow_request_url:按 URL Path 维度统计 L7 访问请求数指标;
# l7Flow_request_resourceType:按资源类型维度统计 L7 访问请求数指标;
# l7Flow_request_sip:按客户端 IP 维度统计 L7 访问请求数指标;
# l7Flow_request_referer:按 Referer 维度统计 L7 访问请求数指标;
# l7Flow_request_ua_device:按设备类型维度统计 L7 访问请求数指标;
# l7Flow_request_ua_browser:按浏览器类型维度统计 L7 访问请求数指标;
# l7Flow_request_us_os:按操作系统类型维度统计 L7 访问请求数指标。
# @type MetricName: String
# @param ZoneIds: 站点 ID 集合,此参数必填。
# @type ZoneIds: Array
# @param Limit: 查询前多少个 top 数据,最大值为1000。不填默认为10,表示查询 top10 的数据。
# @type Limit: Integer
# @param Filters: 过滤条件,详细的过滤条件 Key 值如下:
# country:按照国家/地区进行过滤,国家/地区遵循 ISO 3166-1 alpha-2 规范。示例值:CN。
# province:按照省份进行过滤,此参数只支持服务区域为中国大陆。省份代码参考境内省份映射表,示例值:22。
# isp:按照运营商进行过滤,此参数只支持服务区域为中国大陆。对应的 Value 可选项如下:
2:中国电信;
26:中国联通;
1046:中国移动;
3947:中国铁通;
38:教育网;
43:长城宽带;
0:其他运营商。
# domain:按照子域名进行过滤,示例值: www.example.com。
# url:按照 URL Path 进行过滤,示例值:/content 或 /content/test.jpg。若填写 url 参数,则最多可查询近 30 天的数据。
# referer:按照 Referer 请求头部进行过滤,示例值:http://www.example.com/。若填写 referer 参数,则最多可查询近 30 天的数据;
# resourceType:按照资源类型进行过滤,资源类型一般是文件后缀,示例值:.jpg。若填写 resourceType 参数,则最多可查询近 30 天的数据;
# protocol:按照 HTTP 协议版本进行过滤。对应的 Value 可选项如下:
HTTP/1.0;
HTTP/1.1;
HTTP/2.0;
HTTP/3;
WebSocket。
# socket:按照 HTTP协议类型进行过滤。对应的 Value 可选项如下:
HTTP:HTTP 协议;
HTTPS:HTTPS 协议;
QUIC:QUIC 协议。
# statusCode:按照边缘状态码进行过滤。若填写 statusCode 参数,则最多可查询近 30 天的数据。对应的 Value 可选项如下:
1XX:1xx类型的状态码;
2XX:2xx类型的状态码;
3XX:3xx类型的状态码;
4XX:4xx类型的状态码;
5XX:5xx类型的状态码;
在 [0,600) 范围内的整数。
# browserType:按照浏览器类型进行过滤。若填写 browserType 参数,则最多可查询近 30 天的数据。对应 Value 的可选项如下:
Firefox:Firefox浏览器;
Chrome:Chrome浏览器;
Safari:Safari浏览器;
Other:其他浏览器类型;
Empty:浏览器类型为空;
Bot:搜索引擎爬虫;
MicrosoftEdge:MicrosoftEdge浏览器;
IE:IE浏览器;
Opera:Opera浏览器;
QQBrowser:QQ浏览器;
LBBrowser:LB浏览器;
MaxthonBrowser:Maxthon浏览器;
SouGouBrowser:搜狗浏览器;
BIDUBrowser:百度浏览器;
TaoBrowser:淘浏览器;
UBrowser:UC浏览器。
# deviceType:按照设备类型进行过滤。若填写 deviceType 参数,则最多可查询近 30 天的数据。对应 Value 的可选项如下:
TV:TV设备;
Tablet:Tablet设备;
Mobile:Mobile设备;
Desktop:Desktop设备;
Other:其他设备类型;
Empty:设备类型为空。
# operatingSystemType:按照操作系统类型进行过滤。若填写 operatingSystemType 参数,则最多可查询近 30 天的数据。对应 Value 的可选项如下:
Linux:Linux操作系统;
MacOS:MacOs操作系统;
Android:Android操作系统;
IOS:IOS操作系统;
Windows:Windows操作系统;
NetBSD:NetBSD;
ChromiumOS:ChromiumOS;
Bot:搜索引擎爬虫;
Other:其他类型的操作系统;
Empty:操作系统为空。
# tlsVersion:按照 TLS 版本进行过滤。若填写 tlsVersion 参数,则最多可查询近 30 天的数据。对应 Value 的可选项如下:
TLS1.0;
TLS1.1;
TLS1.2;
TLS1.3。
# ipVersion:按照 IP 版本进行过滤。对应 Value 的可选项如下:
4:IPv4;
6:IPv6。
# cacheType:按照缓存状态进行过滤。对应 Value 的可选项如下:
hit:请求命中 EdgeOne 节点缓存,资源由节点缓存提供。资源部分命中缓存也会记录为 hit。
miss:请求未命中 EdgeOne 节点缓存,资源由源站提供。
dynamic:请求的资源无法缓存/未配置被节点缓存,资源由源站提供。
other:无法被识别的缓存状态。边缘函数响应的请求会记录为 other。
# clientIp:按照客户端 IP 进行过滤。
# @type Filters: Array
# @param Interval: 查询时间粒度,取值有:
# min: 1分钟;
# 5min: 5分钟;
# hour: 1小时;
# day: 1天。不填将根据开始时间跟结束时间的间距自动推算粒度,具体为:2 小时范围内以 min 粒度查询,2 天范围内以 5min 粒度查询,7 天范围内以 hour 粒度查询,超过 7 天以 day 粒度查询。
# @type Interval: String
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据;
# global:全球数据。不填默认取值为global。
# @type Area: String
attr_accessor :StartTime, :EndTime, :MetricName, :ZoneIds, :Limit, :Filters, :Interval, :Area
def initialize(starttime=nil, endtime=nil, metricname=nil, zoneids=nil, limit=nil, filters=nil, interval=nil, area=nil)
@StartTime = starttime
@EndTime = endtime
@MetricName = metricname
@ZoneIds = zoneids
@Limit = limit
@Filters = filters
@Interval = interval
@Area = area
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MetricName = params['MetricName']
@ZoneIds = params['ZoneIds']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
querycondition_tmp = QueryCondition.new
querycondition_tmp.deserialize(i)
@Filters << querycondition_tmp
end
end
@Interval = params['Interval']
@Area = params['Area']
end
end
# DescribeTopL7AnalysisData返回参数结构体
class DescribeTopL7AnalysisDataResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: 七层访问数据按照 MetricName 指定统计维度的前 topN 数据列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
topdatarecord_tmp = TopDataRecord.new
topdatarecord_tmp.deserialize(i)
@Data << topdatarecord_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeTopL7CacheData请求参数结构体
class DescribeTopL7CacheDataRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param MetricName: 查询的指标,取值有:
# l7Cache_outFlux_domain:host/域名;
# l7Cache_outFlux_url:url地址;
# l7Cache_outFlux_resourceType:资源类型;
# l7Cache_outFlux_statusCode:状态码。
# @type MetricName: String
# @param ZoneIds: 站点 ID 集合,此参数必填。
# @type ZoneIds: Array
# @param Limit: 查询前多少个数据,最大值为1000,不填默认为10, 表示查询前top 10的数据。
# @type Limit: Integer
# @param Filters: 过滤条件,详细的过滤条件如下:
# domain
按照【子域名】进行过滤,子域名形如: test.example.com。
类型:String
必选:否
# url
按照【URL】进行过滤,此参数只支持30天的时间范围,URL形如:/content。
类型:String
必选:否
# resourceType
按照【资源类型】进行过滤,此参数只支持30天的时间范围,资源类型形如:jpg,png。
类型:String
必选:否
# cacheType
按照【缓存类型】进行过滤。
类型:String
必选:否
可选项:
hit:命中缓存;
dynamic:资源不可缓存;
miss:未命中缓存。
# statusCode
按照【状态码】进行过滤,此参数只支持30天的时间范围。
类型:String
必选:否
可选项:
1XX:1xx类型的状态码;
100:100状态码;
101:101状态码;
102:102状态码;
2XX:2xx类型的状态码;
200:200状态码;
201:201状态码;
202:202状态码;
203:203状态码;
204:204状态码;
100:100状态码;
206:206状态码;
207:207状态码;
3XX:3xx类型的状态码;
300:300状态码;
301:301状态码;
302:302状态码;
303:303状态码;
304:304状态码;
305:305状态码;
307:307状态码;
4XX:4xx类型的状态码;
400:400状态码;
401:401状态码;
402:402状态码;
403:403状态码;
404:404状态码;
405:405状态码;
406:406状态码;
407:407状态码;
408:408状态码;
409:409状态码;
410:410状态码;
411:411状态码;
412:412状态码;
412:413状态码;
414:414状态码;
415:415状态码;
416:416状态码;
417:417状态码;
422:422状态码;
423:423状态码;
424:424状态码;
426:426状态码;
451:451状态码;
5XX:5xx类型的状态码;
500:500状态码;
501:501状态码;
502:502状态码;
503:503状态码;
504:504状态码;
505:505状态码;
506:506状态码;
507:507状态码;
510:510状态码;
514:514状态码;
544:544状态码。
# tagKey
按照【标签Key】进行过滤。
类型:String
必选:否
# tagValue
按照【标签Value】进行过滤。
类型:String
必选:否
# @type Filters: Array
# @param Interval: 查询时间粒度,取值有:
# min: 1分钟;
# 5min: 5分钟;
# hour: 1小时;
# day: 1天。不填将根据开始时间跟结束时间的间距自动推算粒度,具体为:一小时范围内以min粒度查询,两天范围内以5min粒度查询,七天范围内以hour粒度查询,超过七天以day粒度查询。
# @type Interval: String
# @param Area: 数据归属地区,取值有:
# overseas:全球(除中国大陆地区)数据;
# mainland:中国大陆地区数据;
# global:全球数据。不填默认取值为global。
# @type Area: String
attr_accessor :StartTime, :EndTime, :MetricName, :ZoneIds, :Limit, :Filters, :Interval, :Area
def initialize(starttime=nil, endtime=nil, metricname=nil, zoneids=nil, limit=nil, filters=nil, interval=nil, area=nil)
@StartTime = starttime
@EndTime = endtime
@MetricName = metricname
@ZoneIds = zoneids
@Limit = limit
@Filters = filters
@Interval = interval
@Area = area
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@MetricName = params['MetricName']
@ZoneIds = params['ZoneIds']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
querycondition_tmp = QueryCondition.new
querycondition_tmp.deserialize(i)
@Filters << querycondition_tmp
end
end
@Interval = params['Interval']
@Area = params['Area']
end
end
# DescribeTopL7CacheData返回参数结构体
class DescribeTopL7CacheDataResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: 七层缓存TopN流量数据列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
topdatarecord_tmp = TopDataRecord.new
topdatarecord_tmp.deserialize(i)
@Data << topdatarecord_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeZoneConfigImportResult请求参数结构体
class DescribeZoneConfigImportResultRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param TaskId: 表示需要查询结果的导入配置任务 Id,导入任务 Id 仅支持查询最近 7 天的导入任务。
# @type TaskId: String
attr_accessor :ZoneId, :TaskId
def initialize(zoneid=nil, taskid=nil)
@ZoneId = zoneid
@TaskId = taskid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@TaskId = params['TaskId']
end
end
# DescribeZoneConfigImportResult返回参数结构体
class DescribeZoneConfigImportResultResponse < TencentCloud::Common::AbstractModel
# @param Status: 本次导入任务的导入状态。取值有: success:表示配置项导入成功; failure:表示配置项导入失败; doing:表示配置项正在导入中。
# @type Status: String
# @param Message: 本次导入任务的状态的提示信息。当配置项导入失败时,可通过本字段查看失败原因。
# @type Message: String
# @param Content: 本次导入任务的配置内容。
# @type Content: String
# @param ImportTime: 本次导入任务的开始时间。
# @type ImportTime: String
# @param FinishTime: 本次导入任务的结束时间。
# @type FinishTime: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Status, :Message, :Content, :ImportTime, :FinishTime, :RequestId
def initialize(status=nil, message=nil, content=nil, importtime=nil, finishtime=nil, requestid=nil)
@Status = status
@Message = message
@Content = content
@ImportTime = importtime
@FinishTime = finishtime
@RequestId = requestid
end
def deserialize(params)
@Status = params['Status']
@Message = params['Message']
@Content = params['Content']
@ImportTime = params['ImportTime']
@FinishTime = params['FinishTime']
@RequestId = params['RequestId']
end
end
# DescribeZoneSetting请求参数结构体
class DescribeZoneSettingRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
attr_accessor :ZoneId
def initialize(zoneid=nil)
@ZoneId = zoneid
end
def deserialize(params)
@ZoneId = params['ZoneId']
end
end
# DescribeZoneSetting返回参数结构体
class DescribeZoneSettingResponse < TencentCloud::Common::AbstractModel
# @param ZoneSetting: 站点配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ZoneSetting: :class:`Tencentcloud::Teo.v20220901.models.ZoneSetting`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ZoneSetting, :RequestId
def initialize(zonesetting=nil, requestid=nil)
@ZoneSetting = zonesetting
@RequestId = requestid
end
def deserialize(params)
unless params['ZoneSetting'].nil?
@ZoneSetting = ZoneSetting.new
@ZoneSetting.deserialize(params['ZoneSetting'])
end
@RequestId = params['RequestId']
end
end
# DescribeZones请求参数结构体
class DescribeZonesRequest < TencentCloud::Common::AbstractModel
# @param Offset: 分页查询偏移量。默认值:0。
# @type Offset: Integer
# @param Limit: 分页查询限制数目。默认值:20,最大值:100。
# @type Limit: Integer
# @param Filters: 过滤条件,Filters.Values 的上限为 20。该参数不填写时,返回当前 appid 下有权限的所有站点信息。详细的过滤条件如下:
# zone-name:按照站点名称进行过滤;zone-id:按照站点 ID进行过滤。站点 ID 形如:zone-2noz78a8ev6k;status:按照站点状态进行过滤;tag-key:按照标签键进行过滤;tag-value: 按照标签值进行过滤。模糊查询时仅支持过滤字段名为 zone-name。
# @type Filters: Array
# @param Order: 可根据该字段对返回结果进行排序,取值有:
# type:接入类型;
# area:加速区域;
# create-time:创建时间;
# zone-name:站点名称;
# use-time:最近使用时间;
# active-status:生效状态。不填写时对返回结果默认按照 create-time 排序。
# @type Order: String
# @param Direction: 排序方向,如果是字段值为数字,则根据数字大小排序;如果字段值为文本,则根据 ascill 码的大小排序。取值有:
# asc:从小到大排序;
# desc:从大到小排序。不填写使用默认值 desc。
# @type Direction: String
attr_accessor :Offset, :Limit, :Filters, :Order, :Direction
def initialize(offset=nil, limit=nil, filters=nil, order=nil, direction=nil)
@Offset = offset
@Limit = limit
@Filters = filters
@Order = order
@Direction = direction
end
def deserialize(params)
@Offset = params['Offset']
@Limit = params['Limit']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
advancedfilter_tmp = AdvancedFilter.new
advancedfilter_tmp.deserialize(i)
@Filters << advancedfilter_tmp
end
end
@Order = params['Order']
@Direction = params['Direction']
end
end
# DescribeZones返回参数结构体
class DescribeZonesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 符合条件的站点个数。
# @type TotalCount: Integer
# @param Zones: 站点详细信息。
# @type Zones: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Zones, :RequestId
def initialize(totalcount=nil, zones=nil, requestid=nil)
@TotalCount = totalcount
@Zones = zones
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Zones'].nil?
@Zones = []
params['Zones'].each do |i|
zone_tmp = Zone.new
zone_tmp.deserialize(i)
@Zones << zone_tmp
end
end
@RequestId = params['RequestId']
end
end
# DestroyPlan请求参数结构体
class DestroyPlanRequest < TencentCloud::Common::AbstractModel
# @param PlanId: 套餐 ID,形如 edgeone-2wdo315m2y4c。
# @type PlanId: String
attr_accessor :PlanId
def initialize(planid=nil)
@PlanId = planid
end
def deserialize(params)
@PlanId = params['PlanId']
end
end
# DestroyPlan返回参数结构体
class DestroyPlanResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# 域名配置信息
class DetailHost < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param Status: 加速服务状态,取值为:
# process:部署中;
# online:已启动;
# offline:已关闭。
# @type Status: String
# @param Host: 域名。
# @type Host: String
# @param ZoneName: 站点名称。
# @type ZoneName: String
# @param Cname: 分配的Cname域名
# @type Cname: String
# @param Id: 资源ID。
# @type Id: String
# @param InstanceId: 实例ID。
# @type InstanceId: String
# @param Lock: 锁状态。
# @type Lock: Integer
# @param Mode: 域名状态类型。
# @type Mode: Integer
# @param Area: 域名加速地域,取值有:
# global:全球;
# mainland:中国大陆;
# overseas:境外区域。
# @type Area: String
# @param AccelerateType: 加速类型配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AccelerateType: :class:`Tencentcloud::Teo.v20220901.models.AccelerateType`
# @param Https: Https配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Https: :class:`Tencentcloud::Teo.v20220901.models.Https`
# @param CacheConfig: 缓存配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CacheConfig: :class:`Tencentcloud::Teo.v20220901.models.CacheConfig`
# @param Origin: 源站配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Origin: :class:`Tencentcloud::Teo.v20220901.models.Origin`
# @param SecurityType: 安全类型。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SecurityType: :class:`Tencentcloud::Teo.v20220901.models.SecurityType`
# @param CacheKey: 缓存键配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CacheKey: :class:`Tencentcloud::Teo.v20220901.models.CacheKey`
# @param Compression: 智能压缩配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Compression: :class:`Tencentcloud::Teo.v20220901.models.Compression`
# @param Waf: Waf防护配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Waf: :class:`Tencentcloud::Teo.v20220901.models.Waf`
# @param CC: CC防护配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CC: :class:`Tencentcloud::Teo.v20220901.models.CC`
# @param DDoS: DDoS防护配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DDoS: :class:`Tencentcloud::Teo.v20220901.models.DDoS`
# @param SmartRouting: 智能路由配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SmartRouting: :class:`Tencentcloud::Teo.v20220901.models.SmartRouting`
# @param Ipv6: Ipv6访问配置项。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Ipv6: :class:`Tencentcloud::Teo.v20220901.models.Ipv6`
# @param ClientIpCountry: 回源时是否携带客户端IP所属地域信息的配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClientIpCountry: :class:`Tencentcloud::Teo.v20220901.models.ClientIpCountry`
attr_accessor :ZoneId, :Status, :Host, :ZoneName, :Cname, :Id, :InstanceId, :Lock, :Mode, :Area, :AccelerateType, :Https, :CacheConfig, :Origin, :SecurityType, :CacheKey, :Compression, :Waf, :CC, :DDoS, :SmartRouting, :Ipv6, :ClientIpCountry
def initialize(zoneid=nil, status=nil, host=nil, zonename=nil, cname=nil, id=nil, instanceid=nil, lock=nil, mode=nil, area=nil, acceleratetype=nil, https=nil, cacheconfig=nil, origin=nil, securitytype=nil, cachekey=nil, compression=nil, waf=nil, cc=nil, ddos=nil, smartrouting=nil, ipv6=nil, clientipcountry=nil)
@ZoneId = zoneid
@Status = status
@Host = host
@ZoneName = zonename
@Cname = cname
@Id = id
@InstanceId = instanceid
@Lock = lock
@Mode = mode
@Area = area
@AccelerateType = acceleratetype
@Https = https
@CacheConfig = cacheconfig
@Origin = origin
@SecurityType = securitytype
@CacheKey = cachekey
@Compression = compression
@Waf = waf
@CC = cc
@DDoS = ddos
@SmartRouting = smartrouting
@Ipv6 = ipv6
@ClientIpCountry = clientipcountry
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Status = params['Status']
@Host = params['Host']
@ZoneName = params['ZoneName']
@Cname = params['Cname']
@Id = params['Id']
@InstanceId = params['InstanceId']
@Lock = params['Lock']
@Mode = params['Mode']
@Area = params['Area']
unless params['AccelerateType'].nil?
@AccelerateType = AccelerateType.new
@AccelerateType.deserialize(params['AccelerateType'])
end
unless params['Https'].nil?
@Https = Https.new
@Https.deserialize(params['Https'])
end
unless params['CacheConfig'].nil?
@CacheConfig = CacheConfig.new
@CacheConfig.deserialize(params['CacheConfig'])
end
unless params['Origin'].nil?
@Origin = Origin.new
@Origin.deserialize(params['Origin'])
end
unless params['SecurityType'].nil?
@SecurityType = SecurityType.new
@SecurityType.deserialize(params['SecurityType'])
end
unless params['CacheKey'].nil?
@CacheKey = CacheKey.new
@CacheKey.deserialize(params['CacheKey'])
end
unless params['Compression'].nil?
@Compression = Compression.new
@Compression.deserialize(params['Compression'])
end
unless params['Waf'].nil?
@Waf = Waf.new
@Waf.deserialize(params['Waf'])
end
unless params['CC'].nil?
@CC = CC.new
@CC.deserialize(params['CC'])
end
unless params['DDoS'].nil?
@DDoS = DDoS.new
@DDoS.deserialize(params['DDoS'])
end
unless params['SmartRouting'].nil?
@SmartRouting = SmartRouting.new
@SmartRouting.deserialize(params['SmartRouting'])
end
unless params['Ipv6'].nil?
@Ipv6 = Ipv6.new
@Ipv6.deserialize(params['Ipv6'])
end
unless params['ClientIpCountry'].nil?
@ClientIpCountry = ClientIpCountry.new
@ClientIpCountry.deserialize(params['ClientIpCountry'])
end
end
end
# 最新IP白名单列表相比于当前IP白名单列表的区别
class DiffIPWhitelist < TencentCloud::Common::AbstractModel
# @param LatestIPWhitelist: 最新IP白名单列表。
# @type LatestIPWhitelist: :class:`Tencentcloud::Teo.v20220901.models.IPWhitelist`
# @param AddedIPWhitelist: 最新IP白名单列表相比于当前IP白名单列表,新增部分。
# @type AddedIPWhitelist: :class:`Tencentcloud::Teo.v20220901.models.IPWhitelist`
# @param RemovedIPWhitelist: 最新IP白名单列表相比于当前IP白名单列表,删减部分。
# @type RemovedIPWhitelist: :class:`Tencentcloud::Teo.v20220901.models.IPWhitelist`
# @param NoChangeIPWhitelist: 最新IP白名单列表相比于当前IP白名单列表,不变部分。
# @type NoChangeIPWhitelist: :class:`Tencentcloud::Teo.v20220901.models.IPWhitelist`
attr_accessor :LatestIPWhitelist, :AddedIPWhitelist, :RemovedIPWhitelist, :NoChangeIPWhitelist
def initialize(latestipwhitelist=nil, addedipwhitelist=nil, removedipwhitelist=nil, nochangeipwhitelist=nil)
@LatestIPWhitelist = latestipwhitelist
@AddedIPWhitelist = addedipwhitelist
@RemovedIPWhitelist = removedipwhitelist
@NoChangeIPWhitelist = nochangeipwhitelist
end
def deserialize(params)
unless params['LatestIPWhitelist'].nil?
@LatestIPWhitelist = IPWhitelist.new
@LatestIPWhitelist.deserialize(params['LatestIPWhitelist'])
end
unless params['AddedIPWhitelist'].nil?
@AddedIPWhitelist = IPWhitelist.new
@AddedIPWhitelist.deserialize(params['AddedIPWhitelist'])
end
unless params['RemovedIPWhitelist'].nil?
@RemovedIPWhitelist = IPWhitelist.new
@RemovedIPWhitelist.deserialize(params['RemovedIPWhitelist'])
end
unless params['NoChangeIPWhitelist'].nil?
@NoChangeIPWhitelist = IPWhitelist.new
@NoChangeIPWhitelist.deserialize(params['NoChangeIPWhitelist'])
end
end
end
# CNAME 接入,使用 DNS 解析验证时所需的信息。
class DnsVerification < TencentCloud::Common::AbstractModel
# @param Subdomain: 主机记录。
# @type Subdomain: String
# @param RecordType: 记录类型。
# @type RecordType: String
# @param RecordValue: 记录值。
# @type RecordValue: String
attr_accessor :Subdomain, :RecordType, :RecordValue
def initialize(subdomain=nil, recordtype=nil, recordvalue=nil)
@Subdomain = subdomain
@RecordType = recordtype
@RecordValue = recordvalue
end
def deserialize(params)
@Subdomain = params['Subdomain']
@RecordType = params['RecordType']
@RecordValue = params['RecordValue']
end
end
# DownloadL4Logs请求参数结构体
class DownloadL4LogsRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param ZoneIds: 站点 ID 集合,此参数必填。
# @type ZoneIds: Array
# @param ProxyIds: 四层实例 ID 集合。
# @type ProxyIds: Array
# @param Limit: 分页查询的限制数目,默认值为 20,最大查询条目为 300。
# @type Limit: Integer
# @param Offset: 分页的偏移量,默认值为 0。
# @type Offset: Integer
attr_accessor :StartTime, :EndTime, :ZoneIds, :ProxyIds, :Limit, :Offset
def initialize(starttime=nil, endtime=nil, zoneids=nil, proxyids=nil, limit=nil, offset=nil)
@StartTime = starttime
@EndTime = endtime
@ZoneIds = zoneids
@ProxyIds = proxyids
@Limit = limit
@Offset = offset
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@ZoneIds = params['ZoneIds']
@ProxyIds = params['ProxyIds']
@Limit = params['Limit']
@Offset = params['Offset']
end
end
# DownloadL4Logs返回参数结构体
class DownloadL4LogsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: 四层离线日志数据列表。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
l4offlinelog_tmp = L4OfflineLog.new
l4offlinelog_tmp.deserialize(i)
@Data << l4offlinelog_tmp
end
end
@RequestId = params['RequestId']
end
end
# DownloadL7Logs请求参数结构体
class DownloadL7LogsRequest < TencentCloud::Common::AbstractModel
# @param StartTime: 开始时间。
# @type StartTime: String
# @param EndTime: 结束时间。
# @type EndTime: String
# @param ZoneIds: 站点ID集合,此参数必填。
# @type ZoneIds: Array
# @param Domains: 子域名集合,不填默认选择全部子域名。
# @type Domains: Array
# @param Limit: 分页查询的限制数目,默认值为 20,最大查询条目为 300。
# @type Limit: Integer
# @param Offset: 分页的偏移量,默认值为 0。
# @type Offset: Integer
attr_accessor :StartTime, :EndTime, :ZoneIds, :Domains, :Limit, :Offset
def initialize(starttime=nil, endtime=nil, zoneids=nil, domains=nil, limit=nil, offset=nil)
@StartTime = starttime
@EndTime = endtime
@ZoneIds = zoneids
@Domains = domains
@Limit = limit
@Offset = offset
end
def deserialize(params)
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@ZoneIds = params['ZoneIds']
@Domains = params['Domains']
@Limit = params['Limit']
@Offset = params['Offset']
end
end
# DownloadL7Logs返回参数结构体
class DownloadL7LogsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果的总条数。
# @type TotalCount: Integer
# @param Data: 七层离线日志数据列表。
# @type Data: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :Data, :RequestId
def initialize(totalcount=nil, data=nil, requestid=nil)
@TotalCount = totalcount
@Data = data
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
l7offlinelog_tmp = L7OfflineLog.new
l7offlinelog_tmp.deserialize(i)
@Data << l7offlinelog_tmp
end
end
@RequestId = params['RequestId']
end
end
# 拦截页面的总体配置,用于配置各个模块的拦截后行为。
class DropPageConfig < TencentCloud::Common::AbstractModel
# @param Switch: 配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param WafDropPageDetail: Waf(托管规则)模块的拦截页面配置。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type WafDropPageDetail: :class:`Tencentcloud::Teo.v20220901.models.DropPageDetail`
# @param AclDropPageDetail: 自定义页面的拦截页面配置。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AclDropPageDetail: :class:`Tencentcloud::Teo.v20220901.models.DropPageDetail`
attr_accessor :Switch, :WafDropPageDetail, :AclDropPageDetail
def initialize(switch=nil, wafdroppagedetail=nil, acldroppagedetail=nil)
@Switch = switch
@WafDropPageDetail = wafdroppagedetail
@AclDropPageDetail = acldroppagedetail
end
def deserialize(params)
@Switch = params['Switch']
unless params['WafDropPageDetail'].nil?
@WafDropPageDetail = DropPageDetail.new
@WafDropPageDetail.deserialize(params['WafDropPageDetail'])
end
unless params['AclDropPageDetail'].nil?
@AclDropPageDetail = DropPageDetail.new
@AclDropPageDetail.deserialize(params['AclDropPageDetail'])
end
end
end
# 拦截页面的配置信息
class DropPageDetail < TencentCloud::Common::AbstractModel
# @param PageId: 拦截页面的唯一 Id。系统默认包含一个自带拦截页面,Id 值为0。
# 该 Id 可通过创建拦截页面接口进行上传获取。如传入0,代表使用系统默认拦截页面。该参数已废弃。
# @type PageId: Integer
# @param StatusCode: 拦截页面的 HTTP 状态码。状态码取值:100~600,不支持 3xx 状态码。托管规则拦截页面默认:566,安全防护(除托管规则外)拦截页面默认:567.
# @type StatusCode: Integer
# @param Name: 页面文件名或 url。
# @type Name: String
# @param Type: 页面的类型,取值有:
# page:指定页面。
# @type Type: String
# @param CustomResponseId: 自定义响应 Id。该 Id 可通过查询自定义错误页列表接口获取。默认值为default,使用系统默认页面。Type 类型是 page 时必填,且不能为空。
# @type CustomResponseId: String
attr_accessor :PageId, :StatusCode, :Name, :Type, :CustomResponseId
def initialize(pageid=nil, statuscode=nil, name=nil, type=nil, customresponseid=nil)
@PageId = pageid
@StatusCode = statuscode
@Name = name
@Type = type
@CustomResponseId = customresponseid
end
def deserialize(params)
@PageId = params['PageId']
@StatusCode = params['StatusCode']
@Name = params['Name']
@Type = params['Type']
@CustomResponseId = params['CustomResponseId']
end
end
# 安全实例状态。
class EntityStatus < TencentCloud::Common::AbstractModel
# @param Entity: 实例名,现在只有子域名。
# @type Entity: String
# @param Status: 实例配置下发状态,取值有:
# online:配置已生效;fail:配置失败; process:配置下发中。
# @type Status: String
# @param Message: 实例配置下发信息提示。
# @type Message: String
attr_accessor :Entity, :Status, :Message
def initialize(entity=nil, status=nil, message=nil)
@Entity = entity
@Status = status
@Message = message
end
def deserialize(params)
@Entity = params['Entity']
@Status = params['Status']
@Message = params['Message']
end
end
# 环境信息。
class EnvInfo < TencentCloud::Common::AbstractModel
# @param EnvId: 环境 ID。
# @type EnvId: String
# @param EnvType: 环境类型,取值有:
# production: 生产环境;staging: 测试环境。
# @type EnvType: String
# @param Status: 环境状态,取值有:
# creating:创建中;
# running:稳定运行中,可进行版本变更;
# version_deploying:版本部署中,不能进行新的变更。
# @type Status: String
# @param Scope: 当前环境的配置生效范围:
# 当 EnvType 取值为 production 时,该参数值为 ["ALL"],代表全网生效;
# 当 EnvType 取值为 staging 时,会返回测试节点 IP,可用于绑定 host 测试。
# @type Scope: Array
# @param CurrentConfigGroupVersionInfos: 当前环境中各配置组实际生效的版本,根据 Status 的取值有以下两种情况:
# 当 Status 取值为 version_deploying 时,本字段返回的值为执行变更动作之前生效的版本,即新版本部署期间,实际生效的版本为执行变更动作之前的版本;
# 当 Status 取值为 running 时,本字段返回的值即为当前实际生效的版本。
# @type CurrentConfigGroupVersionInfos: Array
# @param CreateTime: 创建时间。时间为世界标准时间(UTC), 遵循 ISO 8601 标准的日期和时间格式。
# @type CreateTime: String
# @param UpdateTime: 更新时间。时间为世界标准时间(UTC), 遵循 ISO 8601 标准的日期和时间格式。
# @type UpdateTime: String
attr_accessor :EnvId, :EnvType, :Status, :Scope, :CurrentConfigGroupVersionInfos, :CreateTime, :UpdateTime
def initialize(envid=nil, envtype=nil, status=nil, scope=nil, currentconfiggroupversioninfos=nil, createtime=nil, updatetime=nil)
@EnvId = envid
@EnvType = envtype
@Status = status
@Scope = scope
@CurrentConfigGroupVersionInfos = currentconfiggroupversioninfos
@CreateTime = createtime
@UpdateTime = updatetime
end
def deserialize(params)
@EnvId = params['EnvId']
@EnvType = params['EnvType']
@Status = params['Status']
@Scope = params['Scope']
unless params['CurrentConfigGroupVersionInfos'].nil?
@CurrentConfigGroupVersionInfos = []
params['CurrentConfigGroupVersionInfos'].each do |i|
configgroupversioninfo_tmp = ConfigGroupVersionInfo.new
configgroupversioninfo_tmp.deserialize(i)
@CurrentConfigGroupVersionInfos << configgroupversioninfo_tmp
end
end
@CreateTime = params['CreateTime']
@UpdateTime = params['UpdateTime']
end
end
# 自定义错误页面被引用的来源
class ErrorPageReference < TencentCloud::Common::AbstractModel
# @param BusinessId: 引用的业务 ID,如自定义拦截规则 ID。
# @type BusinessId: String
attr_accessor :BusinessId
def initialize(businessid=nil)
@BusinessId = businessid
end
def deserialize(params)
@BusinessId = params['BusinessId']
end
end
# 例外规则,用于配置需要跳过特定场景的规则
class ExceptConfig < TencentCloud::Common::AbstractModel
# @param Switch: 配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param ExceptUserRules: 例外规则详情。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExceptUserRules: Array
attr_accessor :Switch, :ExceptUserRules
def initialize(switch=nil, exceptuserrules=nil)
@Switch = switch
@ExceptUserRules = exceptuserrules
end
def deserialize(params)
@Switch = params['Switch']
unless params['ExceptUserRules'].nil?
@ExceptUserRules = []
params['ExceptUserRules'].each do |i|
exceptuserrule_tmp = ExceptUserRule.new
exceptuserrule_tmp.deserialize(i)
@ExceptUserRules << exceptuserrule_tmp
end
end
end
end
# 例外规则的配置,包含生效的条件,生效的范围。
class ExceptUserRule < TencentCloud::Common::AbstractModel
# @param RuleName: 规则名称,不可使用中文。
# @type RuleName: String
# @param Action: 规则的处置方式,当前仅支持skip:跳过全部托管规则。
# @type Action: String
# @param RuleStatus: 规则生效状态,取值有:
# on:生效;
# off:失效。
# @type RuleStatus: String
# @param RuleID: 规则ID。仅出参使用。默认由底层生成。
# @type RuleID: Integer
# @param UpdateTime: 更新时间,如果为null,默认由底层按当前时间生成。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdateTime: String
# @param ExceptUserRuleConditions: 匹配条件。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExceptUserRuleConditions: Array
# @param ExceptUserRuleScope: 规则生效的范围。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExceptUserRuleScope: :class:`Tencentcloud::Teo.v20220901.models.ExceptUserRuleScope`
# @param RulePriority: 优先级,取值范围0-100。如果为null,默认由底层设置为0。
# @type RulePriority: Integer
attr_accessor :RuleName, :Action, :RuleStatus, :RuleID, :UpdateTime, :ExceptUserRuleConditions, :ExceptUserRuleScope, :RulePriority
def initialize(rulename=nil, action=nil, rulestatus=nil, ruleid=nil, updatetime=nil, exceptuserruleconditions=nil, exceptuserrulescope=nil, rulepriority=nil)
@RuleName = rulename
@Action = action
@RuleStatus = rulestatus
@RuleID = ruleid
@UpdateTime = updatetime
@ExceptUserRuleConditions = exceptuserruleconditions
@ExceptUserRuleScope = exceptuserrulescope
@RulePriority = rulepriority
end
def deserialize(params)
@RuleName = params['RuleName']
@Action = params['Action']
@RuleStatus = params['RuleStatus']
@RuleID = params['RuleID']
@UpdateTime = params['UpdateTime']
unless params['ExceptUserRuleConditions'].nil?
@ExceptUserRuleConditions = []
params['ExceptUserRuleConditions'].each do |i|
exceptuserrulecondition_tmp = ExceptUserRuleCondition.new
exceptuserrulecondition_tmp.deserialize(i)
@ExceptUserRuleConditions << exceptuserrulecondition_tmp
end
end
unless params['ExceptUserRuleScope'].nil?
@ExceptUserRuleScope = ExceptUserRuleScope.new
@ExceptUserRuleScope.deserialize(params['ExceptUserRuleScope'])
end
@RulePriority = params['RulePriority']
end
end
# 例外规则生效的具体条件。
class ExceptUserRuleCondition < TencentCloud::Common::AbstractModel
# @param MatchFrom: 匹配项,取值有:
# host:请求域名;
# sip:客户端IP;
# ua:User-Agent;
# cookie:会话 Cookie;
# cgi:CGI 脚本;
# xff:XFF 扩展头部;
# url:请求 URL;
# accept:请求内容类型;
# method:请求方式;
# header:请求头部;
# sip_proto:网络层协议。
# @type MatchFrom: String
# @param MatchParam: 匹配项的参数。仅当 MatchFrom 为 header 时,可以使用本参数,值可填入 header 的 key 作为参数。
# @type MatchParam: String
# @param Operator: 匹配操作符,取值有:
# equal:字符串等于;
# not_equal:数值不等于;
# include:字符包含;
# not_include:字符不包含;
# match:ip匹配;
# not_match:ip不匹配;
# include_area:地域包含;
# is_empty:存在字段但值为空;
# not_exists:不存在关键字段;
# regexp:正则匹配;
# len_gt:数值大于;
# len_lt:数值小于;
# len_eq:数值等于;
# match_prefix:前缀匹配;
# match_suffix:后缀匹配;
# wildcard:通配符。
# @type Operator: String
# @param MatchContent: 匹配值。
# @type MatchContent: String
attr_accessor :MatchFrom, :MatchParam, :Operator, :MatchContent
def initialize(matchfrom=nil, matchparam=nil, operator=nil, matchcontent=nil)
@MatchFrom = matchfrom
@MatchParam = matchparam
@Operator = operator
@MatchContent = matchcontent
end
def deserialize(params)
@MatchFrom = params['MatchFrom']
@MatchParam = params['MatchParam']
@Operator = params['Operator']
@MatchContent = params['MatchContent']
end
end
# 例外规则的生效范围。
class ExceptUserRuleScope < TencentCloud::Common::AbstractModel
# @param Type: 例外规则类型。其中complete模式代表全量数据进行例外,partial模式代表可选择指定模块指定字段进行例外,该字段取值有:
# complete:完全跳过模式;
# partial:部分跳过模式。
# @type Type: String
# @param Modules: 生效的模块,该字段取值有:
# waf:托管规则;
# rate:速率限制;
# acl:自定义规则;
# cc:cc攻击防护;
# bot:Bot防护。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Modules: Array
# @param PartialModules: 跳过部分规则ID的例外规则详情。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PartialModules: Array
# @param SkipConditions: 跳过具体字段不去扫描的例外规则详情。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SkipConditions: Array
attr_accessor :Type, :Modules, :PartialModules, :SkipConditions
def initialize(type=nil, modules=nil, partialmodules=nil, skipconditions=nil)
@Type = type
@Modules = modules
@PartialModules = partialmodules
@SkipConditions = skipconditions
end
def deserialize(params)
@Type = params['Type']
@Modules = params['Modules']
unless params['PartialModules'].nil?
@PartialModules = []
params['PartialModules'].each do |i|
partialmodule_tmp = PartialModule.new
partialmodule_tmp.deserialize(i)
@PartialModules << partialmodule_tmp
end
end
unless params['SkipConditions'].nil?
@SkipConditions = []
params['SkipConditions'].each do |i|
skipcondition_tmp = SkipCondition.new
skipcondition_tmp.deserialize(i)
@SkipConditions << skipcondition_tmp
end
end
end
end
# ExportZoneConfig请求参数结构体
class ExportZoneConfigRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Types: 导出配置项的类型列表,不填表示导出所有类型的配置,当前支持的取值有:L7AccelerationConfig:表示导出七层加速配置,对应控制台「站点加速-全局加速配置」和「站点加速-规则引擎」。
# 需注意:后续支持导出的类型会随着迭代增加,导出所有类型时需要注意导出文件大小,建议使用时指定需要导出的配置类型,以便控制请求响应包负载大小。
# @type Types: Array
attr_accessor :ZoneId, :Types
def initialize(zoneid=nil, types=nil)
@ZoneId = zoneid
@Types = types
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Types = params['Types']
end
end
# ExportZoneConfig返回参数结构体
class ExportZoneConfigResponse < TencentCloud::Common::AbstractModel
# @param Content: 导出的配置的具体内容。以 JSON 格式返回,按照 UTF-8 方式进行编码。配置内容可参考下方示例。
# @type Content: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Content, :RequestId
def initialize(content=nil, requestid=nil)
@Content = content
@RequestId = requestid
end
def deserialize(params)
@Content = params['Content']
@RequestId = params['RequestId']
end
end
# 失败原因
class FailReason < TencentCloud::Common::AbstractModel
# @param Reason: 失败原因。
# @type Reason: String
# @param Targets: 处理失败的资源列表。
# @type Targets: Array
attr_accessor :Reason, :Targets
def initialize(reason=nil, targets=nil)
@Reason = reason
@Targets = targets
end
def deserialize(params)
@Reason = params['Reason']
@Targets = params['Targets']
end
end
# 站点归属权校验——文件校验信息。
class FileAscriptionInfo < TencentCloud::Common::AbstractModel
# @param IdentifyPath: 文件校验目录。
# @type IdentifyPath: String
# @param IdentifyContent: 文件校验内容。
# @type IdentifyContent: String
attr_accessor :IdentifyPath, :IdentifyContent
def initialize(identifypath=nil, identifycontent=nil)
@IdentifyPath = identifypath
@IdentifyContent = identifycontent
end
def deserialize(params)
@IdentifyPath = params['IdentifyPath']
@IdentifyContent = params['IdentifyContent']
end
end
# CNAME 接入,使用文件验证时所需的信息。
class FileVerification < TencentCloud::Common::AbstractModel
# @param Path: EdgeOne 后台服务器将通过 Scheme + Host + URL Path 的格式(例如 https://www.example.com/.well-known/teo-verification/z12h416twn.txt)获取文件验证信息。该字段为您需要创建的 URL Path 部分。
# @type Path: String
# @param Content: 验证文件的内容。该字段的内容需要您填写至 Path 字段返回的 txt 文件中。
# @type Content: String
attr_accessor :Path, :Content
def initialize(path=nil, content=nil)
@Path = path
@Content = content
end
def deserialize(params)
@Path = params['Path']
@Content = params['Content']
end
end
# 描述键值对过滤器,用于条件过滤查询。例如过滤ID、名称、状态等。
# 若存在多个Filter时,Filter间的关系为逻辑与(AND)关系。
# 若同一个Filter存在多个Values,同一Filter下Values间的关系为逻辑或(OR)关系。
class Filter < TencentCloud::Common::AbstractModel
# @param Name: 需要过滤的字段。
# @type Name: String
# @param Values: 字段的过滤值。
# @type Values: Array
attr_accessor :Name, :Values
def initialize(name=nil, values=nil)
@Name = name
@Values = values
end
def deserialize(params)
@Name = params['Name']
@Values = params['Values']
end
end
# 慢速攻击的首段包配置。
class FirstPartConfig < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Switch: String
# @param StatTime: 首段包的统计时长,单位是秒,即期望首段包的统计时长是多少,默认5秒。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StatTime: Integer
attr_accessor :Switch, :StatTime
def initialize(switch=nil, stattime=nil)
@Switch = switch
@StatTime = stattime
end
def deserialize(params)
@Switch = params['Switch']
@StatTime = params['StatTime']
end
end
# 缓存遵循源站配置。
class FollowOrigin < TencentCloud::Common::AbstractModel
# @param Switch: 遵循源站配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param DefaultCache: 源站未返回 Cache-Control 头时,缓存/不缓存开关。当 Switch 为 on 时,此字段必填,否则此字段不生效。取值有:
# on:缓存;
# off:不缓存。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DefaultCache: String
# @param DefaultCacheStrategy: 源站未返回 Cache-Control 头时,使用/不使用默认缓存策略开关。当 DefaultCache 为 on 时,此字段必填,否则此字段不生效;当 DefaultCacheTime 不为 0 时,此字段必须为 off。取值有:
# on:使用默认缓存策略;
# off:不使用默认缓存策略。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DefaultCacheStrategy: String
# @param DefaultCacheTime: 源站未返回 Cache-Control 头时,表示默认的缓存时间,单位为秒,取值:0~315360000。当 DefaultCache 为 on 时,此字段必填,否则此字段不生效;当 DefaultCacheStrategy 为 on 时, 此字段必须为 0。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DefaultCacheTime: Integer
attr_accessor :Switch, :DefaultCache, :DefaultCacheStrategy, :DefaultCacheTime
def initialize(switch=nil, defaultcache=nil, defaultcachestrategy=nil, defaultcachetime=nil)
@Switch = switch
@DefaultCache = defaultcache
@DefaultCacheStrategy = defaultcachestrategy
@DefaultCacheTime = defaultcachetime
end
def deserialize(params)
@Switch = params['Switch']
@DefaultCache = params['DefaultCache']
@DefaultCacheStrategy = params['DefaultCacheStrategy']
@DefaultCacheTime = params['DefaultCacheTime']
end
end
# 访问协议强制 HTTPS 跳转配置。
class ForceRedirect < TencentCloud::Common::AbstractModel
# @param Switch: 访问强制跳转配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param RedirectStatusCode: 重定向状态码,取值有:
# 301:301跳转;
# 302:302跳转。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RedirectStatusCode: Integer
attr_accessor :Switch, :RedirectStatusCode
def initialize(switch=nil, redirectstatuscode=nil)
@Switch = switch
@RedirectStatusCode = redirectstatuscode
end
def deserialize(params)
@Switch = params['Switch']
@RedirectStatusCode = params['RedirectStatusCode']
end
end
# 边缘函数详情
class Function < TencentCloud::Common::AbstractModel
# @param FunctionId: 函数 ID。
# @type FunctionId: String
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Name: 函数名字。
# @type Name: String
# @param Remark: 函数描述。
# @type Remark: String
# @param Content: 函数内容。
# @type Content: String
# @param Domain: 函数默认域名。
# @type Domain: String
# @param CreateTime: 创建时间。时间为世界标准时间(UTC), 遵循 ISO 8601 标准的日期和时间格式。
# @type CreateTime: String
# @param UpdateTime: 修改时间。时间为世界标准时间(UTC), 遵循 ISO 8601 标准的日期和时间格式。
# @type UpdateTime: String
attr_accessor :FunctionId, :ZoneId, :Name, :Remark, :Content, :Domain, :CreateTime, :UpdateTime
def initialize(functionid=nil, zoneid=nil, name=nil, remark=nil, content=nil, domain=nil, createtime=nil, updatetime=nil)
@FunctionId = functionid
@ZoneId = zoneid
@Name = name
@Remark = remark
@Content = content
@Domain = domain
@CreateTime = createtime
@UpdateTime = updatetime
end
def deserialize(params)
@FunctionId = params['FunctionId']
@ZoneId = params['ZoneId']
@Name = params['Name']
@Remark = params['Remark']
@Content = params['Content']
@Domain = params['Domain']
@CreateTime = params['CreateTime']
@UpdateTime = params['UpdateTime']
end
end
# 边缘函数环境变量
class FunctionEnvironmentVariable < TencentCloud::Common::AbstractModel
# @param Key: 变量的名称,限制只能包含大小写字母、数字,特殊字符仅支持 @ . - _ ,最大 64 个字节,不支持重复。
# @type Key: String
# @param Value: 变量的值,限制最大 5000 字节,默认值为空。
# @type Value: String
# @param Type: 变量的类型,取值有:
# string:字符串类型;
# json:json 对象类型。默认值为:string。
# @type Type: String
attr_accessor :Key, :Value, :Type
def initialize(key=nil, value=nil, type=nil)
@Key = key
@Value = value
@Type = type
end
def deserialize(params)
@Key = params['Key']
@Value = params['Value']
@Type = params['Type']
end
end
# 边缘函数触发规则。
class FunctionRule < TencentCloud::Common::AbstractModel
# @param RuleId: 规则ID。
# @type RuleId: String
# @param FunctionRuleConditions: 规则条件列表,列表项之间为或关系。
# @type FunctionRuleConditions: Array
# @param FunctionId: 函数 ID,命中触发规则条件后执行的函数。
# @type FunctionId: String
# @param Remark: 规则描述。
# @type Remark: String
# @param FunctionName: 函数名称。
# @type FunctionName: String
# @param Priority: 函数触发规则优先级,数值越大,优先级越高。
# @type Priority: Integer
# @param CreateTime: 创建时间。时间为世界标准时间(UTC), 遵循 ISO 8601 标准的日期和时间格式。
# @type CreateTime: String
# @param UpdateTime: 更新时间。时间为世界标准时间(UTC), 遵循 ISO 8601 标准的日期和时间格式。
# @type UpdateTime: String
attr_accessor :RuleId, :FunctionRuleConditions, :FunctionId, :Remark, :FunctionName, :Priority, :CreateTime, :UpdateTime
def initialize(ruleid=nil, functionruleconditions=nil, functionid=nil, remark=nil, functionname=nil, priority=nil, createtime=nil, updatetime=nil)
@RuleId = ruleid
@FunctionRuleConditions = functionruleconditions
@FunctionId = functionid
@Remark = remark
@FunctionName = functionname
@Priority = priority
@CreateTime = createtime
@UpdateTime = updatetime
end
def deserialize(params)
@RuleId = params['RuleId']
unless params['FunctionRuleConditions'].nil?
@FunctionRuleConditions = []
params['FunctionRuleConditions'].each do |i|
functionrulecondition_tmp = FunctionRuleCondition.new
functionrulecondition_tmp.deserialize(i)
@FunctionRuleConditions << functionrulecondition_tmp
end
end
@FunctionId = params['FunctionId']
@Remark = params['Remark']
@FunctionName = params['FunctionName']
@Priority = params['Priority']
@CreateTime = params['CreateTime']
@UpdateTime = params['UpdateTime']
end
end
# 边缘函数触发规则条件。
class FunctionRuleCondition < TencentCloud::Common::AbstractModel
# @param RuleConditions: 边缘函数触发规则条件,该列表内所有项全部满足即判断该条件满足。
# @type RuleConditions: Array
attr_accessor :RuleConditions
def initialize(ruleconditions=nil)
@RuleConditions = ruleconditions
end
def deserialize(params)
unless params['RuleConditions'].nil?
@RuleConditions = []
params['RuleConditions'].each do |i|
rulecondition_tmp = RuleCondition.new
rulecondition_tmp.deserialize(i)
@RuleConditions << rulecondition_tmp
end
end
end
end
# Grpc配置项
class Grpc < TencentCloud::Common::AbstractModel
# @param Switch: 是否开启 Grpc 配置,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# HandleFunctionRuntimeEnvironment请求参数结构体
class HandleFunctionRuntimeEnvironmentRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param FunctionId: 函数 ID。
# @type FunctionId: String
# @param Operation: 操作类型,取值有:
# setEnvironmentVariable:设置环境变量,当环境变量存在时为修改行为,否则为添加行为;
# deleteEnvironmentVariable:删除环境变量变量;
# clearEnvironmentVariable:清空环境变量变量;
# resetEnvironmentVariable:重置环境变量变量。
# @type Operation: String
# @param EnvironmentVariables: 环境变量列表,函数运行环境最多支持 64 个变量。当 Operation 取值为 setEnvironmentVariable、deleteEnvironmentVariable、resetEnvironmentVariable 时必填。
# @type EnvironmentVariables: Array
attr_accessor :ZoneId, :FunctionId, :Operation, :EnvironmentVariables
def initialize(zoneid=nil, functionid=nil, operation=nil, environmentvariables=nil)
@ZoneId = zoneid
@FunctionId = functionid
@Operation = operation
@EnvironmentVariables = environmentvariables
end
def deserialize(params)
@ZoneId = params['ZoneId']
@FunctionId = params['FunctionId']
@Operation = params['Operation']
unless params['EnvironmentVariables'].nil?
@EnvironmentVariables = []
params['EnvironmentVariables'].each do |i|
functionenvironmentvariable_tmp = FunctionEnvironmentVariable.new
functionenvironmentvariable_tmp.deserialize(i)
@EnvironmentVariables << functionenvironmentvariable_tmp
end
end
end
end
# HandleFunctionRuntimeEnvironment返回参数结构体
class HandleFunctionRuntimeEnvironmentResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# 刷新预热附带的头部信息
class Header < TencentCloud::Common::AbstractModel
# @param Name: HTTP头部名称。
# @type Name: String
# @param Value: HTTP头部值。
# @type Value: String
attr_accessor :Name, :Value
def initialize(name=nil, value=nil)
@Name = name
@Value = value
end
def deserialize(params)
@Name = params['Name']
@Value = params['Value']
end
end
# 负载均衡实例健康检查策略。
class HealthChecker < TencentCloud::Common::AbstractModel
# @param Type: 健康检查策略,取值有:
# HTTP;
# HTTPS;
# TCP;
# UDP;
# ICMP Ping;
# NoCheck。
# 注意:NoCheck 表示不启用健康检查策略。
# @type Type: String
# @param Port: 检查端口。当 Type=HTTP 或 Type=HTTPS 或 Type=TCP 或 Type=UDP 时为必填。
# @type Port: Integer
# @param Interval: 检查频率,表示多久发起一次健康检查任务,单位为秒。可取值有:30,60,180,300 或 600。
# @type Interval: Integer
# @param Timeout: 每一次健康检查的超时时间,若健康检查消耗时间大于此值,则检查结果判定为”不健康“, 单位为秒,默认值为 5s,取值必须小于 Interval。
# @type Timeout: Integer
# @param HealthThreshold: 健康阈值,表示连续几次健康检查结果为"健康",则判断源站为"健康",单位为次,默认 3 次,最小取值 1 次。
# @type HealthThreshold: Integer
# @param CriticalThreshold: 不健康阈值,表示连续几次健康检查结果为"不健康",则判断源站为"不健康",单位为次,默认 2 次。
# @type CriticalThreshold: Integer
# @param Path: 该参数仅当 Type=HTTP 或 Type=HTTPS 时有效,表示探测路径,需要填写完整的 host/path,不包含协议部分,例如:www.example.com/test。
# @type Path: String
# @param Method: 该参数仅当 Type=HTTP 或 Type=HTTPS 时有效,表示请求方法,取值有:
# GET;
# HEAD。
# @type Method: String
# @param ExpectedCodes: 该参数仅当 Type=HTTP 或 Type=HTTPS 时有效,表示探测节点向源站发起健康检查时,响应哪些状态码可用于认定探测结果为健康。
# @type ExpectedCodes: Array
# @param Headers: 该参数仅当 Type=HTTP 或 Type=HTTPS 时有效,表示探测请求携带的自定义 HTTP 请求头,至多可配置 10 个。
# @type Headers: Array
# @param FollowRedirect: 该参数仅当 Type=HTTP 或 Type=HTTPS 时有效,表示是否启用遵循 301/302 重定向。启用后,301/302 默认为"健康"的状态码,默认跳转 3 次。
# @type FollowRedirect: String
# @param SendContext: 该参数仅当 Type=UDP 时有效,表示健康检查发送的内容。只允许 ASCII 可见字符,最大长度限制 500 个字符。
# @type SendContext: String
# @param RecvContext: 该参数仅当 Type=UDP 时有效,表示健康检查期望源站返回结果。只允许 ASCII 可见字符,最大长度限制 500 个字符。
# @type RecvContext: String
attr_accessor :Type, :Port, :Interval, :Timeout, :HealthThreshold, :CriticalThreshold, :Path, :Method, :ExpectedCodes, :Headers, :FollowRedirect, :SendContext, :RecvContext
def initialize(type=nil, port=nil, interval=nil, timeout=nil, healththreshold=nil, criticalthreshold=nil, path=nil, method=nil, expectedcodes=nil, headers=nil, followredirect=nil, sendcontext=nil, recvcontext=nil)
@Type = type
@Port = port
@Interval = interval
@Timeout = timeout
@HealthThreshold = healththreshold
@CriticalThreshold = criticalthreshold
@Path = path
@Method = method
@ExpectedCodes = expectedcodes
@Headers = headers
@FollowRedirect = followredirect
@SendContext = sendcontext
@RecvContext = recvcontext
end
def deserialize(params)
@Type = params['Type']
@Port = params['Port']
@Interval = params['Interval']
@Timeout = params['Timeout']
@HealthThreshold = params['HealthThreshold']
@CriticalThreshold = params['CriticalThreshold']
@Path = params['Path']
@Method = params['Method']
@ExpectedCodes = params['ExpectedCodes']
unless params['Headers'].nil?
@Headers = []
params['Headers'].each do |i|
customizedheader_tmp = CustomizedHeader.new
customizedheader_tmp.deserialize(i)
@Headers << customizedheader_tmp
end
end
@FollowRedirect = params['FollowRedirect']
@SendContext = params['SendContext']
@RecvContext = params['RecvContext']
end
end
# Hsts配置
class Hsts < TencentCloud::Common::AbstractModel
# @param Switch: 是否开启,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param MaxAge: MaxAge 数值。单位为秒,最大值为1天。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MaxAge: Integer
# @param IncludeSubDomains: 是否包含子域名,取值有:
# on:开启;
# off:关闭。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IncludeSubDomains: String
# @param Preload: 是否开启预加载,取值有:
# on:开启;
# off:关闭。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Preload: String
attr_accessor :Switch, :MaxAge, :IncludeSubDomains, :Preload
def initialize(switch=nil, maxage=nil, includesubdomains=nil, preload=nil)
@Switch = switch
@MaxAge = maxage
@IncludeSubDomains = includesubdomains
@Preload = preload
end
def deserialize(params)
@Switch = params['Switch']
@MaxAge = params['MaxAge']
@IncludeSubDomains = params['IncludeSubDomains']
@Preload = params['Preload']
end
end
# 域名 https 加速配置,默认为关闭状态
class Https < TencentCloud::Common::AbstractModel
# @param Http2: http2 配置开关,取值有:
# on:开启;
# off:关闭。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Http2: String
# @param OcspStapling: OCSP 配置开关,取值有:
# on:开启;
# off:关闭。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OcspStapling: String
# @param TlsVersion: Tls 版本设置,取值有:
# TLSv1:TLSv1版本;
# TLSV1.1:TLSv1.1版本;
# TLSV1.2:TLSv1.2版本;
# TLSv1.3:TLSv1.3版本。修改时必须开启连续的版本。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TlsVersion: Array
# @param Hsts: HSTS 配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Hsts: :class:`Tencentcloud::Teo.v20220901.models.Hsts`
# @param CertInfo: 证书配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CertInfo: Array
# @param ApplyType: 申请类型,取值有:
# apply:托管EdgeOne;
# none:不托管EdgeOne。不填,默认取值为none。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApplyType: String
# @param CipherSuite: 密码套件,取值有:
# loose-v2023:提供高兼容性,安全性一般,支持 TLS 1.0-1.3 密码套件;
# general-v2023:提供较高兼容性,安全性中等,支持 TLS 1.2-1.3 密码套件;
# strict-v2023:提供高安全性能,禁用所有含不安全隐患的加密套件,支持 TLS 1.2-1.3 密码套件。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CipherSuite: String
attr_accessor :Http2, :OcspStapling, :TlsVersion, :Hsts, :CertInfo, :ApplyType, :CipherSuite
def initialize(http2=nil, ocspstapling=nil, tlsversion=nil, hsts=nil, certinfo=nil, applytype=nil, ciphersuite=nil)
@Http2 = http2
@OcspStapling = ocspstapling
@TlsVersion = tlsversion
@Hsts = hsts
@CertInfo = certinfo
@ApplyType = applytype
@CipherSuite = ciphersuite
end
def deserialize(params)
@Http2 = params['Http2']
@OcspStapling = params['OcspStapling']
@TlsVersion = params['TlsVersion']
unless params['Hsts'].nil?
@Hsts = Hsts.new
@Hsts.deserialize(params['Hsts'])
end
unless params['CertInfo'].nil?
@CertInfo = []
params['CertInfo'].each do |i|
servercertinfo_tmp = ServerCertInfo.new
servercertinfo_tmp.deserialize(i)
@CertInfo << servercertinfo_tmp
end
end
@ApplyType = params['ApplyType']
@CipherSuite = params['CipherSuite']
end
end
# IP 网段组
class IPGroup < TencentCloud::Common::AbstractModel
# @param GroupId: 组 Id,创建时填 0 即可。
# @type GroupId: Integer
# @param Name: 组名称。
# @type Name: String
# @param Content: IP 组内容,仅支持 IP 及 IP 掩码。
# @type Content: Array
attr_accessor :GroupId, :Name, :Content
def initialize(groupid=nil, name=nil, content=nil)
@GroupId = groupid
@Name = name
@Content = content
end
def deserialize(params)
@GroupId = params['GroupId']
@Name = params['Name']
@Content = params['Content']
end
end
# IP 归属信息查询
class IPRegionInfo < TencentCloud::Common::AbstractModel
# @param IP: IP 地址,IPV4 或 IPV6。
# @type IP: String
# @param IsEdgeOneIP: IP 是否属于 EdgeOne 节点,取值有:
# yes:该 IP 属于 EdgeOne 节点;
# no:该 IP 不属于 EdgeOne 节点。
# @type IsEdgeOneIP: String
attr_accessor :IP, :IsEdgeOneIP
def initialize(ip=nil, isedgeoneip=nil)
@IP = ip
@IsEdgeOneIP = isedgeoneip
end
def deserialize(params)
@IP = params['IP']
@IsEdgeOneIP = params['IsEdgeOneIP']
end
end
# 源站防护IP白名单
class IPWhitelist < TencentCloud::Common::AbstractModel
# @param IPv4: IPv4列表。
# @type IPv4: Array
# @param IPv6: IPv6列表。
# @type IPv6: Array
attr_accessor :IPv4, :IPv6
def initialize(ipv4=nil, ipv6=nil)
@IPv4 = ipv4
@IPv6 = ipv6
end
def deserialize(params)
@IPv4 = params['IPv4']
@IPv6 = params['IPv6']
end
end
# 站点验证信息
class Identification < TencentCloud::Common::AbstractModel
# @param ZoneName: 站点名称。
# @type ZoneName: String
# @param Domain: 验证子域名。验证站点时,该值为空。验证子域名是为具体子域名。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Domain: String
# @param Status: 验证状态,取值有:
# pending:验证中;
# finished:验证完成。
# @type Status: String
# @param Ascription: 站点归属权校验:Dns校验信息。
# @type Ascription: :class:`Tencentcloud::Teo.v20220901.models.AscriptionInfo`
# @param OriginalNameServers: 域名当前的 NS 记录。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OriginalNameServers: Array
# @param FileAscription: 站点归属权校验:文件校验信息。
# @type FileAscription: :class:`Tencentcloud::Teo.v20220901.models.FileAscriptionInfo`
attr_accessor :ZoneName, :Domain, :Status, :Ascription, :OriginalNameServers, :FileAscription
def initialize(zonename=nil, domain=nil, status=nil, ascription=nil, originalnameservers=nil, fileascription=nil)
@ZoneName = zonename
@Domain = domain
@Status = status
@Ascription = ascription
@OriginalNameServers = originalnameservers
@FileAscription = fileascription
end
def deserialize(params)
@ZoneName = params['ZoneName']
@Domain = params['Domain']
@Status = params['Status']
unless params['Ascription'].nil?
@Ascription = AscriptionInfo.new
@Ascription.deserialize(params['Ascription'])
end
@OriginalNameServers = params['OriginalNameServers']
unless params['FileAscription'].nil?
@FileAscription = FileAscriptionInfo.new
@FileAscription.deserialize(params['FileAscription'])
end
end
end
# IdentifyZone请求参数结构体
class IdentifyZoneRequest < TencentCloud::Common::AbstractModel
# @param ZoneName: 站点名称。
# @type ZoneName: String
# @param Domain: 站点下的子域名。如果验证站点下的子域名,则传该值,否则为空。
# @type Domain: String
attr_accessor :ZoneName, :Domain
def initialize(zonename=nil, domain=nil)
@ZoneName = zonename
@Domain = domain
end
def deserialize(params)
@ZoneName = params['ZoneName']
@Domain = params['Domain']
end
end
# IdentifyZone返回参数结构体
class IdentifyZoneResponse < TencentCloud::Common::AbstractModel
# @param Ascription: 站点归属校验:Dns校验信息。
# @type Ascription: :class:`Tencentcloud::Teo.v20220901.models.AscriptionInfo`
# @param FileAscription: 站点归属权校验:文件校验信息。
# @type FileAscription: :class:`Tencentcloud::Teo.v20220901.models.FileAscriptionInfo`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Ascription, :FileAscription, :RequestId
def initialize(ascription=nil, fileascription=nil, requestid=nil)
@Ascription = ascription
@FileAscription = fileascription
@RequestId = requestid
end
def deserialize(params)
unless params['Ascription'].nil?
@Ascription = AscriptionInfo.new
@Ascription.deserialize(params['Ascription'])
end
unless params['FileAscription'].nil?
@FileAscription = FileAscriptionInfo.new
@FileAscription.deserialize(params['FileAscription'])
end
@RequestId = params['RequestId']
end
end
# 图片优化配置。
class ImageOptimize < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# ImportZoneConfig请求参数结构体
class ImportZoneConfigRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Content: 待导入的配置内容。要求采用 JSON 格式,按照 UTF-8 方式进行编码。配置内容可通过站点配置导出接口(ExportZoneConfig)获取。您可以单独导入「站点加速-全局加速配置」或「站点加速-规则引擎」,传入对应的字段即可,详情可以参考下方示例。
# @type Content: String
attr_accessor :ZoneId, :Content
def initialize(zoneid=nil, content=nil)
@ZoneId = zoneid
@Content = content
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Content = params['Content']
end
end
# ImportZoneConfig返回参数结构体
class ImportZoneConfigResponse < TencentCloud::Common::AbstractModel
# @param TaskId: 表示该次导入配置的任务 Id,通过查询站点配置导入结果接口(DescribeZoneConfigImportResult)获取本次导入任务执行的结果。注意:导入任务 Id 仅支持查询最近 7 天的导入任务。
# @type TaskId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TaskId, :RequestId
def initialize(taskid=nil, requestid=nil)
@TaskId = taskid
@RequestId = requestid
end
def deserialize(params)
@TaskId = params['TaskId']
@RequestId = params['RequestId']
end
end
# IncreasePlanQuota请求参数结构体
class IncreasePlanQuotaRequest < TencentCloud::Common::AbstractModel
# @param PlanId: 套餐 ID, 形如 edgeone-2unuvzjmmn2q。
# @type PlanId: String
# @param QuotaType: 新增的套餐配额类型,取值有: site:站点数; precise_access_control_rule:Web 防护 - 自定义规则 - 精准匹配策略的规则配额; rate_limiting_rule:Web 防护 - 速率限制 - 精准速率限制模块的规则配额。
# @type QuotaType: String
# @param QuotaNumber: 新增的配额个数。单次新增的配额个数上限为 100。
# @type QuotaNumber: Integer
attr_accessor :PlanId, :QuotaType, :QuotaNumber
def initialize(planid=nil, quotatype=nil, quotanumber=nil)
@PlanId = planid
@QuotaType = quotatype
@QuotaNumber = quotanumber
end
def deserialize(params)
@PlanId = params['PlanId']
@QuotaType = params['QuotaType']
@QuotaNumber = params['QuotaNumber']
end
end
# IncreasePlanQuota返回参数结构体
class IncreasePlanQuotaResponse < TencentCloud::Common::AbstractModel
# @param DealName: 订单号。
# @type DealName: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :DealName, :RequestId
def initialize(dealname=nil, requestid=nil)
@DealName = dealname
@RequestId = requestid
end
def deserialize(params)
@DealName = params['DealName']
@RequestId = params['RequestId']
end
end
# 智能分析规则
class IntelligenceRule < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Switch: String
# @param IntelligenceRuleItems: 规则详情。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IntelligenceRuleItems: Array
attr_accessor :Switch, :IntelligenceRuleItems
def initialize(switch=nil, intelligenceruleitems=nil)
@Switch = switch
@IntelligenceRuleItems = intelligenceruleitems
end
def deserialize(params)
@Switch = params['Switch']
unless params['IntelligenceRuleItems'].nil?
@IntelligenceRuleItems = []
params['IntelligenceRuleItems'].each do |i|
intelligenceruleitem_tmp = IntelligenceRuleItem.new
intelligenceruleitem_tmp.deserialize(i)
@IntelligenceRuleItems << intelligenceruleitem_tmp
end
end
end
end
# Bot智能分析规则详情
class IntelligenceRuleItem < TencentCloud::Common::AbstractModel
# @param Label: 智能分析标签,取值有:
# evil_bot:恶意bot;
# suspect_bot:疑似bot;
# good_bot:良好bot;
# normal:正常请求。
# @type Label: String
# @param Action: 触发智能分析标签对应的处置方式,取值有:
# drop:拦截;
# trans:放行;
# alg:Javascript挑战;
# captcha:数字验证码;
# monitor:观察。
# @type Action: String
attr_accessor :Label, :Action
def initialize(label=nil, action=nil)
@Label = label
@Action = action
end
def deserialize(params)
@Label = params['Label']
@Action = params['Action']
end
end
# IP黑白名单及IP区域控制配置
class IpTableConfig < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Switch: String
# @param IpTableRules: 基础管控规则。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IpTableRules: Array
attr_accessor :Switch, :IpTableRules
def initialize(switch=nil, iptablerules=nil)
@Switch = switch
@IpTableRules = iptablerules
end
def deserialize(params)
@Switch = params['Switch']
unless params['IpTableRules'].nil?
@IpTableRules = []
params['IpTableRules'].each do |i|
iptablerule_tmp = IpTableRule.new
iptablerule_tmp.deserialize(i)
@IpTableRules << iptablerule_tmp
end
end
end
end
# 自定义规则-基础访问管控配置。
class IpTableRule < TencentCloud::Common::AbstractModel
# @param Action: 动作,取值有:
# drop:拦截;
# trans:放行;
# monitor:观察。
# @type Action: String
# @param MatchFrom: 根据类型匹配,取值有:
# ip:客户端 IP 进行匹配;
# area:客户端 IP 所属地区匹配;
# asn:客户端所属的自治系统进行匹配;
# referer:请求头 Referer 进行匹配;
# ua:请求头 User-Agent 进行匹配;
# url:请求 URL 进行匹配。
# @type MatchFrom: String
# @param Operator: 规则的匹配方式。取值有:
# match:匹配,适用于 MatchFrom 为 ip;
# not_match:不匹配,适用于 MatchFrom 为 ip;
# include_area:地域包含,适用于 MatchFrom 为 area;
# not_include_area:地域不包含,适用于 MatchFrom 为 area;
# asn_match:ASN 包含,适用于 MatchFrom 为 asn;
# asn_not_match:ASN 不包含,适用于 MatchFrom 为 asn;
# equal:等于,适用于 MatchFrom 为 ua , referer;
# not_equal:不等于,适用于 MatchFrom 为 ua , referer;
# include:通配符匹配,适用于 MatchFrom 为 ua , referer , url;
# not_include:通配符不匹配,适用于 MatchFrom 为 ua , referer;
# is_emty:配置内容为空,适用于 MatchFrom 为 ua , referer;
# not_exists:配置内容不存在,适用于 MatchFrom 为 ua , referer。
# @type Operator: String
# @param RuleID: 规则id。仅出参使用。
# @type RuleID: Integer
# @param UpdateTime: 更新时间。仅出参使用。
# @type UpdateTime: String
# @param Status: 规则启用状态。取值有:
# on:启用;
# off:未启用。
# 当入参缺省时,按 on 取值。
# @type Status: String
# @param RuleName: 规则名。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleName: String
# @param MatchContent: 匹配内容。支持多值输入。
# 当输入多个匹配值时,请使用英文逗号分隔;
# 当 MatchFrom 为 ua 时,不支持多值输入;
# 当 Operator 为 is_empty 或 not_exists 时,本字段入参值无效。
# @type MatchContent: String
attr_accessor :Action, :MatchFrom, :Operator, :RuleID, :UpdateTime, :Status, :RuleName, :MatchContent
def initialize(action=nil, matchfrom=nil, operator=nil, ruleid=nil, updatetime=nil, status=nil, rulename=nil, matchcontent=nil)
@Action = action
@MatchFrom = matchfrom
@Operator = operator
@RuleID = ruleid
@UpdateTime = updatetime
@Status = status
@RuleName = rulename
@MatchContent = matchcontent
end
def deserialize(params)
@Action = params['Action']
@MatchFrom = params['MatchFrom']
@Operator = params['Operator']
@RuleID = params['RuleID']
@UpdateTime = params['UpdateTime']
@Status = params['Status']
@RuleName = params['RuleName']
@MatchContent = params['MatchContent']
end
end
# Ipv6访问配置
class Ipv6 < TencentCloud::Common::AbstractModel
# @param Switch: Ipv6 访问功能配置,取值有:
# on:开启Ipv6访问功能;
# off:关闭Ipv6访问功能。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 视频即时处理配置
class JITVideoProcess < TencentCloud::Common::AbstractModel
# @param Switch: 视频即时处理配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 离线日志详细信息
class L4OfflineLog < TencentCloud::Common::AbstractModel
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
# @param Area: 日志所属区域,取值有:
# mainland:中国大陆境内;
# overseas:全球(不含中国大陆)。
# @type Area: String
# @param LogPacketName: 离线日志数据包名。
# @type LogPacketName: String
# @param Url: 离线日志下载地址。
# @type Url: String
# @param LogTime: 日志打包时间,此参数已经废弃。
# @type LogTime: Integer
# @param LogStartTime: 日志打包开始时间。
# @type LogStartTime: String
# @param LogEndTime: 日志打包结束时间。
# @type LogEndTime: String
# @param Size: 日志大小,单位为 Byte。
# @type Size: Integer
attr_accessor :ProxyId, :Area, :LogPacketName, :Url, :LogTime, :LogStartTime, :LogEndTime, :Size
def initialize(proxyid=nil, area=nil, logpacketname=nil, url=nil, logtime=nil, logstarttime=nil, logendtime=nil, size=nil)
@ProxyId = proxyid
@Area = area
@LogPacketName = logpacketname
@Url = url
@LogTime = logtime
@LogStartTime = logstarttime
@LogEndTime = logendtime
@Size = size
end
def deserialize(params)
@ProxyId = params['ProxyId']
@Area = params['Area']
@LogPacketName = params['LogPacketName']
@Url = params['Url']
@LogTime = params['LogTime']
@LogStartTime = params['LogStartTime']
@LogEndTime = params['LogEndTime']
@Size = params['Size']
end
end
# 四层代理实例。
class L4Proxy < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
# @param ProxyName: 四层代理实例名称。
# @type ProxyName: String
# @param Area: 四层代理实例的加速区域。
# mainland:中国大陆可用区;
# overseas: 全球可用区(不含中国大陆);
# global:全球可用区。
# @type Area: String
# @param Cname: 接入 CNAME。
# @type Cname: String
# @param Ips: 开启固定 IP 后,该值会返回对应的接入 IP;未开启时,该值为空。
# @type Ips: Array
# @param Status: 四层代理实例状态。
# online:已启用;
# offline:已停用;
# progress:部署中;
# stopping:停用中;
# banned:已封禁;
# fail:部署失败/停用失败。
# @type Status: String
# @param Ipv6: 是否开启 IPv6 访问。
# on:开启;
# off:关闭。
# @type Ipv6: String
# @param StaticIp: 是否开启固定 IP。
# on:开启; off:关闭。
# @type StaticIp: String
# @param AccelerateMainland: 是否开启中国大陆网络优化。
# on:开启 off:关闭
# @type AccelerateMainland: String
# @param DDosProtectionConfig: 安全防护配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DDosProtectionConfig: :class:`Tencentcloud::Teo.v20220901.models.DDosProtectionConfig`
# @param L4ProxyRuleCount: 四层代理实例下的转发规则数量。
# @type L4ProxyRuleCount: Integer
# @param UpdateTime: 最新变更时间。
# @type UpdateTime: String
attr_accessor :ZoneId, :ProxyId, :ProxyName, :Area, :Cname, :Ips, :Status, :Ipv6, :StaticIp, :AccelerateMainland, :DDosProtectionConfig, :L4ProxyRuleCount, :UpdateTime
def initialize(zoneid=nil, proxyid=nil, proxyname=nil, area=nil, cname=nil, ips=nil, status=nil, ipv6=nil, staticip=nil, acceleratemainland=nil, ddosprotectionconfig=nil, l4proxyrulecount=nil, updatetime=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@ProxyName = proxyname
@Area = area
@Cname = cname
@Ips = ips
@Status = status
@Ipv6 = ipv6
@StaticIp = staticip
@AccelerateMainland = acceleratemainland
@DDosProtectionConfig = ddosprotectionconfig
@L4ProxyRuleCount = l4proxyrulecount
@UpdateTime = updatetime
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@ProxyName = params['ProxyName']
@Area = params['Area']
@Cname = params['Cname']
@Ips = params['Ips']
@Status = params['Status']
@Ipv6 = params['Ipv6']
@StaticIp = params['StaticIp']
@AccelerateMainland = params['AccelerateMainland']
unless params['DDosProtectionConfig'].nil?
@DDosProtectionConfig = DDosProtectionConfig.new
@DDosProtectionConfig.deserialize(params['DDosProtectionConfig'])
end
@L4ProxyRuleCount = params['L4ProxyRuleCount']
@UpdateTime = params['UpdateTime']
end
end
# 四层远程鉴权信息
class L4ProxyRemoteAuth < TencentCloud::Common::AbstractModel
# @param Switch: 四层远程鉴权开关,取值有:
# on:表示开启;
# off:表示关闭。
# @type Switch: String
# @param Address: 远程鉴权服务地址,格式为: domain/ip:port。例:example.auth.com:8888
# @type Address: String
# @param ServerFaultyBehavior: 远程鉴权服务不可访问后,经过四层转发规则默认回源行为,取值有:
# reject:表示进行拦截,拒绝访问;
# allow:表示允许通过。
# @type ServerFaultyBehavior: String
attr_accessor :Switch, :Address, :ServerFaultyBehavior
def initialize(switch=nil, address=nil, serverfaultybehavior=nil)
@Switch = switch
@Address = address
@ServerFaultyBehavior = serverfaultybehavior
end
def deserialize(params)
@Switch = params['Switch']
@Address = params['Address']
@ServerFaultyBehavior = params['ServerFaultyBehavior']
end
end
# 四层代理转发规则详情。
class L4ProxyRule < TencentCloud::Common::AbstractModel
# @param RuleId: 转发规则 ID。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数请勿填写;在 ModifyL4ProxyRules 作为入参使用时,该参数必填。
# @type RuleId: String
# @param Protocol: 转发协议。取值有:
# TCP:TCP 协议;
# UDP:UDP 协议。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数必填;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写时表示不修改。
# @type Protocol: String
# @param PortRange: 转发端口,支持按照以下形式填写:
# 单端口,如:80;
# 端口段,如:81-85。表示 81、82、83、84、85 五个端口。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数必填;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写时表示不修改。
# @type PortRange: Array
# @param OriginType: 源站类型,取值有:
# IP_DOMAIN:IP/域名源站;
# ORIGIN_GROUP:源站组;
# LB:负载均衡,当前仅白名单开放。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数必填;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写时表示不修改。
# @type OriginType: String
# @param OriginValue: 源站地址:
# 当 OriginType 为 IP_DOMAIN 时,填写 IP 或域名,如 8.8.8.8 或 test.com ;
# 当 OriginType 为 ORIGIN_GROUP 时,填写源站组 ID,如 og-537y24vf5b41;
# 当 OriginType 为 LB 时,填写负载均衡实例 ID,如 lb-2qwk30xf7s9g。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数必填;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写时表示不修改。
# @type OriginValue: Array
# @param OriginPortRange: 源站端口,支持按照以下形式填写:
# 单端口,如:80;
# 端口段,如:81-85,表示 81、82、83、84、85 五个端口。填写端口段时,则需要与转发端口段长度保持一致,例如转发端口:80-90,则转发端口:90-100。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数必填;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写时表示不修改。
# @type OriginPortRange: String
# @param ClientIPPassThroughMode: 传递客户端 IP 的形式,取值有:
# TOA:TOA(仅 Protocol = TCP 时可选);
# PPV1:Proxy Protocol 传递,协议版本 V1(仅 Protocol = TCP 时可选);
# PPV2:Proxy Protocol 传递,协议版本 V2;
# SPP:Simple Proxy Protocol 传递,(仅 Protocol = UDP 时可选);
# OFF:不传递。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数选填,不填写时默认为 OFF;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写表示不修改。
# @type ClientIPPassThroughMode: String
# @param SessionPersist: 是否开启会话保持,取值有:
# on:开启;
# off:关闭。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数选填,不填写时默认为 off;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写表示不修改。
# @type SessionPersist: String
# @param SessionPersistTime: 会话保持时间,取值范围为 30-3600,单位为秒。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数选填,仅当 SessionPersist = on 时,该值才会生效,且当 SessionPersist = on ,该值不填写默认为 3600;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写表示不修改。
# @type SessionPersistTime: Integer
# @param RuleTag: 规则标签。可输入1-50 个任意字符。
# 注意:L4ProxyRule 在 CreateL4ProxyRules 作为入参使用时,该参数选填;在 ModifyL4ProxyRules 作为入参使用时,该参数选填,不填写表示不修改。
# @type RuleTag: String
# @param Status: 规则状态,取值有:
# online:已启用;
# offline:已停用;
# progress:部署中;
# stopping:停用中;
# fail:部署失败/停用失败。
# 注意:L4ProxyRule 在 CreateL4ProxyRules、ModifyL4ProxyRules 作为入参使用时,该参数请勿填写。
# @type Status: String
# @param BuId: BuID。
# @type BuId: String
# @param RemoteAuth: 远程鉴权信息。
# 注意:RemoteAuth 在 CreateL4ProxyRules 或 ModifyL4ProxyRules 不可作为入参使用,如有传此参数,会忽略。在 DescribeL4ProxyRules 返回为空时,表示没有开启远程鉴权。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RemoteAuth: :class:`Tencentcloud::Teo.v20220901.models.L4ProxyRemoteAuth`
attr_accessor :RuleId, :Protocol, :PortRange, :OriginType, :OriginValue, :OriginPortRange, :ClientIPPassThroughMode, :SessionPersist, :SessionPersistTime, :RuleTag, :Status, :BuId, :RemoteAuth
def initialize(ruleid=nil, protocol=nil, portrange=nil, origintype=nil, originvalue=nil, originportrange=nil, clientippassthroughmode=nil, sessionpersist=nil, sessionpersisttime=nil, ruletag=nil, status=nil, buid=nil, remoteauth=nil)
@RuleId = ruleid
@Protocol = protocol
@PortRange = portrange
@OriginType = origintype
@OriginValue = originvalue
@OriginPortRange = originportrange
@ClientIPPassThroughMode = clientippassthroughmode
@SessionPersist = sessionpersist
@SessionPersistTime = sessionpersisttime
@RuleTag = ruletag
@Status = status
@BuId = buid
@RemoteAuth = remoteauth
end
def deserialize(params)
@RuleId = params['RuleId']
@Protocol = params['Protocol']
@PortRange = params['PortRange']
@OriginType = params['OriginType']
@OriginValue = params['OriginValue']
@OriginPortRange = params['OriginPortRange']
@ClientIPPassThroughMode = params['ClientIPPassThroughMode']
@SessionPersist = params['SessionPersist']
@SessionPersistTime = params['SessionPersistTime']
@RuleTag = params['RuleTag']
@Status = params['Status']
@BuId = params['BuId']
unless params['RemoteAuth'].nil?
@RemoteAuth = L4ProxyRemoteAuth.new
@RemoteAuth.deserialize(params['RemoteAuth'])
end
end
end
# 七层离线日志详细信息。
class L7OfflineLog < TencentCloud::Common::AbstractModel
# @param Domain: 离线日志域名。
# @type Domain: String
# @param Area: 日志所属区域,取值有:
# mainland:中国大陆境内;
# overseas:全球(不含中国大陆)。
# @type Area: String
# @param LogPacketName: 离线日志数据包名。
# @type LogPacketName: String
# @param Url: 离线日志下载地址。
# @type Url: String
# @param LogTime: 日志打包时间,此参数已经废弃。
# @type LogTime: Integer
# @param LogStartTime: 日志打包开始时间。
# @type LogStartTime: String
# @param LogEndTime: 日志打包结束时间。
# @type LogEndTime: String
# @param Size: 日志原始大小,单位 Byte。
# @type Size: Integer
attr_accessor :Domain, :Area, :LogPacketName, :Url, :LogTime, :LogStartTime, :LogEndTime, :Size
def initialize(domain=nil, area=nil, logpacketname=nil, url=nil, logtime=nil, logstarttime=nil, logendtime=nil, size=nil)
@Domain = domain
@Area = area
@LogPacketName = logpacketname
@Url = url
@LogTime = logtime
@LogStartTime = logstarttime
@LogEndTime = logendtime
@Size = size
end
def deserialize(params)
@Domain = params['Domain']
@Area = params['Area']
@LogPacketName = params['LogPacketName']
@Url = params['Url']
@LogTime = params['LogTime']
@LogStartTime = params['LogStartTime']
@LogEndTime = params['LogEndTime']
@Size = params['Size']
end
end
# 负载均衡实例信息。
class LoadBalancer < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例 ID。
# @type InstanceId: String
# @param Name: 实例名称,可输入 1-200 个字符,允许字符为 a-z,A-Z,0-9,_,-。
# @type Name: String
# @param Type: 实例类型,取值有:
# HTTP:HTTP 专用型,支持添加 HTTP 专用型和通用型源站组,仅支持被站点加速相关服务引用(如域名服务和规则引擎);
# GENERAL:通用型,仅支持添加通用型源站组,能被站点加速服务(如域名服务和规则引擎)和四层代理引用。
# @type Type: String
# @param HealthChecker: 健康检查策略。详情请参考 [健康检查策略介绍](https://cloud.tencent.com/document/product/1552/104228)。
# @type HealthChecker: :class:`Tencentcloud::Teo.v20220901.models.HealthChecker`
# @param SteeringPolicy: 源站组间的流量调度策略,取值有:
# Pritory:按优先级顺序进行故障转移 。
# @type SteeringPolicy: String
# @param FailoverPolicy: 实际访问某源站失败时的请求重试策略,详情请参考 [请求重试策略介绍](https://cloud.tencent.com/document/product/1552/104227),取值有:
# OtherOriginGroup:单次请求失败后,请求优先重试下一优先级源站组;
# OtherRecordInOriginGroup:单次请求失败后,请求优先重试同源站组内的其他源站。
# @type FailoverPolicy: String
# @param OriginGroupHealthStatus: 源站组健康状态。
# @type OriginGroupHealthStatus: Array
# @param Status: 负载均衡状态,取值有:
# Pending:部署中;
# Deleting:删除中;
# Running:已生效。
# @type Status: String
# @param L4UsedList: 该负载均衡实例绑的定四层层代理实例的列表。
# @type L4UsedList: Array
# @param L7UsedList: 该负载均衡实例绑定的七层域名列表。
# @type L7UsedList: Array
attr_accessor :InstanceId, :Name, :Type, :HealthChecker, :SteeringPolicy, :FailoverPolicy, :OriginGroupHealthStatus, :Status, :L4UsedList, :L7UsedList
def initialize(instanceid=nil, name=nil, type=nil, healthchecker=nil, steeringpolicy=nil, failoverpolicy=nil, origingrouphealthstatus=nil, status=nil, l4usedlist=nil, l7usedlist=nil)
@InstanceId = instanceid
@Name = name
@Type = type
@HealthChecker = healthchecker
@SteeringPolicy = steeringpolicy
@FailoverPolicy = failoverpolicy
@OriginGroupHealthStatus = origingrouphealthstatus
@Status = status
@L4UsedList = l4usedlist
@L7UsedList = l7usedlist
end
def deserialize(params)
@InstanceId = params['InstanceId']
@Name = params['Name']
@Type = params['Type']
unless params['HealthChecker'].nil?
@HealthChecker = HealthChecker.new
@HealthChecker.deserialize(params['HealthChecker'])
end
@SteeringPolicy = params['SteeringPolicy']
@FailoverPolicy = params['FailoverPolicy']
unless params['OriginGroupHealthStatus'].nil?
@OriginGroupHealthStatus = []
params['OriginGroupHealthStatus'].each do |i|
origingrouphealthstatus_tmp = OriginGroupHealthStatus.new
origingrouphealthstatus_tmp.deserialize(i)
@OriginGroupHealthStatus << origingrouphealthstatus_tmp
end
end
@Status = params['Status']
@L4UsedList = params['L4UsedList']
@L7UsedList = params['L7UsedList']
end
end
# 实时日志投递的输出格式。您可以直接通过 FormatType 参数使用指定预设日志输出格式(JSON Lines / csv),也可以在预设日志输出格式基础上,通过其他参数来自定义变体输出格式。
class LogFormat < TencentCloud::Common::AbstractModel
# @param FormatType: 日志投递的预设输出格式类型,取值有:
# json:使用预设日志输出格式 JSON Lines,单条日志中的字段以键值对方式呈现;
# csv:使用预设日志输出格式 csv,单条日志中仅呈现字段值,不呈现字段名称。
# @type FormatType: String
# @param BatchPrefix: 在每个日志投递批次之前添加的字符串。每个日志投递批次可能包含多条日志记录。
# @type BatchPrefix: String
# @param BatchSuffix: 在每个日志投递批次后附加的字符串。
# @type BatchSuffix: String
# @param RecordPrefix: 在每条日志记录之前添加的字符串。
# @type RecordPrefix: String
# @param RecordSuffix: 在每条日志记录后附加的字符串。
# @type RecordSuffix: String
# @param RecordDelimiter: 插入日志记录之间作为分隔符的字符串,取值有:
# \n:换行符;
# \t:制表符;
# ,:半角逗号。
# @type RecordDelimiter: String
# @param FieldDelimiter: 单条日志记录内,插入字段之间作为分隔符的字符串,取值有:
# \t:制表符;
# ,:半角逗号;
# ;:半角分号。
# @type FieldDelimiter: String
attr_accessor :FormatType, :BatchPrefix, :BatchSuffix, :RecordPrefix, :RecordSuffix, :RecordDelimiter, :FieldDelimiter
def initialize(formattype=nil, batchprefix=nil, batchsuffix=nil, recordprefix=nil, recordsuffix=nil, recorddelimiter=nil, fielddelimiter=nil)
@FormatType = formattype
@BatchPrefix = batchprefix
@BatchSuffix = batchsuffix
@RecordPrefix = recordprefix
@RecordSuffix = recordsuffix
@RecordDelimiter = recorddelimiter
@FieldDelimiter = fielddelimiter
end
def deserialize(params)
@FormatType = params['FormatType']
@BatchPrefix = params['BatchPrefix']
@BatchSuffix = params['BatchSuffix']
@RecordPrefix = params['RecordPrefix']
@RecordSuffix = params['RecordSuffix']
@RecordDelimiter = params['RecordDelimiter']
@FieldDelimiter = params['FieldDelimiter']
end
end
# 浏览器缓存规则配置,用于设置 MaxAge 默认值,默认为关闭状态
class MaxAge < TencentCloud::Common::AbstractModel
# @param FollowOrigin: 是否遵循源站,取值有:
# on:遵循源站,忽略MaxAge 时间设置;
# off:不遵循源站,使用MaxAge 时间设置。
# @type FollowOrigin: String
# @param MaxAgeTime: MaxAge 时间设置,单位秒,最大365天。
# 注意:时间为0,即不缓存。
# @type MaxAgeTime: Integer
attr_accessor :FollowOrigin, :MaxAgeTime
def initialize(followorigin=nil, maxagetime=nil)
@FollowOrigin = followorigin
@MaxAgeTime = maxagetime
end
def deserialize(params)
@FollowOrigin = params['FollowOrigin']
@MaxAgeTime = params['MaxAgeTime']
end
end
# ModifyAccelerationDomain请求参数结构体
class ModifyAccelerationDomainRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 加速域名所属站点ID。
# @type ZoneId: String
# @param DomainName: 加速域名名称。
# @type DomainName: String
# @param OriginInfo: 源站信息。
# @type OriginInfo: :class:`Tencentcloud::Teo.v20220901.models.OriginInfo`
# @param OriginProtocol: 回源协议,取值有:
# FOLLOW: 协议跟随;
# HTTP: HTTP协议回源;
# HTTPS: HTTPS协议回源。
# 不填保持原有配置。
# @type OriginProtocol: String
# @param HttpOriginPort: HTTP回源端口,取值为1-65535,当OriginProtocol=FOLLOW/HTTP时生效, 不填保持原有配置。
# @type HttpOriginPort: Integer
# @param HttpsOriginPort: HTTPS回源端口,取值为1-65535,当OriginProtocol=FOLLOW/HTTPS时生效,不填保持原有配置。
# @type HttpsOriginPort: Integer
# @param IPv6Status: IPv6状态,取值有:
# follow:遵循站点IPv6配置;
# on:开启状态;
# off:关闭状态。
# 不填保持原有配置。
# @type IPv6Status: String
attr_accessor :ZoneId, :DomainName, :OriginInfo, :OriginProtocol, :HttpOriginPort, :HttpsOriginPort, :IPv6Status
def initialize(zoneid=nil, domainname=nil, origininfo=nil, originprotocol=nil, httporiginport=nil, httpsoriginport=nil, ipv6status=nil)
@ZoneId = zoneid
@DomainName = domainname
@OriginInfo = origininfo
@OriginProtocol = originprotocol
@HttpOriginPort = httporiginport
@HttpsOriginPort = httpsoriginport
@IPv6Status = ipv6status
end
def deserialize(params)
@ZoneId = params['ZoneId']
@DomainName = params['DomainName']
unless params['OriginInfo'].nil?
@OriginInfo = OriginInfo.new
@OriginInfo.deserialize(params['OriginInfo'])
end
@OriginProtocol = params['OriginProtocol']
@HttpOriginPort = params['HttpOriginPort']
@HttpsOriginPort = params['HttpsOriginPort']
@IPv6Status = params['IPv6Status']
end
end
# ModifyAccelerationDomain返回参数结构体
class ModifyAccelerationDomainResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyAccelerationDomainStatuses请求参数结构体
class ModifyAccelerationDomainStatusesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 加速域名所属站点ID。
# @type ZoneId: String
# @param DomainNames: 要执行状态变更的加速域名列表。
# @type DomainNames: Array
# @param Status: 加速域名状态,取值有:
# online:启用;
# offline:停用。
# @type Status: String
# @param Force: 是否强制停用。当域名存在关联资源(如马甲域名、流量调度功能)时,是否强制停用该域名,取值有:
# true:停用该域名及所有关联资源;
# false:当该加速域名存在关联资源时,不允许停用。不填写,默认值为:false。
# @type Force: Boolean
attr_accessor :ZoneId, :DomainNames, :Status, :Force
def initialize(zoneid=nil, domainnames=nil, status=nil, force=nil)
@ZoneId = zoneid
@DomainNames = domainnames
@Status = status
@Force = force
end
def deserialize(params)
@ZoneId = params['ZoneId']
@DomainNames = params['DomainNames']
@Status = params['Status']
@Force = params['Force']
end
end
# ModifyAccelerationDomainStatuses返回参数结构体
class ModifyAccelerationDomainStatusesResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyAliasDomain请求参数结构体
class ModifyAliasDomainRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param AliasName: 别称域名名称。
# @type AliasName: String
# @param TargetName: 目标域名名称。
# @type TargetName: String
# @param CertType: 证书配置,取值有:
# none:不配置;
# hosting:SSL托管证书;
# apply:申请免费证书。不填写保持原有配置。
# @type CertType: String
# @param CertId: 当 CertType 取值为 hosting 时填入相应证书 ID。
# @type CertId: Array
attr_accessor :ZoneId, :AliasName, :TargetName, :CertType, :CertId
def initialize(zoneid=nil, aliasname=nil, targetname=nil, certtype=nil, certid=nil)
@ZoneId = zoneid
@AliasName = aliasname
@TargetName = targetname
@CertType = certtype
@CertId = certid
end
def deserialize(params)
@ZoneId = params['ZoneId']
@AliasName = params['AliasName']
@TargetName = params['TargetName']
@CertType = params['CertType']
@CertId = params['CertId']
end
end
# ModifyAliasDomain返回参数结构体
class ModifyAliasDomainResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyAliasDomainStatus请求参数结构体
class ModifyAliasDomainStatusRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Paused: 别称域名状态,取值有:
# false:开启别称域名;
# true:关闭别称域名。
# @type Paused: Boolean
# @param AliasNames: 待修改状态的别称域名名称。如果为空,则不执行修改状态操作。
# @type AliasNames: Array
attr_accessor :ZoneId, :Paused, :AliasNames
def initialize(zoneid=nil, paused=nil, aliasnames=nil)
@ZoneId = zoneid
@Paused = paused
@AliasNames = aliasnames
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Paused = params['Paused']
@AliasNames = params['AliasNames']
end
end
# ModifyAliasDomainStatus返回参数结构体
class ModifyAliasDomainStatusResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyApplicationProxy请求参数结构体
class ModifyApplicationProxyRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 代理 ID。
# @type ProxyId: String
# @param ProxyName: 当 ProxyType=hostname 时,表示域名或子域名;
# 当 ProxyType=instance 时,表示代理名称。
# @type ProxyName: String
# @param SessionPersistTime: 会话保持时间,取值范围:30-3600,单位:秒。
# 不填写保持原有配置。
# @type SessionPersistTime: Integer
# @param ProxyType: 四层代理模式,取值有:
# instance:表示实例模式。不填写使用默认值instance。
# @type ProxyType: String
# @param Ipv6: Ipv6 访问配置,不填写保持原有配置。
# @type Ipv6: :class:`Tencentcloud::Teo.v20220901.models.Ipv6`
# @param AccelerateMainland: 中国大陆加速优化配置。 不填写表示保持原有配置。
# @type AccelerateMainland: :class:`Tencentcloud::Teo.v20220901.models.AccelerateMainland`
attr_accessor :ZoneId, :ProxyId, :ProxyName, :SessionPersistTime, :ProxyType, :Ipv6, :AccelerateMainland
def initialize(zoneid=nil, proxyid=nil, proxyname=nil, sessionpersisttime=nil, proxytype=nil, ipv6=nil, acceleratemainland=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@ProxyName = proxyname
@SessionPersistTime = sessionpersisttime
@ProxyType = proxytype
@Ipv6 = ipv6
@AccelerateMainland = acceleratemainland
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@ProxyName = params['ProxyName']
@SessionPersistTime = params['SessionPersistTime']
@ProxyType = params['ProxyType']
unless params['Ipv6'].nil?
@Ipv6 = Ipv6.new
@Ipv6.deserialize(params['Ipv6'])
end
unless params['AccelerateMainland'].nil?
@AccelerateMainland = AccelerateMainland.new
@AccelerateMainland.deserialize(params['AccelerateMainland'])
end
end
end
# ModifyApplicationProxy返回参数结构体
class ModifyApplicationProxyResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyApplicationProxyRule请求参数结构体
class ModifyApplicationProxyRuleRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param ProxyId: 代理ID。
# @type ProxyId: String
# @param RuleId: 规则ID。
# @type RuleId: String
# @param OriginType: 源站类型,取值有:
# custom:手动添加;
# origins:源站组。
# @type OriginType: String
# @param Port: 端口,支持格式:
# 80:80端口;
# 81-90:81至90端口。
# @type Port: Array
# @param Proto: 协议,取值有:
# TCP:TCP协议;
# UDP:UDP协议。不填保持原有值。
# @type Proto: String
# @param OriginValue: 源站信息:
# 当 OriginType 为 custom 时,表示一个或多个源站,如`["8.8.8.8","9.9.9.9"]` 或 `OriginValue=["test.com"]`;
# 当 OriginType 为 origins 时,要求有且仅有一个元素,表示源站组ID,如`["origin-537f5b41-162a-11ed-abaa-525400c5da15"]`。
# 不填保持原有值。
# @type OriginValue: Array
# @param ForwardClientIp: 传递客户端IP,取值有:
# TOA:TOA(仅Proto=TCP时可选);
# PPV1:Proxy Protocol传递,协议版本V1(仅Proto=TCP时可选);
# PPV2:Proxy Protocol传递,协议版本V2;
# OFF:不传递。不填保持原有值。
# @type ForwardClientIp: String
# @param SessionPersist: 是否开启会话保持,取值有:
# true:开启;
# false:关闭。不填为false。
# @type SessionPersist: Boolean
# @param SessionPersistTime: 会话保持的时间,只有当SessionPersist为true时,该值才会生效。
# @type SessionPersistTime: Integer
# @param OriginPort: 源站端口,支持格式:
# 单端口:80;
# 端口段:81-90,81至90端口。
# @type OriginPort: String
# @param RuleTag: 规则标签。不填保持原有值。
# @type RuleTag: String
attr_accessor :ZoneId, :ProxyId, :RuleId, :OriginType, :Port, :Proto, :OriginValue, :ForwardClientIp, :SessionPersist, :SessionPersistTime, :OriginPort, :RuleTag
def initialize(zoneid=nil, proxyid=nil, ruleid=nil, origintype=nil, port=nil, proto=nil, originvalue=nil, forwardclientip=nil, sessionpersist=nil, sessionpersisttime=nil, originport=nil, ruletag=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@RuleId = ruleid
@OriginType = origintype
@Port = port
@Proto = proto
@OriginValue = originvalue
@ForwardClientIp = forwardclientip
@SessionPersist = sessionpersist
@SessionPersistTime = sessionpersisttime
@OriginPort = originport
@RuleTag = ruletag
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@RuleId = params['RuleId']
@OriginType = params['OriginType']
@Port = params['Port']
@Proto = params['Proto']
@OriginValue = params['OriginValue']
@ForwardClientIp = params['ForwardClientIp']
@SessionPersist = params['SessionPersist']
@SessionPersistTime = params['SessionPersistTime']
@OriginPort = params['OriginPort']
@RuleTag = params['RuleTag']
end
end
# ModifyApplicationProxyRule返回参数结构体
class ModifyApplicationProxyRuleResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyApplicationProxyRuleStatus请求参数结构体
class ModifyApplicationProxyRuleStatusRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param ProxyId: 代理ID。
# @type ProxyId: String
# @param RuleId: 规则ID。
# @type RuleId: String
# @param Status: 状态,取值有:
# offline: 停用;
# online: 启用。
# @type Status: String
attr_accessor :ZoneId, :ProxyId, :RuleId, :Status
def initialize(zoneid=nil, proxyid=nil, ruleid=nil, status=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@RuleId = ruleid
@Status = status
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@RuleId = params['RuleId']
@Status = params['Status']
end
end
# ModifyApplicationProxyRuleStatus返回参数结构体
class ModifyApplicationProxyRuleStatusResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyApplicationProxyStatus请求参数结构体
class ModifyApplicationProxyStatusRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param ProxyId: 代理ID。
# @type ProxyId: String
# @param Status: 状态,取值有:
# offline: 停用;
# online: 启用。
# @type Status: String
attr_accessor :ZoneId, :ProxyId, :Status
def initialize(zoneid=nil, proxyid=nil, status=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@Status = status
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@Status = params['Status']
end
end
# ModifyApplicationProxyStatus返回参数结构体
class ModifyApplicationProxyStatusResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyCustomErrorPage请求参数结构体
class ModifyCustomErrorPageRequest < TencentCloud::Common::AbstractModel
# @param PageId: 自定义错误页面 ID。
# @type PageId: String
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Name: 自定义错误页名称,名称为2 - 60个字符。
# @type Name: String
# @param Description: 自定义错误页描述,描述内容不超过60个字符。
# @type Description: String
# @param ContentType: 自定义错误页面类型,取值有:text/html。 application/json。plain/text。text/xml。
# @type ContentType: String
# @param Content: 自定义错误页面内容。内容不超过 2KB。
# @type Content: String
attr_accessor :PageId, :ZoneId, :Name, :Description, :ContentType, :Content
def initialize(pageid=nil, zoneid=nil, name=nil, description=nil, contenttype=nil, content=nil)
@PageId = pageid
@ZoneId = zoneid
@Name = name
@Description = description
@ContentType = contenttype
@Content = content
end
def deserialize(params)
@PageId = params['PageId']
@ZoneId = params['ZoneId']
@Name = params['Name']
@Description = params['Description']
@ContentType = params['ContentType']
@Content = params['Content']
end
end
# ModifyCustomErrorPage返回参数结构体
class ModifyCustomErrorPageResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyFunction请求参数结构体
class ModifyFunctionRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param FunctionId: 函数 ID。
# @type FunctionId: String
# @param Remark: 函数描述,最大支持 60 个字符,不填写保持原有配置。
# @type Remark: String
# @param Content: 函数内容,当前仅支持 JavaScript 代码,最大支持 5MB 大小,不填写保持原有配置。
# @type Content: String
attr_accessor :ZoneId, :FunctionId, :Remark, :Content
def initialize(zoneid=nil, functionid=nil, remark=nil, content=nil)
@ZoneId = zoneid
@FunctionId = functionid
@Remark = remark
@Content = content
end
def deserialize(params)
@ZoneId = params['ZoneId']
@FunctionId = params['FunctionId']
@Remark = params['Remark']
@Content = params['Content']
end
end
# ModifyFunction返回参数结构体
class ModifyFunctionResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyFunctionRulePriority请求参数结构体
class ModifyFunctionRulePriorityRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param RuleIds: 规则 ID 列表,必须填入调整优先级后的所有规则 ID,多条规则执行顺序依次从上往下,不填写保持原优先级顺序。
# @type RuleIds: Array
attr_accessor :ZoneId, :RuleIds
def initialize(zoneid=nil, ruleids=nil)
@ZoneId = zoneid
@RuleIds = ruleids
end
def deserialize(params)
@ZoneId = params['ZoneId']
@RuleIds = params['RuleIds']
end
end
# ModifyFunctionRulePriority返回参数结构体
class ModifyFunctionRulePriorityResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyFunctionRule请求参数结构体
class ModifyFunctionRuleRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param RuleId: 规则 ID。
# @type RuleId: String
# @param FunctionRuleConditions: 规则条件列表,相同触发规则的不同条件匹配项之间为或关系,不填写保持原有配置。
# @type FunctionRuleConditions: Array
# @param FunctionId: 函数 ID,命中触发规则条件后执行的函数,不填写保持原有配置。
# @type FunctionId: String
# @param Remark: 规则描述,最大支持 60 个字符,不填写保持原有配置。
# @type Remark: String
attr_accessor :ZoneId, :RuleId, :FunctionRuleConditions, :FunctionId, :Remark
def initialize(zoneid=nil, ruleid=nil, functionruleconditions=nil, functionid=nil, remark=nil)
@ZoneId = zoneid
@RuleId = ruleid
@FunctionRuleConditions = functionruleconditions
@FunctionId = functionid
@Remark = remark
end
def deserialize(params)
@ZoneId = params['ZoneId']
@RuleId = params['RuleId']
unless params['FunctionRuleConditions'].nil?
@FunctionRuleConditions = []
params['FunctionRuleConditions'].each do |i|
functionrulecondition_tmp = FunctionRuleCondition.new
functionrulecondition_tmp.deserialize(i)
@FunctionRuleConditions << functionrulecondition_tmp
end
end
@FunctionId = params['FunctionId']
@Remark = params['Remark']
end
end
# ModifyFunctionRule返回参数结构体
class ModifyFunctionRuleResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyHostsCertificate请求参数结构体
class ModifyHostsCertificateRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Hosts: 需要修改证书配置的加速域名。
# @type Hosts: Array
# @param Mode: 配置服务端证书的模式,取值有:
# disable:不配置服务端证书;
# eofreecert:配置 EdgeOne 免费服务端证书;
# sslcert:配置 SSL 托管服务端证书;
# 不填写表示服务端证书保持原有配置。
# @type Mode: String
# @param ServerCertInfo: SSL 证书配置,本参数仅在 mode 为 sslcert 时生效,传入对应证书的 CertId 即可。您可以前往 [SSL 证书列表](https://console.cloud.tencent.com/ssl) 查看 CertId。
# @type ServerCertInfo: Array
# @param ApplyType: 托管类型,取值有:
# none:不托管EO;
# apply:托管EO
# 不填,默认取值为none。
# @type ApplyType: String
# @param ClientCertInfo: 在边缘双向认证场景下,该字段为客户端的 CA 证书,部署在 EO 节点内,用于客户端对 EO 节点进行认证。默认关闭,不填写表示保持原有配置。
# @type ClientCertInfo: :class:`Tencentcloud::Teo.v20220901.models.MutualTLS`
attr_accessor :ZoneId, :Hosts, :Mode, :ServerCertInfo, :ApplyType, :ClientCertInfo
extend Gem::Deprecate
deprecate :ApplyType, :none, 2024, 11
deprecate :ApplyType=, :none, 2024, 11
def initialize(zoneid=nil, hosts=nil, mode=nil, servercertinfo=nil, applytype=nil, clientcertinfo=nil)
@ZoneId = zoneid
@Hosts = hosts
@Mode = mode
@ServerCertInfo = servercertinfo
@ApplyType = applytype
@ClientCertInfo = clientcertinfo
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Hosts = params['Hosts']
@Mode = params['Mode']
unless params['ServerCertInfo'].nil?
@ServerCertInfo = []
params['ServerCertInfo'].each do |i|
servercertinfo_tmp = ServerCertInfo.new
servercertinfo_tmp.deserialize(i)
@ServerCertInfo << servercertinfo_tmp
end
end
@ApplyType = params['ApplyType']
unless params['ClientCertInfo'].nil?
@ClientCertInfo = MutualTLS.new
@ClientCertInfo.deserialize(params['ClientCertInfo'])
end
end
end
# ModifyHostsCertificate返回参数结构体
class ModifyHostsCertificateResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyL4Proxy请求参数结构体
class ModifyL4ProxyRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 应用 ID。
# @type ProxyId: String
# @param Ipv6: 是否开启 IPv6 访问。 不填该参数时,表示不修改该配置。该配置仅在部分加速区域和安全防护配置下支持开启,详情请参考 [新建四层代理实例](https://cloud.tencent.com/document/product/1552/90025) 。取值为:
# on:开启;
# off:关闭。
# @type Ipv6: String
# @param AccelerateMainland: 是否开启中国大陆网络优化。不填该参数时,表示不修改该配置。该配置仅在部分加速区域和安全防护配置下支持开启,详情请参考 [新建四层代理实例](https://cloud.tencent.com/document/product/1552/90025) 。取值为:
# on:开启;
# off:关闭。
# @type AccelerateMainland: String
attr_accessor :ZoneId, :ProxyId, :Ipv6, :AccelerateMainland
def initialize(zoneid=nil, proxyid=nil, ipv6=nil, acceleratemainland=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@Ipv6 = ipv6
@AccelerateMainland = acceleratemainland
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@Ipv6 = params['Ipv6']
@AccelerateMainland = params['AccelerateMainland']
end
end
# ModifyL4Proxy返回参数结构体
class ModifyL4ProxyResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyL4ProxyRules请求参数结构体
class ModifyL4ProxyRulesRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
# @param L4ProxyRules: 转发规则列表。单次最多支持 200 条转发规则。
# 注意:L4ProxyRule 在此处使用时,RuleId 为必填字段;Protocol、PortRange、OriginType、OriginValue、OriginPortRange、ClientIPPassThroughMode、SessionPersist、SessionPersistTime、RuleTag 均为选填字段,不填写表示不修改;Status 请勿填写。
# @type L4ProxyRules: Array
attr_accessor :ZoneId, :ProxyId, :L4ProxyRules
def initialize(zoneid=nil, proxyid=nil, l4proxyrules=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@L4ProxyRules = l4proxyrules
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
unless params['L4ProxyRules'].nil?
@L4ProxyRules = []
params['L4ProxyRules'].each do |i|
l4proxyrule_tmp = L4ProxyRule.new
l4proxyrule_tmp.deserialize(i)
@L4ProxyRules << l4proxyrule_tmp
end
end
end
end
# ModifyL4ProxyRules返回参数结构体
class ModifyL4ProxyRulesResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyL4ProxyRulesStatus请求参数结构体
class ModifyL4ProxyRulesStatusRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
# @param RuleIds: 转发规则 ID 列表。单次最多支持 200 条转发规则。
# @type RuleIds: Array
# @param Status: 转发规则状态,取值有:
# online:启用;
# offline:停用。
# @type Status: String
attr_accessor :ZoneId, :ProxyId, :RuleIds, :Status
def initialize(zoneid=nil, proxyid=nil, ruleids=nil, status=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@RuleIds = ruleids
@Status = status
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@RuleIds = params['RuleIds']
@Status = params['Status']
end
end
# ModifyL4ProxyRulesStatus返回参数结构体
class ModifyL4ProxyRulesStatusResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyL4ProxyStatus请求参数结构体
class ModifyL4ProxyStatusRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ProxyId: 四层代理实例 ID。
# @type ProxyId: String
# @param Status: 四层代理实例状态,取值有:
# online:启用;
# offline:停用。
# @type Status: String
attr_accessor :ZoneId, :ProxyId, :Status
def initialize(zoneid=nil, proxyid=nil, status=nil)
@ZoneId = zoneid
@ProxyId = proxyid
@Status = status
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ProxyId = params['ProxyId']
@Status = params['Status']
end
end
# ModifyL4ProxyStatus返回参数结构体
class ModifyL4ProxyStatusResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyLoadBalancer请求参数结构体
class ModifyLoadBalancerRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param InstanceId: 负载均衡实例 ID。
# @type InstanceId: String
# @param Name: 实例名称,可输入 1-200 个字符,允许字符为 a-z,A-Z,0-9,_,-。不填写表示维持原有配置。
# @type Name: String
# @param OriginGroups: 源站组列表及其对应的容灾调度优先级。详情请参考 [快速创建负载均衡实例](https://cloud.tencent.com/document/product/1552/104223) 中的示例场景。不填写表示维持原有配置。
# @type OriginGroups: Array
# @param HealthChecker: 健康检查策略。详情请参考 [健康检查策略介绍](https://cloud.tencent.com/document/product/1552/104228)。不填写表示维持原有配置。
# @type HealthChecker: :class:`Tencentcloud::Teo.v20220901.models.HealthChecker`
# @param SteeringPolicy: 源站组间的流量调度策略,取值有:
# Pritory:按优先级顺序进行故障转移 。不填写表示维持原有配置。
# @type SteeringPolicy: String
# @param FailoverPolicy: 实际访问某源站失败时的请求重试策略,详情请参考 [请求重试策略介绍](https://cloud.tencent.com/document/product/1552/104227),取值有:
# OtherOriginGroup:单次请求失败后,请求优先重试下一优先级源站组;
# OtherRecordInOriginGroup:单次请求失败后,请求优先重试同源站组内的其他源站。不填写表示维持原有配置。
# @type FailoverPolicy: String
attr_accessor :ZoneId, :InstanceId, :Name, :OriginGroups, :HealthChecker, :SteeringPolicy, :FailoverPolicy
def initialize(zoneid=nil, instanceid=nil, name=nil, origingroups=nil, healthchecker=nil, steeringpolicy=nil, failoverpolicy=nil)
@ZoneId = zoneid
@InstanceId = instanceid
@Name = name
@OriginGroups = origingroups
@HealthChecker = healthchecker
@SteeringPolicy = steeringpolicy
@FailoverPolicy = failoverpolicy
end
def deserialize(params)
@ZoneId = params['ZoneId']
@InstanceId = params['InstanceId']
@Name = params['Name']
unless params['OriginGroups'].nil?
@OriginGroups = []
params['OriginGroups'].each do |i|
origingroupinloadbalancer_tmp = OriginGroupInLoadBalancer.new
origingroupinloadbalancer_tmp.deserialize(i)
@OriginGroups << origingroupinloadbalancer_tmp
end
end
unless params['HealthChecker'].nil?
@HealthChecker = HealthChecker.new
@HealthChecker.deserialize(params['HealthChecker'])
end
@SteeringPolicy = params['SteeringPolicy']
@FailoverPolicy = params['FailoverPolicy']
end
end
# ModifyLoadBalancer返回参数结构体
class ModifyLoadBalancerResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyOriginGroup请求参数结构体
class ModifyOriginGroupRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID
# @type ZoneId: String
# @param GroupId: 源站组 ID,此参数必填。
# @type GroupId: String
# @param Name: 源站组名称,不填保持原有配置,可输入1 - 200个字符,允许的字符为 a - z, A - Z, 0 - 9, _, - 。
# @type Name: String
# @param Type: 源站组类型,取值有:
# GENERAL:通用型源站组,仅支持添加 IP/域名 源站,可以被域名服务、规则引擎、四层代理、通用型负载均衡引用;
# HTTP: HTTP专用型源站组,支持添加 IP/域名、对象存储源站,无法被四层代理引用。不填保持原有配置。
# @type Type: String
# @param Records: 源站记录信息,不填保持原有配置。
# @type Records: Array
# @param HostHeader: 回源 Host Header,仅 Type = HTTP 时生效, 不填或者填空表示不配置回源Host,规则引擎修改 Host Header 配置优先级高于源站组的 Host Header。
# @type HostHeader: String
attr_accessor :ZoneId, :GroupId, :Name, :Type, :Records, :HostHeader
def initialize(zoneid=nil, groupid=nil, name=nil, type=nil, records=nil, hostheader=nil)
@ZoneId = zoneid
@GroupId = groupid
@Name = name
@Type = type
@Records = records
@HostHeader = hostheader
end
def deserialize(params)
@ZoneId = params['ZoneId']
@GroupId = params['GroupId']
@Name = params['Name']
@Type = params['Type']
unless params['Records'].nil?
@Records = []
params['Records'].each do |i|
originrecord_tmp = OriginRecord.new
originrecord_tmp.deserialize(i)
@Records << originrecord_tmp
end
end
@HostHeader = params['HostHeader']
end
end
# ModifyOriginGroup返回参数结构体
class ModifyOriginGroupResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyPlan请求参数结构体
class ModifyPlanRequest < TencentCloud::Common::AbstractModel
# @param PlanId: 套餐 ID,形如 edgeone-2unuvzjmmn2q。
# @type PlanId: String
# @param RenewFlag: 预付费套餐自动续费配置。若开启了自动续费,则会在套餐到期前一天自动续费,仅支持个人版,基础版,标准版套餐。不填写表示保持原有配置。
# @type RenewFlag: :class:`Tencentcloud::Teo.v20220901.models.RenewFlag`
attr_accessor :PlanId, :RenewFlag
def initialize(planid=nil, renewflag=nil)
@PlanId = planid
@RenewFlag = renewflag
end
def deserialize(params)
@PlanId = params['PlanId']
unless params['RenewFlag'].nil?
@RenewFlag = RenewFlag.new
@RenewFlag.deserialize(params['RenewFlag'])
end
end
end
# ModifyPlan返回参数结构体
class ModifyPlanResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyRealtimeLogDeliveryTask请求参数结构体
class ModifyRealtimeLogDeliveryTaskRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param TaskId: 实时日志投递任务 ID。
# @type TaskId: String
# @param TaskName: 实时日志投递任务的名称,格式为数字、英文、-和_组合,最多 200 个字符。不填保持原有配置。
# @type TaskName: String
# @param DeliveryStatus: 实时日志投递任务的状态,取值有:
# enabled: 启用;
# disabled: 停用。不填保持原有配置。
# @type DeliveryStatus: String
# @param EntityList: 实时日志投递任务对应的实体(七层域名或者四层代理实例)列表。取值示例如下:
# 七层域名:domain.example.com;
# 四层代理实例:sid-2s69eb5wcms7。不填保持原有配置。
# @type EntityList: Array
# @param Fields: 投递的预设字段列表。不填保持原有配置。
# @type Fields: Array
# @param CustomFields: 投递的自定义字段列表,支持在 HTTP 请求头、响应头、Cookie、请求正文中提取指定内容。不填保持原有配置。自定义字段名称不能重复,且最多不能超过 200 个字段。单个实时日志推送任务最多添加 5 个请求正文类型的自定义字段。目前仅站点加速日志(LogType=domain)支持添加自定义字段。
# @type CustomFields: Array
# @param DeliveryConditions: 日志投递的过滤条件。不填表示投递全量日志。
# @type DeliveryConditions: Array
# @param Sample: 采样比例,采用千分制,取值范围为1-1000,例如:填写 605 表示采样比例为 60.5%。不填保持原有配置。
# @type Sample: Integer
# @param LogFormat: 日志投递的输出格式。不填保持原有配置。
# 特别地,当 TaskType 取值为 cls 时,LogFormat.FormatType 的值只能为 json,且 LogFormat 中其他参数将被忽略,建议不传 LogFormat。
# @type LogFormat: :class:`Tencentcloud::Teo.v20220901.models.LogFormat`
# @param CustomEndpoint: 自定义 HTTP 服务的配置信息,不填保持原有配置。
# @type CustomEndpoint: :class:`Tencentcloud::Teo.v20220901.models.CustomEndpoint`
# @param S3: AWS S3 兼容存储桶的配置信息,不填保持原有配置。
# @type S3: :class:`Tencentcloud::Teo.v20220901.models.S3`
attr_accessor :ZoneId, :TaskId, :TaskName, :DeliveryStatus, :EntityList, :Fields, :CustomFields, :DeliveryConditions, :Sample, :LogFormat, :CustomEndpoint, :S3
def initialize(zoneid=nil, taskid=nil, taskname=nil, deliverystatus=nil, entitylist=nil, fields=nil, customfields=nil, deliveryconditions=nil, sample=nil, logformat=nil, customendpoint=nil, s3=nil)
@ZoneId = zoneid
@TaskId = taskid
@TaskName = taskname
@DeliveryStatus = deliverystatus
@EntityList = entitylist
@Fields = fields
@CustomFields = customfields
@DeliveryConditions = deliveryconditions
@Sample = sample
@LogFormat = logformat
@CustomEndpoint = customendpoint
@S3 = s3
end
def deserialize(params)
@ZoneId = params['ZoneId']
@TaskId = params['TaskId']
@TaskName = params['TaskName']
@DeliveryStatus = params['DeliveryStatus']
@EntityList = params['EntityList']
@Fields = params['Fields']
unless params['CustomFields'].nil?
@CustomFields = []
params['CustomFields'].each do |i|
customfield_tmp = CustomField.new
customfield_tmp.deserialize(i)
@CustomFields << customfield_tmp
end
end
unless params['DeliveryConditions'].nil?
@DeliveryConditions = []
params['DeliveryConditions'].each do |i|
deliverycondition_tmp = DeliveryCondition.new
deliverycondition_tmp.deserialize(i)
@DeliveryConditions << deliverycondition_tmp
end
end
@Sample = params['Sample']
unless params['LogFormat'].nil?
@LogFormat = LogFormat.new
@LogFormat.deserialize(params['LogFormat'])
end
unless params['CustomEndpoint'].nil?
@CustomEndpoint = CustomEndpoint.new
@CustomEndpoint.deserialize(params['CustomEndpoint'])
end
unless params['S3'].nil?
@S3 = S3.new
@S3.deserialize(params['S3'])
end
end
end
# ModifyRealtimeLogDeliveryTask返回参数结构体
class ModifyRealtimeLogDeliveryTaskResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyRule请求参数结构体
class ModifyRuleRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param RuleName: 规则名称,字符串名称长度 1~255。
# @type RuleName: String
# @param Rules: 规则内容。
# @type Rules: Array
# @param RuleId: 规则 ID。
# @type RuleId: String
# @param Status: 规则状态,取值有:
# enable: 启用;
# disable: 未启用。
# @type Status: String
# @param Tags: 规则标签。
# @type Tags: Array
attr_accessor :ZoneId, :RuleName, :Rules, :RuleId, :Status, :Tags
def initialize(zoneid=nil, rulename=nil, rules=nil, ruleid=nil, status=nil, tags=nil)
@ZoneId = zoneid
@RuleName = rulename
@Rules = rules
@RuleId = ruleid
@Status = status
@Tags = tags
end
def deserialize(params)
@ZoneId = params['ZoneId']
@RuleName = params['RuleName']
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
rule_tmp = Rule.new
rule_tmp.deserialize(i)
@Rules << rule_tmp
end
end
@RuleId = params['RuleId']
@Status = params['Status']
@Tags = params['Tags']
end
end
# ModifyRule返回参数结构体
class ModifyRuleResponse < TencentCloud::Common::AbstractModel
# @param RuleId: 规则 ID。
# @type RuleId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RuleId, :RequestId
def initialize(ruleid=nil, requestid=nil)
@RuleId = ruleid
@RequestId = requestid
end
def deserialize(params)
@RuleId = params['RuleId']
@RequestId = params['RequestId']
end
end
# ModifySecurityIPGroup请求参数结构体
class ModifySecurityIPGroupRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 Id。
# @type ZoneId: String
# @param IPGroup: IP 组配置。
# @type IPGroup: :class:`Tencentcloud::Teo.v20220901.models.IPGroup`
# @param Mode: 操作类型,取值有:
# append: 向 IPGroup 中追加 Content 参数中内容;
# remove: 从 IPGroup 中删除 Content 参数中内容;
# update: 全量替换 IPGroup 内容,并可修改 IPGroup 名称。
# @type Mode: String
attr_accessor :ZoneId, :IPGroup, :Mode
def initialize(zoneid=nil, ipgroup=nil, mode=nil)
@ZoneId = zoneid
@IPGroup = ipgroup
@Mode = mode
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['IPGroup'].nil?
@IPGroup = IPGroup.new
@IPGroup.deserialize(params['IPGroup'])
end
@Mode = params['Mode']
end
end
# ModifySecurityIPGroup返回参数结构体
class ModifySecurityIPGroupResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifySecurityPolicy请求参数结构体
class ModifySecurityPolicyRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点Id。
# @type ZoneId: String
# @param SecurityConfig: 安全配置。
# @type SecurityConfig: :class:`Tencentcloud::Teo.v20220901.models.SecurityConfig`
# @param Entity: 子域名/应用名。
# 注意:当同时指定本参数和 TemplateId 参数时,本参数不生效。请勿同时指定本参数和 TemplateId 参数。
# @type Entity: String
# @param TemplateId: 指定模板策略 ID,或指定站点全局策略。
# - 如需配置策略模板,请指定策略模板 ID。
# - 如需配置站点全局策略,请使用 @ZoneLevel@Domain 参数值
# 注意:当使用本参数时,Entity 参数不生效。请勿同时使用本参数和 Entity 参数。
# @type TemplateId: String
attr_accessor :ZoneId, :SecurityConfig, :Entity, :TemplateId
def initialize(zoneid=nil, securityconfig=nil, entity=nil, templateid=nil)
@ZoneId = zoneid
@SecurityConfig = securityconfig
@Entity = entity
@TemplateId = templateid
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['SecurityConfig'].nil?
@SecurityConfig = SecurityConfig.new
@SecurityConfig.deserialize(params['SecurityConfig'])
end
@Entity = params['Entity']
@TemplateId = params['TemplateId']
end
end
# ModifySecurityPolicy返回参数结构体
class ModifySecurityPolicyResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyZone请求参数结构体
class ModifyZoneRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Type: 站点接入方式,取值有:
# full:NS 接入;
# partial:CNAME 接入,如果站点当前是无域名接入,仅支持切换到 CNAME 接入;
# dnsPodAccess:DNSPod 托管接入,该接入模式要求您的域名已托管在 DNSPod 内。不填写保持原有配置。
# @type Type: String
# @param VanityNameServers: 自定义站点信息,以替代系统默认分配的名称服务器。不填写保持原有配置。当站点是无域名接入方式时不允许传此参数。
# @type VanityNameServers: :class:`Tencentcloud::Teo.v20220901.models.VanityNameServers`
# @param AliasZoneName: 站点别名。数字、英文、-和_组合,限制20个字符。
# @type AliasZoneName: String
# @param Area: 站点接入地域,取值有:
# global:全球;
# mainland:中国大陆;
# overseas:境外区域。当站点是无域名接入方式时,不允许传此参数。
# @type Area: String
# @param ZoneName: 站点名称。仅当站点由无域名接入方式切换到CNAME接入方式的场景下有效。
# @type ZoneName: String
attr_accessor :ZoneId, :Type, :VanityNameServers, :AliasZoneName, :Area, :ZoneName
def initialize(zoneid=nil, type=nil, vanitynameservers=nil, aliaszonename=nil, area=nil, zonename=nil)
@ZoneId = zoneid
@Type = type
@VanityNameServers = vanitynameservers
@AliasZoneName = aliaszonename
@Area = area
@ZoneName = zonename
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Type = params['Type']
unless params['VanityNameServers'].nil?
@VanityNameServers = VanityNameServers.new
@VanityNameServers.deserialize(params['VanityNameServers'])
end
@AliasZoneName = params['AliasZoneName']
@Area = params['Area']
@ZoneName = params['ZoneName']
end
end
# ModifyZone返回参数结构体
class ModifyZoneResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyZoneSetting请求参数结构体
class ModifyZoneSettingRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 待变更的站点 ID。
# @type ZoneId: String
# @param CacheConfig: 缓存过期时间配置。
# 不填写表示保持原有配置。
# @type CacheConfig: :class:`Tencentcloud::Teo.v20220901.models.CacheConfig`
# @param CacheKey: 节点缓存键配置。
# 不填写表示保持原有配置。
# @type CacheKey: :class:`Tencentcloud::Teo.v20220901.models.CacheKey`
# @param MaxAge: 浏览器缓存配置。
# 不填写表示保持原有配置。
# @type MaxAge: :class:`Tencentcloud::Teo.v20220901.models.MaxAge`
# @param OfflineCache: 离线缓存配置。
# 不填写表示保持原有配置。
# @type OfflineCache: :class:`Tencentcloud::Teo.v20220901.models.OfflineCache`
# @param Quic: Quic 访问配置。
# 不填写表示保持原有配置。
# @type Quic: :class:`Tencentcloud::Teo.v20220901.models.Quic`
# @param PostMaxSize: Post 请求传输配置。
# 不填写表示保持原有配置。
# @type PostMaxSize: :class:`Tencentcloud::Teo.v20220901.models.PostMaxSize`
# @param Compression: 智能压缩配置。
# 不填写表示保持原有配置。
# @type Compression: :class:`Tencentcloud::Teo.v20220901.models.Compression`
# @param UpstreamHttp2: Http2 回源配置。
# 不填写表示保持原有配置。
# @type UpstreamHttp2: :class:`Tencentcloud::Teo.v20220901.models.UpstreamHttp2`
# @param ForceRedirect: 访问协议强制 Https 跳转配置。
# 不填写表示保持原有配置。
# @type ForceRedirect: :class:`Tencentcloud::Teo.v20220901.models.ForceRedirect`
# @param Https: Https 加速配置。
# 不填写表示保持原有配置。
# @type Https: :class:`Tencentcloud::Teo.v20220901.models.Https`
# @param Origin: 源站配置。
# 不填写表示保持原有配置。
# @type Origin: :class:`Tencentcloud::Teo.v20220901.models.Origin`
# @param SmartRouting: 智能加速配置。
# 不填写表示保持原有配置。
# @type SmartRouting: :class:`Tencentcloud::Teo.v20220901.models.SmartRouting`
# @param WebSocket: WebSocket 配置。
# 不填写表示保持原有配置。
# @type WebSocket: :class:`Tencentcloud::Teo.v20220901.models.WebSocket`
# @param ClientIpHeader: 客户端 IP 回源请求头配置。
# 不填写表示保持原有配置。
# @type ClientIpHeader: :class:`Tencentcloud::Teo.v20220901.models.ClientIpHeader`
# @param CachePrefresh: 缓存预刷新配置。
# 不填写表示保持原有配置。
# @type CachePrefresh: :class:`Tencentcloud::Teo.v20220901.models.CachePrefresh`
# @param Ipv6: Ipv6 访问配置。
# 不填写表示保持原有配置。
# @type Ipv6: :class:`Tencentcloud::Teo.v20220901.models.Ipv6`
# @param ClientIpCountry: 回源时是否携带客户端 IP 所属地域信息的配置。
# 不填写表示保持原有配置。
# @type ClientIpCountry: :class:`Tencentcloud::Teo.v20220901.models.ClientIpCountry`
# @param Grpc: Grpc 协议支持配置。
# 不填写表示保持原有配置。
# @type Grpc: :class:`Tencentcloud::Teo.v20220901.models.Grpc`
# @param ImageOptimize: 图片优化配置。
# 不填写表示关闭。
# @type ImageOptimize: :class:`Tencentcloud::Teo.v20220901.models.ImageOptimize`
# @param StandardDebug: 标准 Debug 配置。
# @type StandardDebug: :class:`Tencentcloud::Teo.v20220901.models.StandardDebug`
# @param JITVideoProcess: 视频即时处理配置。不填写表示保持原有配置。
# @type JITVideoProcess: :class:`Tencentcloud::Teo.v20220901.models.JITVideoProcess`
attr_accessor :ZoneId, :CacheConfig, :CacheKey, :MaxAge, :OfflineCache, :Quic, :PostMaxSize, :Compression, :UpstreamHttp2, :ForceRedirect, :Https, :Origin, :SmartRouting, :WebSocket, :ClientIpHeader, :CachePrefresh, :Ipv6, :ClientIpCountry, :Grpc, :ImageOptimize, :StandardDebug, :JITVideoProcess
def initialize(zoneid=nil, cacheconfig=nil, cachekey=nil, maxage=nil, offlinecache=nil, quic=nil, postmaxsize=nil, compression=nil, upstreamhttp2=nil, forceredirect=nil, https=nil, origin=nil, smartrouting=nil, websocket=nil, clientipheader=nil, cacheprefresh=nil, ipv6=nil, clientipcountry=nil, grpc=nil, imageoptimize=nil, standarddebug=nil, jitvideoprocess=nil)
@ZoneId = zoneid
@CacheConfig = cacheconfig
@CacheKey = cachekey
@MaxAge = maxage
@OfflineCache = offlinecache
@Quic = quic
@PostMaxSize = postmaxsize
@Compression = compression
@UpstreamHttp2 = upstreamhttp2
@ForceRedirect = forceredirect
@Https = https
@Origin = origin
@SmartRouting = smartrouting
@WebSocket = websocket
@ClientIpHeader = clientipheader
@CachePrefresh = cacheprefresh
@Ipv6 = ipv6
@ClientIpCountry = clientipcountry
@Grpc = grpc
@ImageOptimize = imageoptimize
@StandardDebug = standarddebug
@JITVideoProcess = jitvideoprocess
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['CacheConfig'].nil?
@CacheConfig = CacheConfig.new
@CacheConfig.deserialize(params['CacheConfig'])
end
unless params['CacheKey'].nil?
@CacheKey = CacheKey.new
@CacheKey.deserialize(params['CacheKey'])
end
unless params['MaxAge'].nil?
@MaxAge = MaxAge.new
@MaxAge.deserialize(params['MaxAge'])
end
unless params['OfflineCache'].nil?
@OfflineCache = OfflineCache.new
@OfflineCache.deserialize(params['OfflineCache'])
end
unless params['Quic'].nil?
@Quic = Quic.new
@Quic.deserialize(params['Quic'])
end
unless params['PostMaxSize'].nil?
@PostMaxSize = PostMaxSize.new
@PostMaxSize.deserialize(params['PostMaxSize'])
end
unless params['Compression'].nil?
@Compression = Compression.new
@Compression.deserialize(params['Compression'])
end
unless params['UpstreamHttp2'].nil?
@UpstreamHttp2 = UpstreamHttp2.new
@UpstreamHttp2.deserialize(params['UpstreamHttp2'])
end
unless params['ForceRedirect'].nil?
@ForceRedirect = ForceRedirect.new
@ForceRedirect.deserialize(params['ForceRedirect'])
end
unless params['Https'].nil?
@Https = Https.new
@Https.deserialize(params['Https'])
end
unless params['Origin'].nil?
@Origin = Origin.new
@Origin.deserialize(params['Origin'])
end
unless params['SmartRouting'].nil?
@SmartRouting = SmartRouting.new
@SmartRouting.deserialize(params['SmartRouting'])
end
unless params['WebSocket'].nil?
@WebSocket = WebSocket.new
@WebSocket.deserialize(params['WebSocket'])
end
unless params['ClientIpHeader'].nil?
@ClientIpHeader = ClientIpHeader.new
@ClientIpHeader.deserialize(params['ClientIpHeader'])
end
unless params['CachePrefresh'].nil?
@CachePrefresh = CachePrefresh.new
@CachePrefresh.deserialize(params['CachePrefresh'])
end
unless params['Ipv6'].nil?
@Ipv6 = Ipv6.new
@Ipv6.deserialize(params['Ipv6'])
end
unless params['ClientIpCountry'].nil?
@ClientIpCountry = ClientIpCountry.new
@ClientIpCountry.deserialize(params['ClientIpCountry'])
end
unless params['Grpc'].nil?
@Grpc = Grpc.new
@Grpc.deserialize(params['Grpc'])
end
unless params['ImageOptimize'].nil?
@ImageOptimize = ImageOptimize.new
@ImageOptimize.deserialize(params['ImageOptimize'])
end
unless params['StandardDebug'].nil?
@StandardDebug = StandardDebug.new
@StandardDebug.deserialize(params['StandardDebug'])
end
unless params['JITVideoProcess'].nil?
@JITVideoProcess = JITVideoProcess.new
@JITVideoProcess.deserialize(params['JITVideoProcess'])
end
end
end
# ModifyZoneSetting返回参数结构体
class ModifyZoneSettingResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# ModifyZoneStatus请求参数结构体
class ModifyZoneStatusRequest < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param Paused: 站点状态,取值有:
# false:开启站点;
# true:关闭站点。
# @type Paused: Boolean
attr_accessor :ZoneId, :Paused
def initialize(zoneid=nil, paused=nil)
@ZoneId = zoneid
@Paused = paused
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Paused = params['Paused']
end
end
# ModifyZoneStatus返回参数结构体
class ModifyZoneStatusResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# HTTPS 双向认证。
class MutualTLS < TencentCloud::Common::AbstractModel
# @param Switch: 双向认证配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param CertInfos: 双向认证证书列表。
# 注意:MutualTLS 在 ModifyHostsCertificate 作为入参使用时,该参数传入对应证书的 CertId 即可。您可以前往 [SSL 证书列表](https://console.cloud.tencent.com/ssl) 查看 CertId。
# @type CertInfos: Array
attr_accessor :Switch, :CertInfos
def initialize(switch=nil, certinfos=nil)
@Switch = switch
@CertInfos = certinfos
end
def deserialize(params)
@Switch = params['Switch']
unless params['CertInfos'].nil?
@CertInfos = []
params['CertInfos'].each do |i|
certificateinfo_tmp = CertificateInfo.new
certificateinfo_tmp.deserialize(i)
@CertInfos << certificateinfo_tmp
end
end
end
end
# 不缓存配置
class NoCache < TencentCloud::Common::AbstractModel
# @param Switch: 不缓存配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 规则引擎常规类型的动作
class NormalAction < TencentCloud::Common::AbstractModel
# @param Action: 功能名称,功能名称填写规范可调用接口 [查询规则引擎的设置参数](https://cloud.tencent.com/document/product/1552/80618) 查看。
# @type Action: String
# @param Parameters: 参数。
# @type Parameters: Array
attr_accessor :Action, :Parameters
def initialize(action=nil, parameters=nil)
@Action = action
@Parameters = parameters
end
def deserialize(params)
@Action = params['Action']
unless params['Parameters'].nil?
@Parameters = []
params['Parameters'].each do |i|
rulenormalactionparams_tmp = RuleNormalActionParams.new
rulenormalactionparams_tmp.deserialize(i)
@Parameters << rulenormalactionparams_tmp
end
end
end
end
# NS 接入,切换 DNS 服务器所需的信息。
class NsVerification < TencentCloud::Common::AbstractModel
# @param NameServers: NS 接入时,分配给用户的 DNS 服务器地址,需要将域名的 NameServer 切换至该地址。
# @type NameServers: Array
attr_accessor :NameServers
def initialize(nameservers=nil)
@NameServers = nameservers
end
def deserialize(params)
@NameServers = params['NameServers']
end
end
# 离线缓存是否开启
class OfflineCache < TencentCloud::Common::AbstractModel
# @param Switch: 离线缓存是否开启,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 源站配置。
class Origin < TencentCloud::Common::AbstractModel
# @param Origins: 主源站列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Origins: Array
# @param BackupOrigins: 备源站列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BackupOrigins: Array
# @param OriginPullProtocol: 回源协议配置,取值有:
# http:强制 http 回源;
# follow:协议跟随回源;
# https:强制 https 回源。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OriginPullProtocol: String
# @param CosPrivateAccess: 源站为腾讯云 COS 时,是否为私有访问 bucket,取值有:
# on:私有访问;
# off:公共访问。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CosPrivateAccess: String
attr_accessor :Origins, :BackupOrigins, :OriginPullProtocol, :CosPrivateAccess
def initialize(origins=nil, backuporigins=nil, originpullprotocol=nil, cosprivateaccess=nil)
@Origins = origins
@BackupOrigins = backuporigins
@OriginPullProtocol = originpullprotocol
@CosPrivateAccess = cosprivateaccess
end
def deserialize(params)
@Origins = params['Origins']
@BackupOrigins = params['BackupOrigins']
@OriginPullProtocol = params['OriginPullProtocol']
@CosPrivateAccess = params['CosPrivateAccess']
end
end
# 加速域名源站信息。
class OriginDetail < TencentCloud::Common::AbstractModel
# @param OriginType: 源站类型,取值有:
# IP_DOMAIN:IPV4、IPV6 或域名类型源站;
# COS:腾讯云 COS 对象存储源站;
# AWS_S3:AWS S3 对象存储源站;
# ORIGIN_GROUP:源站组类型源站;
# VOD:云点播;
# SPACE:源站卸载,当前仅白名单开放;
# LB:负载均衡,当前仅白名单开放。
# @type OriginType: String
# @param Origin: 源站地址,根据 OriginType 的取值分为以下情况:
# 当 OriginType = IP_DOMAIN 时,该参数为 IPv4、IPv6 地址或域名;
# 当 OriginType = COS 时,该参数为 COS 桶的访问域名;
# 当 OriginType = AWS_S3,该参数为 S3 桶的访问域名;
# 当 OriginType = ORIGIN_GROUP 时,该参数为源站组 ID;
# 当 OriginType = VOD 时,该参数请填写云点播应用 ID ;
# @type Origin: String
# @param BackupOrigin: 备用源站组 ID,该参数仅在 OriginType = ORIGIN_GROUP 且配置了备源站组时会生效。
# @type BackupOrigin: String
# @param OriginGroupName: 主源源站组名称,当 OriginType = ORIGIN_GROUP 时该参数会返回值。
# @type OriginGroupName: String
# @param BackOriginGroupName: 备用源站组名称,该参数仅当 OriginType = ORIGIN_GROUP 且配置了备用源站组时会生效。
# @type BackOriginGroupName: String
# @param PrivateAccess: 指定是否允许访问私有对象存储源站,该参数仅当源站类型OriginType = COS 或 AWS_S3 时会生效,取值有:
# on:使用私有鉴权;
# off:不使用私有鉴权。
# 不填写,默认值为 off。
# @type PrivateAccess: String
# @param PrivateParameters: 私有鉴权使用参数,该参数仅当源站类型 PrivateAccess = on 时会生效。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PrivateParameters: Array
# @param VodeoSubAppId: MO 子应用 ID
# @type VodeoSubAppId: Integer
# @param VodeoDistributionRange: MO 分发范围,取值有: All:全部 Bucket:存储桶
# @type VodeoDistributionRange: String
# @param VodeoBucketId: MO 存储桶 ID,分发范围(DistributionRange)为存储桶(Bucket)时必填
# @type VodeoBucketId: String
attr_accessor :OriginType, :Origin, :BackupOrigin, :OriginGroupName, :BackOriginGroupName, :PrivateAccess, :PrivateParameters, :VodeoSubAppId, :VodeoDistributionRange, :VodeoBucketId
extend Gem::Deprecate
deprecate :VodeoSubAppId, :none, 2024, 11
deprecate :VodeoSubAppId=, :none, 2024, 11
deprecate :VodeoDistributionRange, :none, 2024, 11
deprecate :VodeoDistributionRange=, :none, 2024, 11
deprecate :VodeoBucketId, :none, 2024, 11
deprecate :VodeoBucketId=, :none, 2024, 11
def initialize(origintype=nil, origin=nil, backuporigin=nil, origingroupname=nil, backorigingroupname=nil, privateaccess=nil, privateparameters=nil, vodeosubappid=nil, vodeodistributionrange=nil, vodeobucketid=nil)
@OriginType = origintype
@Origin = origin
@BackupOrigin = backuporigin
@OriginGroupName = origingroupname
@BackOriginGroupName = backorigingroupname
@PrivateAccess = privateaccess
@PrivateParameters = privateparameters
@VodeoSubAppId = vodeosubappid
@VodeoDistributionRange = vodeodistributionrange
@VodeoBucketId = vodeobucketid
end
def deserialize(params)
@OriginType = params['OriginType']
@Origin = params['Origin']
@BackupOrigin = params['BackupOrigin']
@OriginGroupName = params['OriginGroupName']
@BackOriginGroupName = params['BackOriginGroupName']
@PrivateAccess = params['PrivateAccess']
unless params['PrivateParameters'].nil?
@PrivateParameters = []
params['PrivateParameters'].each do |i|
privateparameter_tmp = PrivateParameter.new
privateparameter_tmp.deserialize(i)
@PrivateParameters << privateparameter_tmp
end
end
@VodeoSubAppId = params['VodeoSubAppId']
@VodeoDistributionRange = params['VodeoDistributionRange']
@VodeoBucketId = params['VodeoBucketId']
end
end
# 源站组信息
class OriginGroup < TencentCloud::Common::AbstractModel
# @param GroupId: 源站组ID。
# @type GroupId: String
# @param Name: 源站组名称。
# @type Name: String
# @param Type: 源站组类型,取值有:
# GENERAL:通用型源站组;
# HTTP: HTTP专用型源站组。
# @type Type: String
# @param Records: 源站记录信息。
# @type Records: Array
# @param References: 源站组被引用实例列表。
# @type References: Array
# @param CreateTime: 源站组创建时间。
# @type CreateTime: String
# @param UpdateTime: 源站组更新时间。
# @type UpdateTime: String
# @param HostHeader: 回源Host Header。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type HostHeader: String
attr_accessor :GroupId, :Name, :Type, :Records, :References, :CreateTime, :UpdateTime, :HostHeader
def initialize(groupid=nil, name=nil, type=nil, records=nil, references=nil, createtime=nil, updatetime=nil, hostheader=nil)
@GroupId = groupid
@Name = name
@Type = type
@Records = records
@References = references
@CreateTime = createtime
@UpdateTime = updatetime
@HostHeader = hostheader
end
def deserialize(params)
@GroupId = params['GroupId']
@Name = params['Name']
@Type = params['Type']
unless params['Records'].nil?
@Records = []
params['Records'].each do |i|
originrecord_tmp = OriginRecord.new
originrecord_tmp.deserialize(i)
@Records << originrecord_tmp
end
end
unless params['References'].nil?
@References = []
params['References'].each do |i|
origingroupreference_tmp = OriginGroupReference.new
origingroupreference_tmp.deserialize(i)
@References << origingroupreference_tmp
end
end
@CreateTime = params['CreateTime']
@UpdateTime = params['UpdateTime']
@HostHeader = params['HostHeader']
end
end
# 源站组健康状态。
class OriginGroupHealthStatus < TencentCloud::Common::AbstractModel
# @param OriginGroupID: 源站组 ID。
# @type OriginGroupID: String
# @param OriginGroupName: 源站组名。
# @type OriginGroupName: String
# @param OriginType: 源站组类型,取值有:
# HTTP:HTTP 专用型;
# GENERAL:通用型。
# @type OriginType: String
# @param Priority: 优先级。
# @type Priority: String
# @param OriginHealthStatus: 源站组里各源站的健康状态。
# @type OriginHealthStatus: Array
attr_accessor :OriginGroupID, :OriginGroupName, :OriginType, :Priority, :OriginHealthStatus
def initialize(origingroupid=nil, origingroupname=nil, origintype=nil, priority=nil, originhealthstatus=nil)
@OriginGroupID = origingroupid
@OriginGroupName = origingroupname
@OriginType = origintype
@Priority = priority
@OriginHealthStatus = originhealthstatus
end
def deserialize(params)
@OriginGroupID = params['OriginGroupID']
@OriginGroupName = params['OriginGroupName']
@OriginType = params['OriginType']
@Priority = params['Priority']
unless params['OriginHealthStatus'].nil?
@OriginHealthStatus = []
params['OriginHealthStatus'].each do |i|
originhealthstatus_tmp = OriginHealthStatus.new
originhealthstatus_tmp.deserialize(i)
@OriginHealthStatus << originhealthstatus_tmp
end
end
end
end
# 源站组健康状态详情。
class OriginGroupHealthStatusDetail < TencentCloud::Common::AbstractModel
# @param OriginGroupId: 源站组 ID。
# @type OriginGroupId: String
# @param OriginHealthStatus: 根据所有探测区域的结果综合决策出来的源站组下各个源站的健康状态。超过一半的地域判定该源站不健康,则对应状态为不健康,否则为健康。
# @type OriginHealthStatus: Array
# @param CheckRegionHealthStatus: 各个健康检查区域下源站的健康状态。
# @type CheckRegionHealthStatus: Array
attr_accessor :OriginGroupId, :OriginHealthStatus, :CheckRegionHealthStatus
def initialize(origingroupid=nil, originhealthstatus=nil, checkregionhealthstatus=nil)
@OriginGroupId = origingroupid
@OriginHealthStatus = originhealthstatus
@CheckRegionHealthStatus = checkregionhealthstatus
end
def deserialize(params)
@OriginGroupId = params['OriginGroupId']
unless params['OriginHealthStatus'].nil?
@OriginHealthStatus = []
params['OriginHealthStatus'].each do |i|
originhealthstatus_tmp = OriginHealthStatus.new
originhealthstatus_tmp.deserialize(i)
@OriginHealthStatus << originhealthstatus_tmp
end
end
unless params['CheckRegionHealthStatus'].nil?
@CheckRegionHealthStatus = []
params['CheckRegionHealthStatus'].each do |i|
checkregionhealthstatus_tmp = CheckRegionHealthStatus.new
checkregionhealthstatus_tmp.deserialize(i)
@CheckRegionHealthStatus << checkregionhealthstatus_tmp
end
end
end
end
# 负载均衡实例中需要绑定的源站组和优先级关系。
class OriginGroupInLoadBalancer < TencentCloud::Common::AbstractModel
# @param Priority: 优先级,填写格式为 "priority_" + "数字",最高优先级为 "priority_1"。参考取值有:
# priority_1:第一优先级;
# priority_2:第二优先级;
# priority_3:第三优先级。其他优先级可以将数字递增,最多可以递增至 "priority_10"。
# @type Priority: String
# @param OriginGroupId: 源站组 ID。
# @type OriginGroupId: String
attr_accessor :Priority, :OriginGroupId
def initialize(priority=nil, origingroupid=nil)
@Priority = priority
@OriginGroupId = origingroupid
end
def deserialize(params)
@Priority = params['Priority']
@OriginGroupId = params['OriginGroupId']
end
end
# 源站组引用服务。
class OriginGroupReference < TencentCloud::Common::AbstractModel
# @param InstanceType: 引用服务类型,取值有:
# AccelerationDomain: 加速域名;
# RuleEngine: 规则引擎;
# Loadbalance: 负载均衡;
# ApplicationProxy: 四层代理。
# @type InstanceType: String
# @param InstanceId: 引用类型的实例ID。
# @type InstanceId: String
# @param InstanceName: 应用类型的实例名称。
# @type InstanceName: String
attr_accessor :InstanceType, :InstanceId, :InstanceName
def initialize(instancetype=nil, instanceid=nil, instancename=nil)
@InstanceType = instancetype
@InstanceId = instanceid
@InstanceName = instancename
end
def deserialize(params)
@InstanceType = params['InstanceType']
@InstanceId = params['InstanceId']
@InstanceName = params['InstanceName']
end
end
# 源站组里的源站健康状态。
class OriginHealthStatus < TencentCloud::Common::AbstractModel
# @param Origin: 源站。
# @type Origin: String
# @param Healthy: 源站健康状态,取值有:
# Healthy:健康;
# Unhealthy:不健康;
# Undetected:未探测到数据。
# @type Healthy: String
attr_accessor :Origin, :Healthy
def initialize(origin=nil, healthy=nil)
@Origin = origin
@Healthy = healthy
end
def deserialize(params)
@Origin = params['Origin']
@Healthy = params['Healthy']
end
end
# 加速域名源站信息。
class OriginInfo < TencentCloud::Common::AbstractModel
# @param OriginType: 源站类型,取值有:
# IP_DOMAIN:IPV4、IPV6 或域名类型源站;
# COS:腾讯云 COS 对象存储源站;
# AWS_S3:AWS S3 对象存储源站;
# ORIGIN_GROUP:源站组类型源站;
# VOD:云点播;
# SPACE:源站卸载,当前仅白名单开放;
# LB:负载均衡,当前仅白名单开放。
# @type OriginType: String
# @param Origin: 源站地址,根据 OriginType 的取值分为以下情况:
# 当 OriginType = IP_DOMAIN 时,该参数请填写 IPv4、IPv6 地址或域名;
# 当 OriginType = COS 时,该参数请填写 COS 桶的访问域名;
# 当 OriginType = AWS_S3,该参数请填写 S3 桶的访问域名;
# 当 OriginType = ORIGIN_GROUP 时,该参数请填写源站组 ID;
# 当 OriginType = VOD 时,该参数请填写云点播应用 ID ;
# 当 OriginType = LB 时,该参数请填写负载均衡实例 ID,该功能当前仅白名单开放;
# 当 OriginType = SPACE 时,该参数请填写源站卸载空间 ID,该功能当前仅白名单开放。
# @type Origin: String
# @param BackupOrigin: 备用源站组 ID,该参数仅在 OriginType = ORIGIN_GROUP 时生效,该字段为旧版能力,调用后控制台无法进行配置修改,如需使用请提交工单咨询。
# @type BackupOrigin: String
# @param PrivateAccess: 指定是否允许访问私有对象存储源站,该参数仅当源站类型 OriginType = COS 或 AWS_S3 时会生效,取值有:
# on:使用私有鉴权;
# off:不使用私有鉴权。
# 不填写时,默认值为off。
# @type PrivateAccess: String
# @param PrivateParameters: 私有鉴权使用参数,该参数仅当源站类型 PrivateAccess = on 时会生效。
# @type PrivateParameters: Array
# @param VodeoSubAppId: VODEO 子应用 ID。该参数当 OriginType = VODEO 时必填。
# @type VodeoSubAppId: Integer
# @param VodeoDistributionRange: VODEO 分发范围,该参数当 OriginType = VODEO 时必填。取值有:
# All:当前应用下所有存储桶;
# Bucket:指定的某一个存储桶。
# @type VodeoDistributionRange: String
# @param VodeoBucketId: VODEO 存储桶 ID,该参数当 OriginType = VODEO 且 VodeoDistributionRange = Bucket 时必填。
# @type VodeoBucketId: String
attr_accessor :OriginType, :Origin, :BackupOrigin, :PrivateAccess, :PrivateParameters, :VodeoSubAppId, :VodeoDistributionRange, :VodeoBucketId
extend Gem::Deprecate
deprecate :VodeoSubAppId, :none, 2024, 11
deprecate :VodeoSubAppId=, :none, 2024, 11
deprecate :VodeoDistributionRange, :none, 2024, 11
deprecate :VodeoDistributionRange=, :none, 2024, 11
deprecate :VodeoBucketId, :none, 2024, 11
deprecate :VodeoBucketId=, :none, 2024, 11
def initialize(origintype=nil, origin=nil, backuporigin=nil, privateaccess=nil, privateparameters=nil, vodeosubappid=nil, vodeodistributionrange=nil, vodeobucketid=nil)
@OriginType = origintype
@Origin = origin
@BackupOrigin = backuporigin
@PrivateAccess = privateaccess
@PrivateParameters = privateparameters
@VodeoSubAppId = vodeosubappid
@VodeoDistributionRange = vodeodistributionrange
@VodeoBucketId = vodeobucketid
end
def deserialize(params)
@OriginType = params['OriginType']
@Origin = params['Origin']
@BackupOrigin = params['BackupOrigin']
@PrivateAccess = params['PrivateAccess']
unless params['PrivateParameters'].nil?
@PrivateParameters = []
params['PrivateParameters'].each do |i|
privateparameter_tmp = PrivateParameter.new
privateparameter_tmp.deserialize(i)
@PrivateParameters << privateparameter_tmp
end
end
@VodeoSubAppId = params['VodeoSubAppId']
@VodeoDistributionRange = params['VodeoDistributionRange']
@VodeoBucketId = params['VodeoBucketId']
end
end
# 源站防护信息
class OriginProtectionInfo < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# @type ZoneId: String
# @param Hosts: 域名列表。
# @type Hosts: Array
# @param ProxyIds: 代理ID列表。
# @type ProxyIds: Array
# @param CurrentIPWhitelist: 当前版本的IP白名单。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CurrentIPWhitelist: :class:`Tencentcloud::Teo.v20220901.models.IPWhitelist`
# @param NeedUpdate: 该站点是否需要更新源站白名单,取值有:
# true :需要更新IP白名单 ;
# false :无需更新IP白名单。
# @type NeedUpdate: Boolean
# @param Status: 源站防护状态,取值有:
# online :源站防护启用中 ;
# offline :源站防护已停用 ;
# nonactivate :源站防护未激活,仅在从未使用过源站防护功能的站点调用中返回。
# @type Status: String
# @param PlanSupport: 站点套餐是否支持源站防护,取值有:
# true :支持 ;
# false :不支持。
# @type PlanSupport: Boolean
# @param DiffIPWhitelist: 最新IP白名单与当前IP白名单的对比。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DiffIPWhitelist: :class:`Tencentcloud::Teo.v20220901.models.DiffIPWhitelist`
attr_accessor :ZoneId, :Hosts, :ProxyIds, :CurrentIPWhitelist, :NeedUpdate, :Status, :PlanSupport, :DiffIPWhitelist
def initialize(zoneid=nil, hosts=nil, proxyids=nil, currentipwhitelist=nil, needupdate=nil, status=nil, plansupport=nil, diffipwhitelist=nil)
@ZoneId = zoneid
@Hosts = hosts
@ProxyIds = proxyids
@CurrentIPWhitelist = currentipwhitelist
@NeedUpdate = needupdate
@Status = status
@PlanSupport = plansupport
@DiffIPWhitelist = diffipwhitelist
end
def deserialize(params)
@ZoneId = params['ZoneId']
@Hosts = params['Hosts']
@ProxyIds = params['ProxyIds']
unless params['CurrentIPWhitelist'].nil?
@CurrentIPWhitelist = IPWhitelist.new
@CurrentIPWhitelist.deserialize(params['CurrentIPWhitelist'])
end
@NeedUpdate = params['NeedUpdate']
@Status = params['Status']
@PlanSupport = params['PlanSupport']
unless params['DiffIPWhitelist'].nil?
@DiffIPWhitelist = DiffIPWhitelist.new
@DiffIPWhitelist.deserialize(params['DiffIPWhitelist'])
end
end
end
# 源站组记录
class OriginRecord < TencentCloud::Common::AbstractModel
# @param Record: 源站记录值,不包含端口信息,可以为:IPv4,IPv6,域名格式。
# @type Record: String
# @param Type: 源站类型,取值有:
# IP_DOMAIN:IPV4、IPV6、域名类型源站;
# COS:COS源。
# AWS_S3:AWS S3对象存储源站。
# @type Type: String
# @param RecordId: 源站记录ID。
# @type RecordId: String
# @param Weight: 源站权重,取值为0-100, 不填表示不设置权重,由系统自由调度,填0表示权重为0, 流量将不会调度到此源站。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Weight: Integer
# @param Private: 是否私有鉴权,当源站类型 RecordType=COS/AWS_S3 时生效,取值有:
# true:使用私有鉴权;
# false:不使用私有鉴权。不填写,默认值为:false。
# @type Private: Boolean
# @param PrivateParameters: 私有鉴权参数,当源站类型Private=true时有效。
# @type PrivateParameters: Array
attr_accessor :Record, :Type, :RecordId, :Weight, :Private, :PrivateParameters
def initialize(record=nil, type=nil, recordid=nil, weight=nil, private=nil, privateparameters=nil)
@Record = record
@Type = type
@RecordId = recordid
@Weight = weight
@Private = private
@PrivateParameters = privateparameters
end
def deserialize(params)
@Record = params['Record']
@Type = params['Type']
@RecordId = params['RecordId']
@Weight = params['Weight']
@Private = params['Private']
unless params['PrivateParameters'].nil?
@PrivateParameters = []
params['PrivateParameters'].each do |i|
privateparameter_tmp = PrivateParameter.new
privateparameter_tmp.deserialize(i)
@PrivateParameters << privateparameter_tmp
end
end
end
end
# 该结构体表示各种场景、模式下,用于验证用户对站点域名的归属权内容。
class OwnershipVerification < TencentCloud::Common::AbstractModel
# @param DnsVerification: CNAME 、无域名接入时,使用 DNS 解析验证时所需的信息。详情参考 [站点/域名归属权验证
# ](https://cloud.tencent.com/document/product/1552/70789#7af6ecf8-afca-4e35-8811-b5797ed1bde5)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DnsVerification: :class:`Tencentcloud::Teo.v20220901.models.DnsVerification`
# @param FileVerification: CNAME 、无域名接入时,使用文件验证时所需的信息。详情参考 [站点/域名归属权验证
# ](https://cloud.tencent.com/document/product/1552/70789#7af6ecf8-afca-4e35-8811-b5797ed1bde5)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FileVerification: :class:`Tencentcloud::Teo.v20220901.models.FileVerification`
# @param NsVerification: NS 接入,切换 DNS 服务器所需的信息。详情参考 [修改 DNS 服务器](https://cloud.tencent.com/document/product/1552/90452)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NsVerification: :class:`Tencentcloud::Teo.v20220901.models.NsVerification`
attr_accessor :DnsVerification, :FileVerification, :NsVerification
def initialize(dnsverification=nil, fileverification=nil, nsverification=nil)
@DnsVerification = dnsverification
@FileVerification = fileverification
@NsVerification = nsverification
end
def deserialize(params)
unless params['DnsVerification'].nil?
@DnsVerification = DnsVerification.new
@DnsVerification.deserialize(params['DnsVerification'])
end
unless params['FileVerification'].nil?
@FileVerification = FileVerification.new
@FileVerification.deserialize(params['FileVerification'])
end
unless params['NsVerification'].nil?
@NsVerification = NsVerification.new
@NsVerification.deserialize(params['NsVerification'])
end
end
end
# 例外规则的详细模块配置。
class PartialModule < TencentCloud::Common::AbstractModel
# @param Module: 模块名称,取值为:
# waf:托管规则。
# @type Module: String
# @param Include: 模块下的需要例外的具体规则ID列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Include: Array
attr_accessor :Module, :Include
def initialize(_module=nil, include=nil)
@Module = _module
@Include = include
end
def deserialize(params)
@Module = params['Module']
@Include = params['Include']
end
end
# edgeone套餐信息
class PlanInfo < TencentCloud::Common::AbstractModel
# @param Currency: 结算货币类型,取值有:
# CNY :人民币结算;
# USD :美元结算。
# @type Currency: String
# @param Flux: 套餐所含流量,该流量数值为安全加速流量,内容加速流量和智能加速流量的总和(单位:字节)。
# @type Flux: Integer
# @param Frequency: 结算周期,取值有:
# y :按年结算;
# m :按月结算;
# h :按小时结算;
# M :按分钟结算;
# s :按秒结算。
# @type Frequency: String
# @param PlanType: 套餐类型,取值有:
# sta :全球内容分发网络(不包括中国大陆)标准版套餐;
# sta_with_bot :全球内容分发网络(不包括中国大陆)标准版套餐附带bot管理;
# sta_cm :中国大陆内容分发网络标准版套餐;
# sta_cm_with_bot :中国大陆内容分发网络标准版套餐附带bot管理;
# sta_global :全球内容分发网络(包括中国大陆)标准版套餐;
# sta_global_with_bot :全球内容分发网络(包括中国大陆)标准版套餐附带bot管理;
# ent :全球内容分发网络(不包括中国大陆)企业版套餐;
# ent_with_bot : 全球内容分发网络(不包括中国大陆)企业版套餐附带bot管理;
# ent_cm :中国大陆内容分发网络企业版套餐;
# ent_cm_with_bot :中国大陆内容分发网络企业版套餐附带bot管理;
# ent_global :全球内容分发网络(包括中国大陆)企业版套餐;
# ent_global_with_bot :全球内容分发网络(包括中国大陆)企业版套餐附带bot管理。
# @type PlanType: String
# @param Price: 套餐价格(单位:分)。
# @type Price: Float
# @param Request: 套餐所含请求次数,该请求次数为安全加速请求次数。(单位:次)。
# @type Request: Integer
# @param SiteNumber: 套餐所能绑定的站点个数。
# @type SiteNumber: Integer
# @param Area: 套餐加速区域类型,取值有:
# mainland :中国大陆;
# overseas :全球(不包括中国大陆);
# global :全球(包括中国大陆)。
# @type Area: String
attr_accessor :Currency, :Flux, :Frequency, :PlanType, :Price, :Request, :SiteNumber, :Area
def initialize(currency=nil, flux=nil, frequency=nil, plantype=nil, price=nil, request=nil, sitenumber=nil, area=nil)
@Currency = currency
@Flux = flux
@Frequency = frequency
@PlanType = plantype
@Price = price
@Request = request
@SiteNumber = sitenumber
@Area = area
end
def deserialize(params)
@Currency = params['Currency']
@Flux = params['Flux']
@Frequency = params['Frequency']
@PlanType = params['PlanType']
@Price = params['Price']
@Request = params['Request']
@SiteNumber = params['SiteNumber']
@Area = params['Area']
end
end
# POST请求上传文件流式传输最大限制
class PostMaxSize < TencentCloud::Common::AbstractModel
# @param Switch: 是否开启 POST 请求上传文件限制,平台默认为限制为32MB,取值有:
# on:开启限制;
# off:关闭限制。
# @type Switch: String
# @param MaxSize: 最大限制,取值在1MB和500MB之间。单位字节。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MaxSize: Integer
attr_accessor :Switch, :MaxSize
def initialize(switch=nil, maxsize=nil)
@Switch = switch
@MaxSize = maxsize
end
def deserialize(params)
@Switch = params['Switch']
@MaxSize = params['MaxSize']
end
end
# 预付费套餐计费参数
class PrepaidPlanParam < TencentCloud::Common::AbstractModel
# @param Period: 订阅预付费套餐的周期,单位:月,取值有:1,2,3,4,5,6,7,8,9,10,11,12,24,36。
# 不填写使用默认值 1。
# @type Period: Integer
# @param RenewFlag: 预付费套餐的自动续费标志,取值有:
# on:开启自动续费;
# off:不开启自动续费。
# 不填写使用默认值 off,自动续费时,默认续费1个月。
# @type RenewFlag: String
attr_accessor :Period, :RenewFlag
def initialize(period=nil, renewflag=nil)
@Period = period
@RenewFlag = renewflag
end
def deserialize(params)
@Period = params['Period']
@RenewFlag = params['RenewFlag']
end
end
# 对象存储源站私有鉴权参数
class PrivateParameter < TencentCloud::Common::AbstractModel
# @param Name: 私有鉴权参数名称,取值有:
# AccessKeyId:鉴权参数 Access Key ID;
# SecretAccessKey:鉴权参数 Secret Access Key;
# SignatureVersion:鉴权版本,v2 或者 v4;
# Region:存储桶地域。
# @type Name: String
# @param Value: 私有鉴权参数值。
# @type Value: String
attr_accessor :Name, :Value
def initialize(name=nil, value=nil)
@Name = name
@Value = value
end
def deserialize(params)
@Name = params['Name']
@Value = params['Value']
end
end
# 查询条件
class QueryCondition < TencentCloud::Common::AbstractModel
# @param Key: 筛选条件的key。
# @type Key: String
# @param Operator: 查询条件操作符,操作类型有:
# equals: 等于;
# notEquals: 不等于;
# include: 包含;
# notInclude: 不包含;
# startWith: 开始的值是value;
# notStartWith: 不以value的值开始;
# endWith: 结尾是value值;
# notEndWith: 不以value的值结尾。
# @type Operator: String
# @param Value: 筛选条件的值。
# @type Value: Array
attr_accessor :Key, :Operator, :Value
def initialize(key=nil, operator=nil, value=nil)
@Key = key
@Operator = operator
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Operator = params['Operator']
@Value = params['Value']
end
end
# CacheKey中包含请求参数
class QueryString < TencentCloud::Common::AbstractModel
# @param Switch: CacheKey是否由QueryString组成,取值有:
# on:是;
# off:否。
# @type Switch: String
# @param Action: CacheKey使用QueryString的方式,取值有:
# includeCustom:使用部分url参数;
# excludeCustom:排除部分url参数。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Action: String
# @param Value: 使用/排除的url参数数组。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Value: Array
attr_accessor :Switch, :Action, :Value
def initialize(switch=nil, action=nil, value=nil)
@Switch = switch
@Action = action
@Value = value
end
def deserialize(params)
@Switch = params['Switch']
@Action = params['Action']
@Value = params['Value']
end
end
# Quic配置项
class Quic < TencentCloud::Common::AbstractModel
# @param Switch: 是否开启 Quic 配置,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 刷新/预热 可用量及配额
class Quota < TencentCloud::Common::AbstractModel
# @param Batch: 单次批量提交配额上限。
# @type Batch: Integer
# @param Daily: 每日提交配额上限。
# @type Daily: Integer
# @param DailyAvailable: 每日剩余的可提交配额。
# @type DailyAvailable: Integer
# @param Type: 刷新预热缓存类型,取值有:
# purge_prefix:按前缀刷新;
# purge_url:按URL刷新;
# purge_host:按Hostname刷新;
# purge_all:刷新全部缓存内容;
# purge_cache_tag:按CacheTag刷新; prefetch_url:按URL预热。
# @type Type: String
attr_accessor :Batch, :Daily, :DailyAvailable, :Type
def initialize(batch=nil, daily=nil, dailyavailable=nil, type=nil)
@Batch = batch
@Daily = daily
@DailyAvailable = dailyavailable
@Type = type
end
def deserialize(params)
@Batch = params['Batch']
@Daily = params['Daily']
@DailyAvailable = params['DailyAvailable']
@Type = params['Type']
end
end
# 速率限制规则
class RateLimitConfig < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param RateLimitUserRules: 速率限制-用户规则列表。如果为null,默认使用历史配置。
# @type RateLimitUserRules: Array
# @param RateLimitTemplate: 速率限制模板功能。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RateLimitTemplate: :class:`Tencentcloud::Teo.v20220901.models.RateLimitTemplate`
# @param RateLimitIntelligence: 智能客户端过滤。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RateLimitIntelligence: :class:`Tencentcloud::Teo.v20220901.models.RateLimitIntelligence`
# @param RateLimitCustomizes: 速率限制-托管定制规则。如果为null,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RateLimitCustomizes: Array
attr_accessor :Switch, :RateLimitUserRules, :RateLimitTemplate, :RateLimitIntelligence, :RateLimitCustomizes
def initialize(switch=nil, ratelimituserrules=nil, ratelimittemplate=nil, ratelimitintelligence=nil, ratelimitcustomizes=nil)
@Switch = switch
@RateLimitUserRules = ratelimituserrules
@RateLimitTemplate = ratelimittemplate
@RateLimitIntelligence = ratelimitintelligence
@RateLimitCustomizes = ratelimitcustomizes
end
def deserialize(params)
@Switch = params['Switch']
unless params['RateLimitUserRules'].nil?
@RateLimitUserRules = []
params['RateLimitUserRules'].each do |i|
ratelimituserrule_tmp = RateLimitUserRule.new
ratelimituserrule_tmp.deserialize(i)
@RateLimitUserRules << ratelimituserrule_tmp
end
end
unless params['RateLimitTemplate'].nil?
@RateLimitTemplate = RateLimitTemplate.new
@RateLimitTemplate.deserialize(params['RateLimitTemplate'])
end
unless params['RateLimitIntelligence'].nil?
@RateLimitIntelligence = RateLimitIntelligence.new
@RateLimitIntelligence.deserialize(params['RateLimitIntelligence'])
end
unless params['RateLimitCustomizes'].nil?
@RateLimitCustomizes = []
params['RateLimitCustomizes'].each do |i|
ratelimituserrule_tmp = RateLimitUserRule.new
ratelimituserrule_tmp.deserialize(i)
@RateLimitCustomizes << ratelimituserrule_tmp
end
end
end
end
# 智能客户端过滤
class RateLimitIntelligence < TencentCloud::Common::AbstractModel
# @param Switch: 功能开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param Action: 执行动作,取值有:
# monitor:观察;
# alg:挑战。
# @type Action: String
# @param RuleId: 规则id,仅出参使用。
# @type RuleId: Integer
attr_accessor :Switch, :Action, :RuleId
def initialize(switch=nil, action=nil, ruleid=nil)
@Switch = switch
@Action = action
@RuleId = ruleid
end
def deserialize(params)
@Switch = params['Switch']
@Action = params['Action']
@RuleId = params['RuleId']
end
end
# 速率限制模板
class RateLimitTemplate < TencentCloud::Common::AbstractModel
# @param Mode: 模板等级名称,取值有:
# sup_loose:超级宽松;
# loose:宽松;
# emergency:紧急;
# normal:适中;
# strict:严格;
# close:关闭,仅精准速率限制生效。
# @type Mode: String
# @param Action: 模板处置方式,取值有:
# alg:JavaScript挑战;
# monitor:观察。不填写默认取alg。
# @type Action: String
# @param RateLimitTemplateDetail: 模板值详情。仅出参返回。
# @type RateLimitTemplateDetail: :class:`Tencentcloud::Teo.v20220901.models.RateLimitTemplateDetail`
attr_accessor :Mode, :Action, :RateLimitTemplateDetail
def initialize(mode=nil, action=nil, ratelimittemplatedetail=nil)
@Mode = mode
@Action = action
@RateLimitTemplateDetail = ratelimittemplatedetail
end
def deserialize(params)
@Mode = params['Mode']
@Action = params['Action']
unless params['RateLimitTemplateDetail'].nil?
@RateLimitTemplateDetail = RateLimitTemplateDetail.new
@RateLimitTemplateDetail.deserialize(params['RateLimitTemplateDetail'])
end
end
end
# 模板当前详细配置
class RateLimitTemplateDetail < TencentCloud::Common::AbstractModel
# @param Mode: 模板等级名称,取值有:
# sup_loose:超级宽松;
# loose:宽松;
# emergency:紧急;
# normal:适中;
# strict:严格;
# close:关闭,仅精准速率限制生效。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Mode: String
# @param ID: 唯一id。
# @type ID: Integer
# @param Action: 模板处置方式,取值有:
# alg:JavaScript挑战;
# monitor:观察。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Action: String
# @param PunishTime: 惩罚时间,取值范围0-2天,单位秒。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PunishTime: Integer
# @param Threshold: 统计阈值,单位是次,取值范围0-4294967294。
# @type Threshold: Integer
# @param Period: 统计周期,取值范围0-120秒。
# @type Period: Integer
attr_accessor :Mode, :ID, :Action, :PunishTime, :Threshold, :Period
def initialize(mode=nil, id=nil, action=nil, punishtime=nil, threshold=nil, period=nil)
@Mode = mode
@ID = id
@Action = action
@PunishTime = punishtime
@Threshold = threshold
@Period = period
end
def deserialize(params)
@Mode = params['Mode']
@ID = params['ID']
@Action = params['Action']
@PunishTime = params['PunishTime']
@Threshold = params['Threshold']
@Period = params['Period']
end
end
# RateLimit规则
class RateLimitUserRule < TencentCloud::Common::AbstractModel
# @param Threshold: 速率限制统计阈值,单位是次,取值范围0-4294967294。
# @type Threshold: Integer
# @param Period: 速率限制统计时间,取值范围 10/20/30/40/50/60 单位是秒。
# @type Period: Integer
# @param RuleName: 规则名,只能以英文字符,数字,下划线组合,且不能以下划线开头。
# @type RuleName: String
# @param Action: 处置动作,取值有: monitor:观察; drop:拦截; redirect:重定向; page:指定页面;alg:JavaScript 挑战。
# @type Action: String
# @param PunishTime: 惩罚时长,0-2天。
# @type PunishTime: Integer
# @param PunishTimeUnit: 处罚时长单位,取值有:
# second:秒;
# minutes:分钟;
# hour:小时。
# @type PunishTimeUnit: String
# @param RuleStatus: 规则状态,取值有:
# on:生效;
# off:不生效。默认 on 生效。
# @type RuleStatus: String
# @param AclConditions: 规则详情。
# @type AclConditions: Array
# @param RulePriority: 规则权重,取值范围0-100。
# @type RulePriority: Integer
# @param RuleID: 规则 Id。仅出参使用。
# @type RuleID: Integer
# @param FreqFields: 过滤词,取值有:
# sip:客户端 ip。
# 默认为空字符串。
# @type FreqFields: Array
# @param UpdateTime: 更新时间。仅出参使用。修改时默认为当前时间。
# @type UpdateTime: String
# @param FreqScope: 统计范围。取值有:
# source_to_eo:(响应)源站到 EdgeOne;
# client_to_eo:(请求)客户端到 EdgeOne。
# 默认为 source_to_eo。
# @type FreqScope: Array
# @param Name: 自定义返回页面的名称。Action 是 page 时必填,且不能为空。
# @type Name: String
# @param CustomResponseId: 自定义响应 Id。该 Id 可通过查询自定义错误页列表接口获取。默认值为default,使用系统默认页面。Action 是 page 时必填,且不能为空。
# @type CustomResponseId: String
# @param ResponseCode: 自定义返回页面的响应码。Action 是 page 时必填,且不能为空,取值: 100~600,不支持 3xx 响应码。默认值:567。
# @type ResponseCode: Integer
# @param RedirectUrl: 重定向时候的地址。Action 是 redirect 时必填,且不能为空。
# @type RedirectUrl: String
attr_accessor :Threshold, :Period, :RuleName, :Action, :PunishTime, :PunishTimeUnit, :RuleStatus, :AclConditions, :RulePriority, :RuleID, :FreqFields, :UpdateTime, :FreqScope, :Name, :CustomResponseId, :ResponseCode, :RedirectUrl
def initialize(threshold=nil, period=nil, rulename=nil, action=nil, punishtime=nil, punishtimeunit=nil, rulestatus=nil, aclconditions=nil, rulepriority=nil, ruleid=nil, freqfields=nil, updatetime=nil, freqscope=nil, name=nil, customresponseid=nil, responsecode=nil, redirecturl=nil)
@Threshold = threshold
@Period = period
@RuleName = rulename
@Action = action
@PunishTime = punishtime
@PunishTimeUnit = punishtimeunit
@RuleStatus = rulestatus
@AclConditions = aclconditions
@RulePriority = rulepriority
@RuleID = ruleid
@FreqFields = freqfields
@UpdateTime = updatetime
@FreqScope = freqscope
@Name = name
@CustomResponseId = customresponseid
@ResponseCode = responsecode
@RedirectUrl = redirecturl
end
def deserialize(params)
@Threshold = params['Threshold']
@Period = params['Period']
@RuleName = params['RuleName']
@Action = params['Action']
@PunishTime = params['PunishTime']
@PunishTimeUnit = params['PunishTimeUnit']
@RuleStatus = params['RuleStatus']
unless params['AclConditions'].nil?
@AclConditions = []
params['AclConditions'].each do |i|
aclcondition_tmp = AclCondition.new
aclcondition_tmp.deserialize(i)
@AclConditions << aclcondition_tmp
end
end
@RulePriority = params['RulePriority']
@RuleID = params['RuleID']
@FreqFields = params['FreqFields']
@UpdateTime = params['UpdateTime']
@FreqScope = params['FreqScope']
@Name = params['Name']
@CustomResponseId = params['CustomResponseId']
@ResponseCode = params['ResponseCode']
@RedirectUrl = params['RedirectUrl']
end
end
# 实时日志投递任务。
class RealtimeLogDeliveryTask < TencentCloud::Common::AbstractModel
# @param TaskId: 实时日志投递任务 ID。
# @type TaskId: String
# @param TaskName: 实时日志投递任务的名称。
# @type TaskName: String
# @param DeliveryStatus: 实时日志投递任务的状态,取值有: enabled: 已启用; disabled: 已停用;deleted: 异常删除状态,请检查目的地腾讯云 CLS 日志集/日志主题是否已被删除。
# @type DeliveryStatus: String
# @param TaskType: 实时日志投递任务类型,取值有: cls: 推送到腾讯云 CLS; custom_endpoint:推送到自定义 HTTP(S) 地址; s3:推送到 AWS S3 兼容存储桶地址。
# @type TaskType: String
# @param EntityList: 实时日志投递任务对应的实体(七层域名或者四层代理实例)列表。取值示例如下: 七层域名:domain.example.com; 四层代理实例:sid-2s69eb5wcms7。
# @type EntityList: Array
# @param LogType: 数据投递类型,取值有: domain:站点加速日志; application:四层代理日志; web-rateLiming:速率限制和 CC 攻击防护日志; web-attack:托管规则日志; web-rule:自定义规则日志; web-bot:Bot管理日志。
# @type LogType: String
# @param Area: 数据投递区域,取值有: mainland:中国大陆境内; overseas:全球(不含中国大陆)。
# @type Area: String
# @param Fields: 投递的预设字段列表。
# @type Fields: Array
# @param CustomFields: 投递的自定义字段列表。
# @type CustomFields: Array
# @param DeliveryConditions: 日志投递的过滤条件。
# @type DeliveryConditions: Array
# @param Sample: 采样比例,采用千分制,取值范围为1-1000,例如:605 表示采样比例为 60.5%。
# @type Sample: Integer
# @param LogFormat: 日志投递的输出格式。出参为 null 时表示为默认格式,默认格式逻辑如下:
# 当 TaskType 取值为 custom_endpoint 时,默认格式为多个 JSON 对象组成的数组,每个 JSON 对象为一条日志;
# 当 TaskType 取值为 s3 时,默认格式为 JSON Lines。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LogFormat: :class:`Tencentcloud::Teo.v20220901.models.LogFormat`
# @param CLS: CLS 的配置信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CLS: :class:`Tencentcloud::Teo.v20220901.models.CLSTopic`
# @param CustomEndpoint: 自定义 HTTP 服务的配置信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CustomEndpoint: :class:`Tencentcloud::Teo.v20220901.models.CustomEndpoint`
# @param S3: AWS S3 兼容存储桶的配置信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type S3: :class:`Tencentcloud::Teo.v20220901.models.S3`
# @param CreateTime: 创建时间。
# @type CreateTime: String
# @param UpdateTime: 更新时间。
# @type UpdateTime: String
attr_accessor :TaskId, :TaskName, :DeliveryStatus, :TaskType, :EntityList, :LogType, :Area, :Fields, :CustomFields, :DeliveryConditions, :Sample, :LogFormat, :CLS, :CustomEndpoint, :S3, :CreateTime, :UpdateTime
def initialize(taskid=nil, taskname=nil, deliverystatus=nil, tasktype=nil, entitylist=nil, logtype=nil, area=nil, fields=nil, customfields=nil, deliveryconditions=nil, sample=nil, logformat=nil, cls=nil, customendpoint=nil, s3=nil, createtime=nil, updatetime=nil)
@TaskId = taskid
@TaskName = taskname
@DeliveryStatus = deliverystatus
@TaskType = tasktype
@EntityList = entitylist
@LogType = logtype
@Area = area
@Fields = fields
@CustomFields = customfields
@DeliveryConditions = deliveryconditions
@Sample = sample
@LogFormat = logformat
@CLS = cls
@CustomEndpoint = customendpoint
@S3 = s3
@CreateTime = createtime
@UpdateTime = updatetime
end
def deserialize(params)
@TaskId = params['TaskId']
@TaskName = params['TaskName']
@DeliveryStatus = params['DeliveryStatus']
@TaskType = params['TaskType']
@EntityList = params['EntityList']
@LogType = params['LogType']
@Area = params['Area']
@Fields = params['Fields']
unless params['CustomFields'].nil?
@CustomFields = []
params['CustomFields'].each do |i|
customfield_tmp = CustomField.new
customfield_tmp.deserialize(i)
@CustomFields << customfield_tmp
end
end
unless params['DeliveryConditions'].nil?
@DeliveryConditions = []
params['DeliveryConditions'].each do |i|
deliverycondition_tmp = DeliveryCondition.new
deliverycondition_tmp.deserialize(i)
@DeliveryConditions << deliverycondition_tmp
end
end
@Sample = params['Sample']
unless params['LogFormat'].nil?
@LogFormat = LogFormat.new
@LogFormat.deserialize(params['LogFormat'])
end
unless params['CLS'].nil?
@CLS = CLSTopic.new
@CLS.deserialize(params['CLS'])
end
unless params['CustomEndpoint'].nil?
@CustomEndpoint = CustomEndpoint.new
@CustomEndpoint.deserialize(params['CustomEndpoint'])
end
unless params['S3'].nil?
@S3 = S3.new
@S3.deserialize(params['S3'])
end
@CreateTime = params['CreateTime']
@UpdateTime = params['UpdateTime']
end
end
# 预付费套餐自动续费配置项。
class RenewFlag < TencentCloud::Common::AbstractModel
# @param Switch: 预付费套餐的自动续费标志,取值有:
# on:开启自动续费;
# off:不开启自动续费。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# RenewPlan请求参数结构体
class RenewPlanRequest < TencentCloud::Common::AbstractModel
# @param PlanId: 套餐 ID,形如 edgeone-2unuvzjmmn2q。
# @type PlanId: String
# @param Period: 续费套餐的时长,单位:月,取值有:1,2,3,4,5,6,7,8,9,10,11,12,24,36。
# @type Period: Integer
# @param AutoUseVoucher: 是否自动使用代金券,取值有: true:是; false:否。不填写使用默认值 false。
# @type AutoUseVoucher: String
attr_accessor :PlanId, :Period, :AutoUseVoucher
def initialize(planid=nil, period=nil, autousevoucher=nil)
@PlanId = planid
@Period = period
@AutoUseVoucher = autousevoucher
end
def deserialize(params)
@PlanId = params['PlanId']
@Period = params['Period']
@AutoUseVoucher = params['AutoUseVoucher']
end
end
# RenewPlan返回参数结构体
class RenewPlanResponse < TencentCloud::Common::AbstractModel
# @param DealName: 订单号。
# @type DealName: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :DealName, :RequestId
def initialize(dealname=nil, requestid=nil)
@DealName = dealname
@RequestId = requestid
end
def deserialize(params)
@DealName = params['DealName']
@RequestId = params['RequestId']
end
end
# 计费资源
class Resource < TencentCloud::Common::AbstractModel
# @param Id: 资源 ID。
# @type Id: String
# @param PayMode: 付费模式,取值有:
# 0:后付费。
# @type PayMode: Integer
# @param CreateTime: 创建时间。
# @type CreateTime: String
# @param EnableTime: 生效时间。
# @type EnableTime: String
# @param ExpireTime: 失效时间。
# @type ExpireTime: String
# @param Status: 套餐状态,取值有:
# normal:正常;
# isolated:隔离;
# destroyed:销毁。
# @type Status: String
# @param Sv: 询价参数。
# @type Sv: Array
# @param AutoRenewFlag: 是否自动续费,取值有:
# 0:默认状态;
# 1:自动续费;
# 2:不自动续费。
# @type AutoRenewFlag: Integer
# @param PlanId: 套餐关联资源 ID。
# @type PlanId: String
# @param Area: 地域,取值有:
# mainland:国内;
# overseas:海外。
# global:全球。
# @type Area: String
# @param Group: 资源类型,取值有:
# plan:套餐类型;
# pay-as-you-go:后付费类型。
# value-added:增值服务类型。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Group: String
# @param ZoneNumber: 当前资源绑定的站点数量。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ZoneNumber: Integer
# @param Type: 资源标记类型,取值有:
# vodeo:vodeo资源。
# @type Type: String
attr_accessor :Id, :PayMode, :CreateTime, :EnableTime, :ExpireTime, :Status, :Sv, :AutoRenewFlag, :PlanId, :Area, :Group, :ZoneNumber, :Type
def initialize(id=nil, paymode=nil, createtime=nil, enabletime=nil, expiretime=nil, status=nil, sv=nil, autorenewflag=nil, planid=nil, area=nil, group=nil, zonenumber=nil, type=nil)
@Id = id
@PayMode = paymode
@CreateTime = createtime
@EnableTime = enabletime
@ExpireTime = expiretime
@Status = status
@Sv = sv
@AutoRenewFlag = autorenewflag
@PlanId = planid
@Area = area
@Group = group
@ZoneNumber = zonenumber
@Type = type
end
def deserialize(params)
@Id = params['Id']
@PayMode = params['PayMode']
@CreateTime = params['CreateTime']
@EnableTime = params['EnableTime']
@ExpireTime = params['ExpireTime']
@Status = params['Status']
unless params['Sv'].nil?
@Sv = []
params['Sv'].each do |i|
sv_tmp = Sv.new
sv_tmp.deserialize(i)
@Sv << sv_tmp
end
end
@AutoRenewFlag = params['AutoRenewFlag']
@PlanId = params['PlanId']
@Area = params['Area']
@Group = params['Group']
@ZoneNumber = params['ZoneNumber']
@Type = params['Type']
end
end
# 规则引擎HTTP请求头/响应头类型的动作
class RewriteAction < TencentCloud::Common::AbstractModel
# @param Action: 功能名称,功能名称填写规范可调用接口 [查询规则引擎的设置参数](https://cloud.tencent.com/document/product/1552/80618) 查看。
# @type Action: String
# @param Parameters: 参数。
# @type Parameters: Array
attr_accessor :Action, :Parameters
def initialize(action=nil, parameters=nil)
@Action = action
@Parameters = parameters
end
def deserialize(params)
@Action = params['Action']
unless params['Parameters'].nil?
@Parameters = []
params['Parameters'].each do |i|
rulerewriteactionparams_tmp = RuleRewriteActionParams.new
rulerewriteactionparams_tmp.deserialize(i)
@Parameters << rulerewriteactionparams_tmp
end
end
end
end
# 规则引擎规则项,Conditions 数组内多个项的关系为 或,内层 Conditions 列表内多个项的关系为 且。
class Rule < TencentCloud::Common::AbstractModel
# @param Conditions: 执行功能判断条件。
# 注意:满足该数组内任意一项条件,功能即可执行。
# @type Conditions: Array
# @param Actions: 执行的功能。注意:Actions 和 SubRules 不可都为空
# @type Actions: Array
# @param SubRules: 嵌套规则。注意:SubRules 和 Actions 不可都为空
# @type SubRules: Array
attr_accessor :Conditions, :Actions, :SubRules
def initialize(conditions=nil, actions=nil, subrules=nil)
@Conditions = conditions
@Actions = actions
@SubRules = subrules
end
def deserialize(params)
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
ruleandconditions_tmp = RuleAndConditions.new
ruleandconditions_tmp.deserialize(i)
@Conditions << ruleandconditions_tmp
end
end
unless params['Actions'].nil?
@Actions = []
params['Actions'].each do |i|
action_tmp = Action.new
action_tmp.deserialize(i)
@Actions << action_tmp
end
end
unless params['SubRules'].nil?
@SubRules = []
params['SubRules'].each do |i|
subruleitem_tmp = SubRuleItem.new
subruleitem_tmp.deserialize(i)
@SubRules << subruleitem_tmp
end
end
end
end
# 规则引擎条件且关系条件列表
class RuleAndConditions < TencentCloud::Common::AbstractModel
# @param Conditions: 规则引擎条件,该数组内所有项全部满足即判断该条件满足。
# @type Conditions: Array
attr_accessor :Conditions
def initialize(conditions=nil)
@Conditions = conditions
end
def deserialize(params)
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
rulecondition_tmp = RuleCondition.new
rulecondition_tmp.deserialize(i)
@Conditions << rulecondition_tmp
end
end
end
end
# 规则引擎可应用于匹配请求的设置详细信息,可选参数配置项
class RuleChoicePropertiesItem < TencentCloud::Common::AbstractModel
# @param Name: 参数名称。
# @type Name: String
# @param Type: 参数值类型。
# CHOICE:参数值只能在 ChoicesValue 中选择;
# TOGGLE:参数值为开关类型,可在 ChoicesValue 中选择;
# CUSTOM_NUM:参数值用户自定义,整型类型;
# CUSTOM_STRING:参数值用户自定义,字符串类型。
# @type Type: String
# @param ChoicesValue: 参数值的可选值。
# 注意:若参数值为用户自定义则该数组为空数组。
# @type ChoicesValue: Array
# @param Min: 数值参数的最小值,非数值参数或 Min 和 Max 值都为 0 则此项无意义。
# @type Min: Integer
# @param Max: 数值参数的最大值,非数值参数或 Min 和 Max 值都为 0 则此项无意义。
# @type Max: Integer
# @param IsMultiple: 参数值是否支持多选或者填写多个。
# @type IsMultiple: Boolean
# @param IsAllowEmpty: 是否允许为空。
# @type IsAllowEmpty: Boolean
# @param ExtraParameter: 特殊参数。
# 为 NULL:RuleAction 选择 NormalAction;
# 成员参数 Id 为 Action:RuleAction 选择 RewirteAction;
# 成员参数 Id 为 StatusCode:RuleAction 选择 CodeAction。
# @type ExtraParameter: :class:`Tencentcloud::Teo.v20220901.models.RuleExtraParameter`
attr_accessor :Name, :Type, :ChoicesValue, :Min, :Max, :IsMultiple, :IsAllowEmpty, :ExtraParameter
def initialize(name=nil, type=nil, choicesvalue=nil, min=nil, max=nil, ismultiple=nil, isallowempty=nil, extraparameter=nil)
@Name = name
@Type = type
@ChoicesValue = choicesvalue
@Min = min
@Max = max
@IsMultiple = ismultiple
@IsAllowEmpty = isallowempty
@ExtraParameter = extraparameter
end
def deserialize(params)
@Name = params['Name']
@Type = params['Type']
@ChoicesValue = params['ChoicesValue']
@Min = params['Min']
@Max = params['Max']
@IsMultiple = params['IsMultiple']
@IsAllowEmpty = params['IsAllowEmpty']
unless params['ExtraParameter'].nil?
@ExtraParameter = RuleExtraParameter.new
@ExtraParameter.deserialize(params['ExtraParameter'])
end
end
end
# 规则引擎条件使用StatusCode字段动作参数
class RuleCodeActionParams < TencentCloud::Common::AbstractModel
# @param StatusCode: 状态 Code。
# @type StatusCode: Integer
# @param Name: 参数名称,参数填写规范可调用接口 [查询规则引擎的设置参数](https://cloud.tencent.com/document/product/1552/80618) 查看。
# @type Name: String
# @param Values: 参数值。
# @type Values: Array
attr_accessor :StatusCode, :Name, :Values
def initialize(statuscode=nil, name=nil, values=nil)
@StatusCode = statuscode
@Name = name
@Values = values
end
def deserialize(params)
@StatusCode = params['StatusCode']
@Name = params['Name']
@Values = params['Values']
end
end
# 规则引擎条件参数
class RuleCondition < TencentCloud::Common::AbstractModel
# @param Operator: 运算符,取值有:
# equal: 等于;
# notequal: 不等于;
# exist: 存在;
# notexist: 不存在。
# @type Operator: String
# @param Target: 匹配类型,取值有: filename:文件名; extension:文件后缀; host:HOST; full_url:URL Full,当前站点下完整 URL 路径,必须包含 HTTP 协议,Host 和 路径; url:URL Path,当前站点下 URL 路径的请求; client_country:客户端国家/地区; query_string:查询字符串,当前站点下请求URL的查询字符串; request_header:HTTP请求头部。 client_ip:客户端 IP。
# @type Target: String
# @param Values: 对应匹配类型的参数值,仅在匹配类型为查询字符串或HTTP请求头并且运算符取值为存在或不存在时允许传空数组,对应匹配类型有:
# 文件后缀:jpg、txt等文件后缀;
# 文件名称:例如 foo.jpg 中的 foo;
# 全部(站点任意请求): all;
# HOST:当前站点下的 host ,例如www.maxx55.com;
# URL Path:当前站点下 URL 路径的请求,例如:/example;
# URL Full:当前站点下完整 URL 请求,必须包含 HTTP 协议,Host 和 路径,例如:https://www.maxx55.cn/example;
# 客户端国家/地区:符合ISO3166标准的国家/地区标识;
# 查询字符串: 当前站点下URL请求中查询字符串的参数值,例如lang=cn&version=1中的cn和1;
# HTTP 请求头: HTTP请求头部字段值,例如Accept-Language:zh-CN,zh;q=0.9中的zh-CN,zh;q=0.9。
# 客户端 IP: 当前请求携带的客户端请求IP,支持IPv4 IPv6, 支持IP段。
# @type Values: Array
# @param IgnoreCase: 是否忽略参数值的大小写,默认值为 false。
# @type IgnoreCase: Boolean
# @param Name: 对应匹配类型的参数名称,在 Target 值为以下取值时有效,有效时值不能为空:
# query_string(查询字符串): 当前站点下URL请求中查询字符串的参数名称,例如lang=cn&version=1中的lang和version;
# request_header(HTTP 请求头): HTTP请求头部字段名,例如Accept-Language:zh-CN,zh;q=0.9中的Accept-Language。
# @type Name: String
# @param IgnoreNameCase: 是否忽略参数名称的大小写,默认值为 false。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IgnoreNameCase: Boolean
attr_accessor :Operator, :Target, :Values, :IgnoreCase, :Name, :IgnoreNameCase
extend Gem::Deprecate
deprecate :IgnoreNameCase, :none, 2024, 11
deprecate :IgnoreNameCase=, :none, 2024, 11
def initialize(operator=nil, target=nil, values=nil, ignorecase=nil, name=nil, ignorenamecase=nil)
@Operator = operator
@Target = target
@Values = values
@IgnoreCase = ignorecase
@Name = name
@IgnoreNameCase = ignorenamecase
end
def deserialize(params)
@Operator = params['Operator']
@Target = params['Target']
@Values = params['Values']
@IgnoreCase = params['IgnoreCase']
@Name = params['Name']
@IgnoreNameCase = params['IgnoreNameCase']
end
end
# 规则引擎参数详情信息,特殊参数类型。
class RuleExtraParameter < TencentCloud::Common::AbstractModel
# @param Id: 参数名,取值有:
# Action:修改 HTTP 头部所需参数,RuleAction 选择 RewirteAction;
# StatusCode:状态码相关功能所需参数,RuleAction 选择 CodeAction。
# @type Id: String
# @param Type: 参数值类型。
# CHOICE:参数值只能在 Values 中选择;
# CUSTOM_NUM:参数值用户自定义,整型类型;
# CUSTOM_STRING:参数值用户自定义,字符串类型。
# @type Type: String
# @param Choices: 可选参数值。
# 注意:当 Id 的值为 StatusCode 时数组中的值为整型,填写参数值时请填写字符串的整型数值。
# @type Choices: Array
attr_accessor :Id, :Type, :Choices
def initialize(id=nil, type=nil, choices=nil)
@Id = id
@Type = type
@Choices = choices
end
def deserialize(params)
@Id = params['Id']
@Type = params['Type']
@Choices = params['Choices']
end
end
# 规则引擎规则详情
class RuleItem < TencentCloud::Common::AbstractModel
# @param RuleId: 规则ID。
# @type RuleId: String
# @param RuleName: 规则名称,名称字符串长度 1~255。
# @type RuleName: String
# @param Status: 规则状态,取值有:
# enable: 启用;
# disable: 未启用。
# @type Status: String
# @param Rules: 规则内容。
# @type Rules: Array
# @param RulePriority: 规则优先级, 值越大优先级越高,最小为 1。
# @type RulePriority: Integer
# @param Tags: 规则标签。
# @type Tags: Array
attr_accessor :RuleId, :RuleName, :Status, :Rules, :RulePriority, :Tags
def initialize(ruleid=nil, rulename=nil, status=nil, rules=nil, rulepriority=nil, tags=nil)
@RuleId = ruleid
@RuleName = rulename
@Status = status
@Rules = rules
@RulePriority = rulepriority
@Tags = tags
end
def deserialize(params)
@RuleId = params['RuleId']
@RuleName = params['RuleName']
@Status = params['Status']
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
rule_tmp = Rule.new
rule_tmp.deserialize(i)
@Rules << rule_tmp
end
end
@RulePriority = params['RulePriority']
@Tags = params['Tags']
end
end
# 规则引擎条件常规动作参数
class RuleNormalActionParams < TencentCloud::Common::AbstractModel
# @param Name: 参数名称,参数填写规范可调用接口 [查询规则引擎的设置参数](https://cloud.tencent.com/document/product/1552/80618) 查看。
# @type Name: String
# @param Values: 参数值。
# @type Values: Array
attr_accessor :Name, :Values
def initialize(name=nil, values=nil)
@Name = name
@Values = values
end
def deserialize(params)
@Name = params['Name']
@Values = params['Values']
end
end
# 规则引擎条件 HTTP 请求/响应头操作动作参数。
class RuleRewriteActionParams < TencentCloud::Common::AbstractModel
# @param Action: 功能参数名称,参数填写规范可调用接口 [查询规则引擎的设置参数](https://cloud.tencent.com/document/product/1552/80618) 查看。现在只有三种取值:
# add:添加 HTTP 头部;
# set:重写 HTTP 头部;
# del:删除 HTTP 头部。
# @type Action: String
# @param Name: 参数名称。
# @type Name: String
# @param Values: 参数值。
# @type Values: Array
attr_accessor :Action, :Name, :Values
def initialize(action=nil, name=nil, values=nil)
@Action = action
@Name = name
@Values = values
end
def deserialize(params)
@Action = params['Action']
@Name = params['Name']
@Values = params['Values']
end
end
# 规则引擎可应用于匹配请求的设置详细信息。
class RulesProperties < TencentCloud::Common::AbstractModel
# @param Name: 值为参数名称。
# @type Name: String
# @param Min: 数值参数的最小值,非数值参数或 Min 和 Max 值都为 0 则此项无意义。
# @type Min: Integer
# @param ChoicesValue: 参数值的可选值。
# 注意:若参数值为用户自定义则该数组为空数组。
# @type ChoicesValue: Array
# @param Type: 参数值类型。
# CHOICE:参数值只能在 ChoicesValue 中选择;
# TOGGLE:参数值为开关类型,可在 ChoicesValue 中选择;
# OBJECT:参数值为对象类型,ChoiceProperties 为改对象类型关联的属性;
# CUSTOM_NUM:参数值用户自定义,整型类型;
# CUSTOM_STRING:参数值用户自定义,字符串类型。注意:当参数类型为 OBJECT 类型时,请注意参考 [示例2 参数为 OBJECT 类型的创建](https://cloud.tencent.com/document/product/1552/80622#.E7.A4.BA.E4.BE.8B2-.E5.8F.82.E6.95.B0.E4.B8.BA-OBJECT-.E7.B1.BB.E5.9E.8B.E7.9A.84.E5.88.9B.E5.BB.BA)
# @type Type: String
# @param Max: 数值参数的最大值,非数值参数或 Min 和 Max 值都为 0 则此项无意义。
# @type Max: Integer
# @param IsMultiple: 参数值是否支持多选或者填写多个。
# @type IsMultiple: Boolean
# @param IsAllowEmpty: 是否允许为空。
# @type IsAllowEmpty: Boolean
# @param ChoiceProperties: 该参数对应的关联配置参数,属于调用接口的必填参数。
# 注意:如果可选参数无特殊新增参数则该数组为空数组。
# @type ChoiceProperties: Array
# @param ExtraParameter: 为 NULL:无特殊参数,RuleAction 选择 NormalAction;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExtraParameter: :class:`Tencentcloud::Teo.v20220901.models.RuleExtraParameter`
attr_accessor :Name, :Min, :ChoicesValue, :Type, :Max, :IsMultiple, :IsAllowEmpty, :ChoiceProperties, :ExtraParameter
def initialize(name=nil, min=nil, choicesvalue=nil, type=nil, max=nil, ismultiple=nil, isallowempty=nil, choiceproperties=nil, extraparameter=nil)
@Name = name
@Min = min
@ChoicesValue = choicesvalue
@Type = type
@Max = max
@IsMultiple = ismultiple
@IsAllowEmpty = isallowempty
@ChoiceProperties = choiceproperties
@ExtraParameter = extraparameter
end
def deserialize(params)
@Name = params['Name']
@Min = params['Min']
@ChoicesValue = params['ChoicesValue']
@Type = params['Type']
@Max = params['Max']
@IsMultiple = params['IsMultiple']
@IsAllowEmpty = params['IsAllowEmpty']
unless params['ChoiceProperties'].nil?
@ChoiceProperties = []
params['ChoiceProperties'].each do |i|
rulechoicepropertiesitem_tmp = RuleChoicePropertiesItem.new
rulechoicepropertiesitem_tmp.deserialize(i)
@ChoiceProperties << rulechoicepropertiesitem_tmp
end
end
unless params['ExtraParameter'].nil?
@ExtraParameter = RuleExtraParameter.new
@ExtraParameter.deserialize(params['ExtraParameter'])
end
end
end
# 规则引擎可应用于匹配请求的设置列表及其详细信息
class RulesSettingAction < TencentCloud::Common::AbstractModel
# @param Action: 功能名称,取值有:
# 访问URL 重写(AccessUrlRedirect);
# 回源 URL 重写 (UpstreamUrlRedirect);
# 自定义错误页面
# (ErrorPage);
# QUIC(QUIC);
# WebSocket (WebSocket);
# 视频拖拽(VideoSeek);
# Token 鉴权(Authentication);
# 自定义CacheKey(CacheKey);
# 节点缓存 TTL (Cache);
# 浏览器缓存 TTL(MaxAge);
# 离线缓存(OfflineCache);
# 智能加速(SmartRouting);
# 分片回源(RangeOriginPull);
# HTTP/2 回源(UpstreamHttp2);
# Host Header 重写(HostHeader);
# 强制 HTTPS(ForceRedirect);
# 回源 HTTPS(OriginPullProtocol);
# 缓存预刷新(CachePrefresh);
# 智能压缩(Compression);
# 修改 HTTP 请求头(RequestHeader);
# 修改HTTP响应头(ResponseHeader);
# 状态码缓存 TTL(StatusCodeCache);
# Hsts;
# ClientIpHeader;
# TlsVersion;
# OcspStapling。
# @type Action: String
# @param Properties: 参数信息。
# @type Properties: Array
attr_accessor :Action, :Properties
def initialize(action=nil, properties=nil)
@Action = action
@Properties = properties
end
def deserialize(params)
@Action = params['Action']
unless params['Properties'].nil?
@Properties = []
params['Properties'].each do |i|
rulesproperties_tmp = RulesProperties.new
rulesproperties_tmp.deserialize(i)
@Properties << rulesproperties_tmp
end
end
end
end
# 实时日志投递到 AWS S3 兼容存储桶的配置信息。
class S3 < TencentCloud::Common::AbstractModel
# @param Endpoint: 不包含存储桶名称或路径的 URL,例如:`https://storage.googleapis.com`、`https://s3.ap-northeast-2.amazonaws.com`、`https://cos.ap-nanjing.myqcloud.com`。
# @type Endpoint: String
# @param Region: 存储桶所在的地域,例如:`ap-northeast-2`。
# @type Region: String
# @param Bucket: 存储桶名称和日志存储目录,例如:`your_bucket_name/EO-logs/`。如果存储桶中无此目录则会自动创建。
# @type Bucket: String
# @param AccessId: 访问存储桶使用的 Access Key ID。
# @type AccessId: String
# @param AccessKey: 访问存储桶使用的 secret key。
# @type AccessKey: String
# @param CompressType: 数据压缩类型,取值有: gzip:gzip压缩。不填表示不启用压缩。
# @type CompressType: String
attr_accessor :Endpoint, :Region, :Bucket, :AccessId, :AccessKey, :CompressType
def initialize(endpoint=nil, region=nil, bucket=nil, accessid=nil, accesskey=nil, compresstype=nil)
@Endpoint = endpoint
@Region = region
@Bucket = bucket
@AccessId = accessid
@AccessKey = accesskey
@CompressType = compresstype
end
def deserialize(params)
@Endpoint = params['Endpoint']
@Region = params['Region']
@Bucket = params['Bucket']
@AccessId = params['AccessId']
@AccessKey = params['AccessKey']
@CompressType = params['CompressType']
end
end
# 安全数据Entry返回值
class SecEntry < TencentCloud::Common::AbstractModel
# @param Key: 查询维度值。
# @type Key: String
# @param Value: 查询维度下详细数据。
# @type Value: Array
attr_accessor :Key, :Value
def initialize(key=nil, value=nil)
@Key = key
@Value = value
end
def deserialize(params)
@Key = params['Key']
unless params['Value'].nil?
@Value = []
params['Value'].each do |i|
secentryvalue_tmp = SecEntryValue.new
secentryvalue_tmp.deserialize(i)
@Value << secentryvalue_tmp
end
end
end
end
# 安全数据维度值信息
class SecEntryValue < TencentCloud::Common::AbstractModel
# @param Metric: 指标名称。
# @type Metric: String
# @param Detail: 时序数据详情。
# @type Detail: Array
# @param Max: 最大值。
# @type Max: Integer
# @param Avg: 平均值。
# @type Avg: Float
# @param Sum: 数据总和。
# @type Sum: Float
attr_accessor :Metric, :Detail, :Max, :Avg, :Sum
def initialize(metric=nil, detail=nil, max=nil, avg=nil, sum=nil)
@Metric = metric
@Detail = detail
@Max = max
@Avg = avg
@Sum = sum
end
def deserialize(params)
@Metric = params['Metric']
unless params['Detail'].nil?
@Detail = []
params['Detail'].each do |i|
timingdataitem_tmp = TimingDataItem.new
timingdataitem_tmp.deserialize(i)
@Detail << timingdataitem_tmp
end
end
@Max = params['Max']
@Avg = params['Avg']
@Sum = params['Sum']
end
end
# 安全配置
class SecurityConfig < TencentCloud::Common::AbstractModel
# @param WafConfig: 托管规则。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type WafConfig: :class:`Tencentcloud::Teo.v20220901.models.WafConfig`
# @param RateLimitConfig: 速率限制。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RateLimitConfig: :class:`Tencentcloud::Teo.v20220901.models.RateLimitConfig`
# @param AclConfig: 自定义规则。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AclConfig: :class:`Tencentcloud::Teo.v20220901.models.AclConfig`
# @param BotConfig: Bot配置。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BotConfig: :class:`Tencentcloud::Teo.v20220901.models.BotConfig`
# @param SwitchConfig: 七层防护总开关。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SwitchConfig: :class:`Tencentcloud::Teo.v20220901.models.SwitchConfig`
# @param IpTableConfig: 基础访问管控。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type IpTableConfig: :class:`Tencentcloud::Teo.v20220901.models.IpTableConfig`
# @param ExceptConfig: 例外规则配置。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExceptConfig: :class:`Tencentcloud::Teo.v20220901.models.ExceptConfig`
# @param DropPageConfig: 自定义拦截页面配置。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DropPageConfig: :class:`Tencentcloud::Teo.v20220901.models.DropPageConfig`
# @param TemplateConfig: 模板配置。此处仅出参数使用。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TemplateConfig: :class:`Tencentcloud::Teo.v20220901.models.TemplateConfig`
# @param SlowPostConfig: 慢速攻击配置。如果入参为空或不填,默认使用历史配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SlowPostConfig: :class:`Tencentcloud::Teo.v20220901.models.SlowPostConfig`
attr_accessor :WafConfig, :RateLimitConfig, :AclConfig, :BotConfig, :SwitchConfig, :IpTableConfig, :ExceptConfig, :DropPageConfig, :TemplateConfig, :SlowPostConfig
def initialize(wafconfig=nil, ratelimitconfig=nil, aclconfig=nil, botconfig=nil, switchconfig=nil, iptableconfig=nil, exceptconfig=nil, droppageconfig=nil, templateconfig=nil, slowpostconfig=nil)
@WafConfig = wafconfig
@RateLimitConfig = ratelimitconfig
@AclConfig = aclconfig
@BotConfig = botconfig
@SwitchConfig = switchconfig
@IpTableConfig = iptableconfig
@ExceptConfig = exceptconfig
@DropPageConfig = droppageconfig
@TemplateConfig = templateconfig
@SlowPostConfig = slowpostconfig
end
def deserialize(params)
unless params['WafConfig'].nil?
@WafConfig = WafConfig.new
@WafConfig.deserialize(params['WafConfig'])
end
unless params['RateLimitConfig'].nil?
@RateLimitConfig = RateLimitConfig.new
@RateLimitConfig.deserialize(params['RateLimitConfig'])
end
unless params['AclConfig'].nil?
@AclConfig = AclConfig.new
@AclConfig.deserialize(params['AclConfig'])
end
unless params['BotConfig'].nil?
@BotConfig = BotConfig.new
@BotConfig.deserialize(params['BotConfig'])
end
unless params['SwitchConfig'].nil?
@SwitchConfig = SwitchConfig.new
@SwitchConfig.deserialize(params['SwitchConfig'])
end
unless params['IpTableConfig'].nil?
@IpTableConfig = IpTableConfig.new
@IpTableConfig.deserialize(params['IpTableConfig'])
end
unless params['ExceptConfig'].nil?
@ExceptConfig = ExceptConfig.new
@ExceptConfig.deserialize(params['ExceptConfig'])
end
unless params['DropPageConfig'].nil?
@DropPageConfig = DropPageConfig.new
@DropPageConfig.deserialize(params['DropPageConfig'])
end
unless params['TemplateConfig'].nil?
@TemplateConfig = TemplateConfig.new
@TemplateConfig.deserialize(params['TemplateConfig'])
end
unless params['SlowPostConfig'].nil?
@SlowPostConfig = SlowPostConfig.new
@SlowPostConfig.deserialize(params['SlowPostConfig'])
end
end
end
# 安全策略模板的绑定关系。
class SecurityTemplateBinding < TencentCloud::Common::AbstractModel
# @param TemplateId: 模板ID
# @type TemplateId: String
# @param TemplateScope: 模板绑定状态。
# @type TemplateScope: Array
attr_accessor :TemplateId, :TemplateScope
def initialize(templateid=nil, templatescope=nil)
@TemplateId = templateid
@TemplateScope = templatescope
end
def deserialize(params)
@TemplateId = params['TemplateId']
unless params['TemplateScope'].nil?
@TemplateScope = []
params['TemplateScope'].each do |i|
templatescope_tmp = TemplateScope.new
templatescope_tmp.deserialize(i)
@TemplateScope << templatescope_tmp
end
end
end
end
# 安全类型配置项。
class SecurityType < TencentCloud::Common::AbstractModel
# @param Switch: 安全类型开关,取值为:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# https 服务端证书配置
class ServerCertInfo < TencentCloud::Common::AbstractModel
# @param CertId: 服务器证书 ID。来源于 SSL 侧,您可以前往 [SSL 证书列表](https://console.cloud.tencent.com/ssl) 查看 CertId。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CertId: String
# @param Alias: 证书备注名。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Alias: String
# @param Type: 证书类型,取值有:
# default:默认证书;
# upload:用户上传;
# managed:腾讯云托管。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param ExpireTime: 证书过期时间。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ExpireTime: String
# @param DeployTime: 证书部署时间。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DeployTime: String
# @param SignAlgo: 签名算法。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SignAlgo: String
# @param CommonName: 证书归属域名名称。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CommonName: String
attr_accessor :CertId, :Alias, :Type, :ExpireTime, :DeployTime, :SignAlgo, :CommonName
def initialize(certid=nil, _alias=nil, type=nil, expiretime=nil, deploytime=nil, signalgo=nil, commonname=nil)
@CertId = certid
@Alias = _alias
@Type = type
@ExpireTime = expiretime
@DeployTime = deploytime
@SignAlgo = signalgo
@CommonName = commonname
end
def deserialize(params)
@CertId = params['CertId']
@Alias = params['Alias']
@Type = params['Type']
@ExpireTime = params['ExpireTime']
@DeployTime = params['DeployTime']
@SignAlgo = params['SignAlgo']
@CommonName = params['CommonName']
end
end
# 例外规则的跳过匹配条件,即在例外时根据本匹配条件,略过指定字段及内容。
class SkipCondition < TencentCloud::Common::AbstractModel
# @param Type: 例外跳过类型,取值为:
# header_fields:HTTP请求Header;
# cookie:HTTP请求Cookie;
# query_string:HTTP请求URL中的Query参数;
# uri:HTTP请求URI;
# body_raw:HTTP请求Body;
# body_json: JSON格式的HTTP Body。
# @type Type: String
# @param Selector: 选择跳过的字段,取值为:
# args:uri 下选择 query 参数: ?name1=jack&age=12;
# path:uri 下选择部分路径:/path/to/resource.jpg;
# full:uri 下选择完整路径:example.com/path/to/resource.jpg?name1=jack&age=12;
# upload_filename:分段文件名,即分段传输文件时;
# keys:所有的Key;
# values:匹配Key对应的值;
# key_value:匹配Key及匹配Value。
# @type Selector: String
# @param MatchFromType: 匹配Key所使用的匹配方式,取值为:
# equal:精准匹配,等于;
# wildcard:通配符匹配,支持 * 通配。
# @type MatchFromType: String
# @param MatchFrom: 匹配Key的值。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MatchFrom: Array
# @param MatchContentType: 匹配Content所使用的匹配方式,取值为:
# equal:精准匹配,等于;
# wildcard:通配符匹配,支持 * 通配。
# @type MatchContentType: String
# @param MatchContent: 匹配Value的值。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MatchContent: Array
attr_accessor :Type, :Selector, :MatchFromType, :MatchFrom, :MatchContentType, :MatchContent
def initialize(type=nil, selector=nil, matchfromtype=nil, matchfrom=nil, matchcontenttype=nil, matchcontent=nil)
@Type = type
@Selector = selector
@MatchFromType = matchfromtype
@MatchFrom = matchfrom
@MatchContentType = matchcontenttype
@MatchContent = matchcontent
end
def deserialize(params)
@Type = params['Type']
@Selector = params['Selector']
@MatchFromType = params['MatchFromType']
@MatchFrom = params['MatchFrom']
@MatchContentType = params['MatchContentType']
@MatchContent = params['MatchContent']
end
end
# 慢速攻击配置。
class SlowPostConfig < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param FirstPartConfig: 首包配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FirstPartConfig: :class:`Tencentcloud::Teo.v20220901.models.FirstPartConfig`
# @param SlowRateConfig: 基础配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SlowRateConfig: :class:`Tencentcloud::Teo.v20220901.models.SlowRateConfig`
# @param Action: 慢速攻击的处置动作,取值有:
# monitor:观察;
# drop:拦截。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Action: String
# @param RuleId: 本规则的Id。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RuleId: Integer
attr_accessor :Switch, :FirstPartConfig, :SlowRateConfig, :Action, :RuleId
def initialize(switch=nil, firstpartconfig=nil, slowrateconfig=nil, action=nil, ruleid=nil)
@Switch = switch
@FirstPartConfig = firstpartconfig
@SlowRateConfig = slowrateconfig
@Action = action
@RuleId = ruleid
end
def deserialize(params)
@Switch = params['Switch']
unless params['FirstPartConfig'].nil?
@FirstPartConfig = FirstPartConfig.new
@FirstPartConfig.deserialize(params['FirstPartConfig'])
end
unless params['SlowRateConfig'].nil?
@SlowRateConfig = SlowRateConfig.new
@SlowRateConfig.deserialize(params['SlowRateConfig'])
end
@Action = params['Action']
@RuleId = params['RuleId']
end
end
# 慢速攻击的基础配置。
class SlowRateConfig < TencentCloud::Common::AbstractModel
# @param Switch: 开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param Interval: 统计的间隔,单位是秒,即在首段包传输结束后,将数据传输轴按照本参数切分,每个分片独立计算慢速攻击。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Interval: Integer
# @param Threshold: 统计时应用的速率阈值,单位是bps,即如果本分片中的传输速率没达到本参数的值,则判定为慢速攻击,应用慢速攻击的处置方式。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Threshold: Integer
attr_accessor :Switch, :Interval, :Threshold
def initialize(switch=nil, interval=nil, threshold=nil)
@Switch = switch
@Interval = interval
@Threshold = threshold
end
def deserialize(params)
@Switch = params['Switch']
@Interval = params['Interval']
@Threshold = params['Threshold']
end
end
# 智能加速配置
class SmartRouting < TencentCloud::Common::AbstractModel
# @param Switch: 智能加速配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 支持标准debug结构体
class StandardDebug < TencentCloud::Common::AbstractModel
# @param Switch: Debug 功能开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param AllowClientIPList: 允许的客户端来源。支持填写 IPv4 以及 IPv6 的 IP/IP 段。0.0.0.0/0 表示允许所有 IPv4 客户端进行调试,::/0 表示允许所有 IPv6 客户端进行调试。
# @type AllowClientIPList: Array
# @param ExpireTime: Debug 功能到期时间。超出设置的时间,则功能失效。
# @type ExpireTime: String
attr_accessor :Switch, :AllowClientIPList, :ExpireTime
def initialize(switch=nil, allowclientiplist=nil, expiretime=nil)
@Switch = switch
@AllowClientIPList = allowclientiplist
@ExpireTime = expiretime
end
def deserialize(params)
@Switch = params['Switch']
@AllowClientIPList = params['AllowClientIPList']
@ExpireTime = params['ExpireTime']
end
end
# 嵌套规则信息。
class SubRule < TencentCloud::Common::AbstractModel
# @param Conditions: 执行功能判断条件。
# 注意:满足该数组内任意一项条件,功能即可执行。
# @type Conditions: Array
# @param Actions: 执行的功能。
# @type Actions: Array
attr_accessor :Conditions, :Actions
def initialize(conditions=nil, actions=nil)
@Conditions = conditions
@Actions = actions
end
def deserialize(params)
unless params['Conditions'].nil?
@Conditions = []
params['Conditions'].each do |i|
ruleandconditions_tmp = RuleAndConditions.new
ruleandconditions_tmp.deserialize(i)
@Conditions << ruleandconditions_tmp
end
end
unless params['Actions'].nil?
@Actions = []
params['Actions'].each do |i|
action_tmp = Action.new
action_tmp.deserialize(i)
@Actions << action_tmp
end
end
end
end
# 规则引擎嵌套规则
class SubRuleItem < TencentCloud::Common::AbstractModel
# @param Rules: 嵌套规则信息。
# @type Rules: Array
# @param Tags: 规则标签。
# @type Tags: Array
attr_accessor :Rules, :Tags
def initialize(rules=nil, tags=nil)
@Rules = rules
@Tags = tags
end
def deserialize(params)
unless params['Rules'].nil?
@Rules = []
params['Rules'].each do |i|
subrule_tmp = SubRule.new
subrule_tmp.deserialize(i)
@Rules << subrule_tmp
end
end
@Tags = params['Tags']
end
end
# 询价参数
class Sv < TencentCloud::Common::AbstractModel
# @param Key: 询价参数键。
# @type Key: String
# @param Value: 询价参数值。
# @type Value: String
# @param Pack: 询价参数映射的配额,取值有:
# zone:站点数;
# custom-rule:自定义规则数;
# rate-limiting-rule:速率限制规则数;
# l4-proxy-instance:四层代理实例数。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Pack: String
# @param InstanceId: 询价参数映射的四层代理实例Id。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceId: String
# @param ProtectionSpecs: 询价参数对应的防护等级。
# 取值有: cm_30G:中国大陆加速区域保底防护30Gbps; cm_60G:中国大陆加速区域保底防护60Gbps; cm_100G:中国大陆加速区域保底防护100Gbps; anycast_300G:全球加速区域(除中国大陆)Anycast联防300Gbps; anycast_unlimited:全球加速区域(除中国大陆)Anycast无上限全力防护; cm_30G_anycast_300G:中国大陆加速区域保底防护30Gbps,全球加速区域(除中国大陆)Anycast联防300Gbps; cm_30G_anycast_unlimited:中国大陆加速区域保底防护30Gbps,全球加速区域(除中国大陆)Anycast无上限全力防护; cm_60G_anycast_300G:中国大陆加速区域保底防护60Gbps,全球加速区域(除中国大陆)Anycast联防300Gbps; cm_60G_anycast_unlimited:中国大陆加速区域保底防护60Gbps,全球加速区域(除中国大陆)Anycast无上限全力防护; cm_100G_anycast_300G:中国大陆加速区域保底防护100Gbps,全球加速区域(除中国大陆)Anycast联防300Gbps; cm_100G_anycast_unlimited:中国大陆加速区域保底防护100Gbps,全球加速区域(除中国大陆)Anycast无上限全力防护。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ProtectionSpecs: String
attr_accessor :Key, :Value, :Pack, :InstanceId, :ProtectionSpecs
def initialize(key=nil, value=nil, pack=nil, instanceid=nil, protectionspecs=nil)
@Key = key
@Value = value
@Pack = pack
@InstanceId = instanceid
@ProtectionSpecs = protectionspecs
end
def deserialize(params)
@Key = params['Key']
@Value = params['Value']
@Pack = params['Pack']
@InstanceId = params['InstanceId']
@ProtectionSpecs = params['ProtectionSpecs']
end
end
# 功能总开关
class SwitchConfig < TencentCloud::Common::AbstractModel
# @param WebSwitch: Web类型的安全总开关,取值有:
# on:开启;
# off:关闭。不影响DDoS与Bot的开关。
# @type WebSwitch: String
attr_accessor :WebSwitch
def initialize(webswitch=nil)
@WebSwitch = webswitch
end
def deserialize(params)
@WebSwitch = params['WebSwitch']
end
end
# 标签配置
class Tag < TencentCloud::Common::AbstractModel
# @param TagKey: 标签键。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TagKey: String
# @param TagValue: 标签值。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TagValue: String
attr_accessor :TagKey, :TagValue
def initialize(tagkey=nil, tagvalue=nil)
@TagKey = tagkey
@TagValue = tagvalue
end
def deserialize(params)
@TagKey = params['TagKey']
@TagValue = params['TagValue']
end
end
# 内容管理任务结果
class Task < TencentCloud::Common::AbstractModel
# @param JobId: 任务 ID。
# @type JobId: String
# @param Target: 资源。
# @type Target: String
# @param Type: 任务类型。
# @type Type: String
# @param Method: 节点缓存清除方法,取值有:
# invalidate:标记过期,用户请求时触发回源校验,即发送带有 If-None-Match 和 If-Modified-Since 头部的 HTTP 条件请求。若源站响应 200,则节点会回源拉取新的资源并更新缓存;若源站响应 304,则节点不会更新缓存;
# delete:直接删除节点缓存,用户请求时触发回源拉取资源。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Method: String
# @param Status: 状态。取值有:
# processing:处理中;
# success:成功;
# failed:失败;
# timeout:超时。
# @type Status: String
# @param CreateTime: 任务创建时间。
# @type CreateTime: String
# @param UpdateTime: 任务完成时间。
# @type UpdateTime: String
attr_accessor :JobId, :Target, :Type, :Method, :Status, :CreateTime, :UpdateTime
def initialize(jobid=nil, target=nil, type=nil, method=nil, status=nil, createtime=nil, updatetime=nil)
@JobId = jobid
@Target = target
@Type = type
@Method = method
@Status = status
@CreateTime = createtime
@UpdateTime = updatetime
end
def deserialize(params)
@JobId = params['JobId']
@Target = params['Target']
@Type = params['Type']
@Method = params['Method']
@Status = params['Status']
@CreateTime = params['CreateTime']
@UpdateTime = params['UpdateTime']
end
end
# 安全模板配置
class TemplateConfig < TencentCloud::Common::AbstractModel
# @param TemplateId: 模板ID。
# @type TemplateId: String
# @param TemplateName: 模板名称。
# @type TemplateName: String
attr_accessor :TemplateId, :TemplateName
def initialize(templateid=nil, templatename=nil)
@TemplateId = templateid
@TemplateName = templatename
end
def deserialize(params)
@TemplateId = params['TemplateId']
@TemplateName = params['TemplateName']
end
end
# 安全模板绑定域名状态
class TemplateScope < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点ID。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ZoneId: String
# @param EntityStatus: 实例状态列表。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EntityStatus: Array
attr_accessor :ZoneId, :EntityStatus
def initialize(zoneid=nil, entitystatus=nil)
@ZoneId = zoneid
@EntityStatus = entitystatus
end
def deserialize(params)
@ZoneId = params['ZoneId']
unless params['EntityStatus'].nil?
@EntityStatus = []
params['EntityStatus'].each do |i|
entitystatus_tmp = EntityStatus.new
entitystatus_tmp.deserialize(i)
@EntityStatus << entitystatus_tmp
end
end
end
end
# 统计曲线数据项
class TimingDataItem < TencentCloud::Common::AbstractModel
# @param Timestamp: 返回数据对应时间点,采用 unix 秒级时间戳。
# @type Timestamp: Integer
# @param Value: 具体数值。
# @type Value: Integer
attr_accessor :Timestamp, :Value
def initialize(timestamp=nil, value=nil)
@Timestamp = timestamp
@Value = value
end
def deserialize(params)
@Timestamp = params['Timestamp']
@Value = params['Value']
end
end
# 时序数据信息
class TimingDataRecord < TencentCloud::Common::AbstractModel
# @param TypeKey: 查询维度值。
# @type TypeKey: String
# @param TypeValue: 详细时序数据。
# @type TypeValue: Array
attr_accessor :TypeKey, :TypeValue
def initialize(typekey=nil, typevalue=nil)
@TypeKey = typekey
@TypeValue = typevalue
end
def deserialize(params)
@TypeKey = params['TypeKey']
unless params['TypeValue'].nil?
@TypeValue = []
params['TypeValue'].each do |i|
timingtypevalue_tmp = TimingTypeValue.new
timingtypevalue_tmp.deserialize(i)
@TypeValue << timingtypevalue_tmp
end
end
end
end
# 时序类型详细数据
class TimingTypeValue < TencentCloud::Common::AbstractModel
# @param Sum: 数据和。
# @type Sum: Integer
# @param Max: 最大值。
# @type Max: Integer
# @param Avg: 平均值。
# @type Avg: Integer
# @param MetricName: 指标名。
# @type MetricName: String
# @param Detail: 详细数据。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Detail: Array
attr_accessor :Sum, :Max, :Avg, :MetricName, :Detail
def initialize(sum=nil, max=nil, avg=nil, metricname=nil, detail=nil)
@Sum = sum
@Max = max
@Avg = avg
@MetricName = metricname
@Detail = detail
end
def deserialize(params)
@Sum = params['Sum']
@Max = params['Max']
@Avg = params['Avg']
@MetricName = params['MetricName']
unless params['Detail'].nil?
@Detail = []
params['Detail'].each do |i|
timingdataitem_tmp = TimingDataItem.new
timingdataitem_tmp.deserialize(i)
@Detail << timingdataitem_tmp
end
end
end
end
# Top类数据记录
class TopDataRecord < TencentCloud::Common::AbstractModel
# @param TypeKey: 查询维度值。
# @type TypeKey: String
# @param DetailData: top数据排行。
# @type DetailData: Array
attr_accessor :TypeKey, :DetailData
def initialize(typekey=nil, detaildata=nil)
@TypeKey = typekey
@DetailData = detaildata
end
def deserialize(params)
@TypeKey = params['TypeKey']
unless params['DetailData'].nil?
@DetailData = []
params['DetailData'].each do |i|
topdetaildata_tmp = TopDetailData.new
topdetaildata_tmp.deserialize(i)
@DetailData << topdetaildata_tmp
end
end
end
end
# Top数据的详细信息
class TopDetailData < TencentCloud::Common::AbstractModel
# @param Key: 字段名。
# @type Key: String
# @param Value: 字段值。
# @type Value: Integer
attr_accessor :Key, :Value
def initialize(key=nil, value=nil)
@Key = key
@Value = value
end
def deserialize(params)
@Key = params['Key']
@Value = params['Value']
end
end
# TopN的Entry数据
class TopEntry < TencentCloud::Common::AbstractModel
# @param Key: top查询维度值。
# @type Key: String
# @param Value: 查询具体数据。
# @type Value: Array
attr_accessor :Key, :Value
def initialize(key=nil, value=nil)
@Key = key
@Value = value
end
def deserialize(params)
@Key = params['Key']
unless params['Value'].nil?
@Value = []
params['Value'].each do |i|
topentryvalue_tmp = TopEntryValue.new
topentryvalue_tmp.deserialize(i)
@Value << topentryvalue_tmp
end
end
end
end
# TopN数据Entry
class TopEntryValue < TencentCloud::Common::AbstractModel
# @param Name: 排序实体名。
# @type Name: String
# @param Count: 排序实体数量。
# @type Count: Integer
attr_accessor :Name, :Count
def initialize(name=nil, count=nil)
@Name = name
@Count = count
end
def deserialize(params)
@Name = params['Name']
@Count = params['Count']
end
end
# UpgradePlan请求参数结构体
class UpgradePlanRequest < TencentCloud::Common::AbstractModel
# @param PlanId: 套餐 ID,形如 edgeone-2unuvzjmmn2q。
# @type PlanId: String
# @param PlanType: 需要升级到的目标套餐版本,取值有: basic:基础版套餐; standard:标准版套餐。
# @type PlanType: String
# @param AutoUseVoucher: 是否自动使用代金券,取值有: true:是; false:否。不填写使用默认值 false。
# @type AutoUseVoucher: String
attr_accessor :PlanId, :PlanType, :AutoUseVoucher
def initialize(planid=nil, plantype=nil, autousevoucher=nil)
@PlanId = planid
@PlanType = plantype
@AutoUseVoucher = autousevoucher
end
def deserialize(params)
@PlanId = params['PlanId']
@PlanType = params['PlanType']
@AutoUseVoucher = params['AutoUseVoucher']
end
end
# UpgradePlan返回参数结构体
class UpgradePlanResponse < TencentCloud::Common::AbstractModel
# @param DealName: 订单号。
# @type DealName: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :DealName, :RequestId
def initialize(dealname=nil, requestid=nil)
@DealName = dealname
@RequestId = requestid
end
def deserialize(params)
@DealName = params['DealName']
@RequestId = params['RequestId']
end
end
# 用于 EO 节点回源时携带的证书,源站启用双向认证握手时使用,用于源站认证客户端证书是否有效,确保请求来源于受信任的 EO 节点。
class UpstreamCertInfo < TencentCloud::Common::AbstractModel
# @param UpstreamMutualTLS: 在回源双向认证场景下,该字段为 EO 节点回源时携带的证书(包含公钥、私钥即可),部署在 EO 节点,用于源站对 EO 节点进行认证。在作为入参使用时,不填写表示保持原有配置。
# @type UpstreamMutualTLS: :class:`Tencentcloud::Teo.v20220901.models.MutualTLS`
attr_accessor :UpstreamMutualTLS
def initialize(upstreammutualtls=nil)
@UpstreamMutualTLS = upstreammutualtls
end
def deserialize(params)
unless params['UpstreamMutualTLS'].nil?
@UpstreamMutualTLS = MutualTLS.new
@UpstreamMutualTLS.deserialize(params['UpstreamMutualTLS'])
end
end
end
# Http2回源配置
class UpstreamHttp2 < TencentCloud::Common::AbstractModel
# @param Switch: http2 回源配置开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
attr_accessor :Switch
def initialize(switch=nil)
@Switch = switch
end
def deserialize(params)
@Switch = params['Switch']
end
end
# 自定义 nameservers
class VanityNameServers < TencentCloud::Common::AbstractModel
# @param Switch: 自定义 ns 开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param Servers: 自定义 ns 列表。
# @type Servers: Array
attr_accessor :Switch, :Servers
def initialize(switch=nil, servers=nil)
@Switch = switch
@Servers = servers
end
def deserialize(params)
@Switch = params['Switch']
@Servers = params['Servers']
end
end
# 自定义名字服务器 IP 信息
class VanityNameServersIps < TencentCloud::Common::AbstractModel
# @param Name: 自定义名字服务器名称。
# @type Name: String
# @param IPv4: 自定义名字服务器 IPv4 地址。
# @type IPv4: String
attr_accessor :Name, :IPv4
def initialize(name=nil, ipv4=nil)
@Name = name
@IPv4 = ipv4
end
def deserialize(params)
@Name = params['Name']
@IPv4 = params['IPv4']
end
end
# VerifyOwnership请求参数结构体
class VerifyOwnershipRequest < TencentCloud::Common::AbstractModel
# @param Domain: 站点或者加速域名。
# @type Domain: String
attr_accessor :Domain
def initialize(domain=nil)
@Domain = domain
end
def deserialize(params)
@Domain = params['Domain']
end
end
# VerifyOwnership返回参数结构体
class VerifyOwnershipResponse < TencentCloud::Common::AbstractModel
# @param Status: 归属权验证结果。
# success:验证成功;
# fail:验证失败。
# @type Status: String
# @param Result: 当验证结果为不通过时,该字段会返回原因,协助您排查问题。
# @type Result: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Status, :Result, :RequestId
def initialize(status=nil, result=nil, requestid=nil)
@Status = status
@Result = result
@RequestId = requestid
end
def deserialize(params)
@Status = params['Status']
@Result = params['Result']
@RequestId = params['RequestId']
end
end
# 无
class Waf < TencentCloud::Common::AbstractModel
# @param Switch: Waf开关,取值为:
# on:开启;
# off:关闭。
# @type Switch: String
# @param PolicyId: 策略ID。
# @type PolicyId: Integer
attr_accessor :Switch, :PolicyId
def initialize(switch=nil, policyid=nil)
@Switch = switch
@PolicyId = policyid
end
def deserialize(params)
@Switch = params['Switch']
@PolicyId = params['PolicyId']
end
end
# Waf配置。
class WafConfig < TencentCloud::Common::AbstractModel
# @param Switch: WafConfig开关,取值有:
# on:开启;
# off:关闭。开关仅与配置是否生效有关,即使为off(关闭),也可以正常修改配置的内容。
# @type Switch: String
# @param Level: 上一次设置的防护级别,取值有:
# loose:宽松;
# normal:正常;
# strict:严格;
# stricter:超严格;
# custom:自定义。
# @type Level: String
# @param Mode: 全局WAF模式,取值有:
# block:阻断(全局阻断,但可对详细规则配置观察);
# observe:观察(无论详细规则配置什么,都为观察)。
# @type Mode: String
# @param WafRule: 托管规则详细配置。如果为null,默认使用历史配置。
# @type WafRule: :class:`Tencentcloud::Teo.v20220901.models.WafRule`
# @param AiRule: AI规则引擎防护配置。如果为null,默认使用历史配置。
# @type AiRule: :class:`Tencentcloud::Teo.v20220901.models.AiRule`
attr_accessor :Switch, :Level, :Mode, :WafRule, :AiRule
def initialize(switch=nil, level=nil, mode=nil, wafrule=nil, airule=nil)
@Switch = switch
@Level = level
@Mode = mode
@WafRule = wafrule
@AiRule = airule
end
def deserialize(params)
@Switch = params['Switch']
@Level = params['Level']
@Mode = params['Mode']
unless params['WafRule'].nil?
@WafRule = WafRule.new
@WafRule.deserialize(params['WafRule'])
end
unless params['AiRule'].nil?
@AiRule = AiRule.new
@AiRule.deserialize(params['AiRule'])
end
end
end
# Waf规则
class WafRule < TencentCloud::Common::AbstractModel
# @param Switch: 托管规则开关,取值有:
# on:开启;
# off:关闭。
# @type Switch: String
# @param BlockRuleIDs: 黑名单ID列表,将规则ID加入本参数列表中代表该ID关闭,即该规则ID不再生效。
# @type BlockRuleIDs: Array
# @param ObserveRuleIDs: 观察模式ID列表,将规则ID加入本参数列表中代表该ID使用观察模式生效,即该规则ID进入观察模式。
# @type ObserveRuleIDs: Array
attr_accessor :Switch, :BlockRuleIDs, :ObserveRuleIDs
def initialize(switch=nil, blockruleids=nil, observeruleids=nil)
@Switch = switch
@BlockRuleIDs = blockruleids
@ObserveRuleIDs = observeruleids
end
def deserialize(params)
@Switch = params['Switch']
@BlockRuleIDs = params['BlockRuleIDs']
@ObserveRuleIDs = params['ObserveRuleIDs']
end
end
# WebSocket配置
class WebSocket < TencentCloud::Common::AbstractModel
# @param Switch: WebSocket 超时时间配置开关,取值有:
# on:使用Timeout作为WebSocket超时时间;
# off:平台仍支持WebSocket连接,此时使用系统默认的15秒为超时时间。
# @type Switch: String
# @param Timeout: 超时时间,单位为秒,最大超时时间120秒。
# @type Timeout: Integer
attr_accessor :Switch, :Timeout
def initialize(switch=nil, timeout=nil)
@Switch = switch
@Timeout = timeout
end
def deserialize(params)
@Switch = params['Switch']
@Timeout = params['Timeout']
end
end
# 站点信息
class Zone < TencentCloud::Common::AbstractModel
# @param ZoneId: 站点 ID。
# @type ZoneId: String
# @param ZoneName: 站点名称。
# @type ZoneName: String
# @param OriginalNameServers: 站点当前使用的 NS 列表。
# @type OriginalNameServers: Array
# @param NameServers: 腾讯云分配的 NS 列表。
# @type NameServers: Array
# @param Status: 站点状态,取值有:
# active:NS 已切换;
# pending:NS 未切换;
# moved:NS 已切走;
# deactivated:被封禁。
# initializing:待绑定套餐。
# @type Status: String
# @param Type: 站点接入方式,取值有:
# full:NS 接入;
# partial:CNAME 接入;
# noDomainAccess:无域名接入;
# @type Type: String
# @param Paused: 站点是否关闭。
# @type Paused: Boolean
# @param CnameSpeedUp: 是否开启 CNAME 加速,取值有:
# enabled:开启;
# disabled:关闭。
# @type CnameSpeedUp: String
# @param CnameStatus: CNAME 接入状态,取值有:
# finished:站点已验证;
# pending:站点验证中。
# @type CnameStatus: String
# @param Tags: 资源标签列表。
# @type Tags: Array
# @param Resources: 计费资源列表。
# @type Resources: Array
# @param CreatedOn: 站点创建时间。
# @type CreatedOn: String
# @param ModifiedOn: 站点修改时间。
# @type ModifiedOn: String
# @param Area: 站点接入地域,取值有:
# global:全球;
# mainland:中国大陆;
# overseas:境外区域。
# @type Area: String
# @param VanityNameServers: 用户自定义 NS 信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type VanityNameServers: :class:`Tencentcloud::Teo.v20220901.models.VanityNameServers`
# @param VanityNameServersIps: 用户自定义 NS IP 信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type VanityNameServersIps: Array
# @param ActiveStatus: 展示状态,取值有:
# active:已启用;
# inactive:未生效;
# paused:已停用。
# @type ActiveStatus: String
# @param AliasZoneName: 站点别名。数字、英文、-和_组合,限制20个字符。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AliasZoneName: String
# @param IsFake: 是否伪站点,取值有:
# 0:非伪站点;
# 1:伪站点。
# @type IsFake: Integer
# @param LockStatus: 锁定状态,取值有: enable:正常,允许进行修改操作; disable:锁定中,不允许进行修改操作; plan_migrate:套餐迁移中,不允许进行修改操作。
# @type LockStatus: String
# @param OwnershipVerification: 归属权验证信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OwnershipVerification: :class:`Tencentcloud::Teo.v20220901.models.OwnershipVerification`
attr_accessor :ZoneId, :ZoneName, :OriginalNameServers, :NameServers, :Status, :Type, :Paused, :CnameSpeedUp, :CnameStatus, :Tags, :Resources, :CreatedOn, :ModifiedOn, :Area, :VanityNameServers, :VanityNameServersIps, :ActiveStatus, :AliasZoneName, :IsFake, :LockStatus, :OwnershipVerification
def initialize(zoneid=nil, zonename=nil, originalnameservers=nil, nameservers=nil, status=nil, type=nil, paused=nil, cnamespeedup=nil, cnamestatus=nil, tags=nil, resources=nil, createdon=nil, modifiedon=nil, area=nil, vanitynameservers=nil, vanitynameserversips=nil, activestatus=nil, aliaszonename=nil, isfake=nil, lockstatus=nil, ownershipverification=nil)
@ZoneId = zoneid
@ZoneName = zonename
@OriginalNameServers = originalnameservers
@NameServers = nameservers
@Status = status
@Type = type
@Paused = paused
@CnameSpeedUp = cnamespeedup
@CnameStatus = cnamestatus
@Tags = tags
@Resources = resources
@CreatedOn = createdon
@ModifiedOn = modifiedon
@Area = area
@VanityNameServers = vanitynameservers
@VanityNameServersIps = vanitynameserversips
@ActiveStatus = activestatus
@AliasZoneName = aliaszonename
@IsFake = isfake
@LockStatus = lockstatus
@OwnershipVerification = ownershipverification
end
def deserialize(params)
@ZoneId = params['ZoneId']
@ZoneName = params['ZoneName']
@OriginalNameServers = params['OriginalNameServers']
@NameServers = params['NameServers']
@Status = params['Status']
@Type = params['Type']
@Paused = params['Paused']
@CnameSpeedUp = params['CnameSpeedUp']
@CnameStatus = params['CnameStatus']
unless params['Tags'].nil?
@Tags = []
params['Tags'].each do |i|
tag_tmp = Tag.new
tag_tmp.deserialize(i)
@Tags << tag_tmp
end
end
unless params['Resources'].nil?
@Resources = []
params['Resources'].each do |i|
resource_tmp = Resource.new
resource_tmp.deserialize(i)
@Resources << resource_tmp
end
end
@CreatedOn = params['CreatedOn']
@ModifiedOn = params['ModifiedOn']
@Area = params['Area']
unless params['VanityNameServers'].nil?
@VanityNameServers = VanityNameServers.new
@VanityNameServers.deserialize(params['VanityNameServers'])
end
unless params['VanityNameServersIps'].nil?
@VanityNameServersIps = []
params['VanityNameServersIps'].each do |i|
vanitynameserversips_tmp = VanityNameServersIps.new
vanitynameserversips_tmp.deserialize(i)
@VanityNameServersIps << vanitynameserversips_tmp
end
end
@ActiveStatus = params['ActiveStatus']
@AliasZoneName = params['AliasZoneName']
@IsFake = params['IsFake']
@LockStatus = params['LockStatus']
unless params['OwnershipVerification'].nil?
@OwnershipVerification = OwnershipVerification.new
@OwnershipVerification.deserialize(params['OwnershipVerification'])
end
end
end
# 站点配置。
class ZoneSetting < TencentCloud::Common::AbstractModel
# @param ZoneName: 站点名称。
# @type ZoneName: String
# @param Area: 站点加速区域信息,取值有:
# mainland:中国境内加速;
# overseas:中国境外加速。
# @type Area: String
# @param CacheKey: 节点缓存键配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CacheKey: :class:`Tencentcloud::Teo.v20220901.models.CacheKey`
# @param Quic: Quic访问配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Quic: :class:`Tencentcloud::Teo.v20220901.models.Quic`
# @param PostMaxSize: POST请求传输配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PostMaxSize: :class:`Tencentcloud::Teo.v20220901.models.PostMaxSize`
# @param Compression: 智能压缩配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Compression: :class:`Tencentcloud::Teo.v20220901.models.Compression`
# @param UpstreamHttp2: Http2回源配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpstreamHttp2: :class:`Tencentcloud::Teo.v20220901.models.UpstreamHttp2`
# @param ForceRedirect: 访问协议强制Https跳转配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ForceRedirect: :class:`Tencentcloud::Teo.v20220901.models.ForceRedirect`
# @param CacheConfig: 缓存过期时间配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CacheConfig: :class:`Tencentcloud::Teo.v20220901.models.CacheConfig`
# @param Origin: 源站配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Origin: :class:`Tencentcloud::Teo.v20220901.models.Origin`
# @param SmartRouting: 智能加速配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SmartRouting: :class:`Tencentcloud::Teo.v20220901.models.SmartRouting`
# @param MaxAge: 浏览器缓存配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MaxAge: :class:`Tencentcloud::Teo.v20220901.models.MaxAge`
# @param OfflineCache: 离线缓存配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OfflineCache: :class:`Tencentcloud::Teo.v20220901.models.OfflineCache`
# @param WebSocket: WebSocket配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type WebSocket: :class:`Tencentcloud::Teo.v20220901.models.WebSocket`
# @param ClientIpHeader: 客户端IP回源请求头配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClientIpHeader: :class:`Tencentcloud::Teo.v20220901.models.ClientIpHeader`
# @param CachePrefresh: 缓存预刷新配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CachePrefresh: :class:`Tencentcloud::Teo.v20220901.models.CachePrefresh`
# @param Ipv6: Ipv6访问配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Ipv6: :class:`Tencentcloud::Teo.v20220901.models.Ipv6`
# @param Https: Https 加速配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Https: :class:`Tencentcloud::Teo.v20220901.models.Https`
# @param ClientIpCountry: 回源时是否携带客户端IP所属地域信息的配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ClientIpCountry: :class:`Tencentcloud::Teo.v20220901.models.ClientIpCountry`
# @param Grpc: Grpc协议支持配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Grpc: :class:`Tencentcloud::Teo.v20220901.models.Grpc`
# @param ImageOptimize: 图片优化相关配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ImageOptimize: :class:`Tencentcloud::Teo.v20220901.models.ImageOptimize`
# @param AccelerateMainland: 中国大陆加速优化配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AccelerateMainland: :class:`Tencentcloud::Teo.v20220901.models.AccelerateMainland`
# @param StandardDebug: 标准 Debug 配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StandardDebug: :class:`Tencentcloud::Teo.v20220901.models.StandardDebug`
# @param JITVideoProcess: 视频即时处理配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type JITVideoProcess: :class:`Tencentcloud::Teo.v20220901.models.JITVideoProcess`
attr_accessor :ZoneName, :Area, :CacheKey, :Quic, :PostMaxSize, :Compression, :UpstreamHttp2, :ForceRedirect, :CacheConfig, :Origin, :SmartRouting, :MaxAge, :OfflineCache, :WebSocket, :ClientIpHeader, :CachePrefresh, :Ipv6, :Https, :ClientIpCountry, :Grpc, :ImageOptimize, :AccelerateMainland, :StandardDebug, :JITVideoProcess
def initialize(zonename=nil, area=nil, cachekey=nil, quic=nil, postmaxsize=nil, compression=nil, upstreamhttp2=nil, forceredirect=nil, cacheconfig=nil, origin=nil, smartrouting=nil, maxage=nil, offlinecache=nil, websocket=nil, clientipheader=nil, cacheprefresh=nil, ipv6=nil, https=nil, clientipcountry=nil, grpc=nil, imageoptimize=nil, acceleratemainland=nil, standarddebug=nil, jitvideoprocess=nil)
@ZoneName = zonename
@Area = area
@CacheKey = cachekey
@Quic = quic
@PostMaxSize = postmaxsize
@Compression = compression
@UpstreamHttp2 = upstreamhttp2
@ForceRedirect = forceredirect
@CacheConfig = cacheconfig
@Origin = origin
@SmartRouting = smartrouting
@MaxAge = maxage
@OfflineCache = offlinecache
@WebSocket = websocket
@ClientIpHeader = clientipheader
@CachePrefresh = cacheprefresh
@Ipv6 = ipv6
@Https = https
@ClientIpCountry = clientipcountry
@Grpc = grpc
@ImageOptimize = imageoptimize
@AccelerateMainland = acceleratemainland
@StandardDebug = standarddebug
@JITVideoProcess = jitvideoprocess
end
def deserialize(params)
@ZoneName = params['ZoneName']
@Area = params['Area']
unless params['CacheKey'].nil?
@CacheKey = CacheKey.new
@CacheKey.deserialize(params['CacheKey'])
end
unless params['Quic'].nil?
@Quic = Quic.new
@Quic.deserialize(params['Quic'])
end
unless params['PostMaxSize'].nil?
@PostMaxSize = PostMaxSize.new
@PostMaxSize.deserialize(params['PostMaxSize'])
end
unless params['Compression'].nil?
@Compression = Compression.new
@Compression.deserialize(params['Compression'])
end
unless params['UpstreamHttp2'].nil?
@UpstreamHttp2 = UpstreamHttp2.new
@UpstreamHttp2.deserialize(params['UpstreamHttp2'])
end
unless params['ForceRedirect'].nil?
@ForceRedirect = ForceRedirect.new
@ForceRedirect.deserialize(params['ForceRedirect'])
end
unless params['CacheConfig'].nil?
@CacheConfig = CacheConfig.new
@CacheConfig.deserialize(params['CacheConfig'])
end
unless params['Origin'].nil?
@Origin = Origin.new
@Origin.deserialize(params['Origin'])
end
unless params['SmartRouting'].nil?
@SmartRouting = SmartRouting.new
@SmartRouting.deserialize(params['SmartRouting'])
end
unless params['MaxAge'].nil?
@MaxAge = MaxAge.new
@MaxAge.deserialize(params['MaxAge'])
end
unless params['OfflineCache'].nil?
@OfflineCache = OfflineCache.new
@OfflineCache.deserialize(params['OfflineCache'])
end
unless params['WebSocket'].nil?
@WebSocket = WebSocket.new
@WebSocket.deserialize(params['WebSocket'])
end
unless params['ClientIpHeader'].nil?
@ClientIpHeader = ClientIpHeader.new
@ClientIpHeader.deserialize(params['ClientIpHeader'])
end
unless params['CachePrefresh'].nil?
@CachePrefresh = CachePrefresh.new
@CachePrefresh.deserialize(params['CachePrefresh'])
end
unless params['Ipv6'].nil?
@Ipv6 = Ipv6.new
@Ipv6.deserialize(params['Ipv6'])
end
unless params['Https'].nil?
@Https = Https.new
@Https.deserialize(params['Https'])
end
unless params['ClientIpCountry'].nil?
@ClientIpCountry = ClientIpCountry.new
@ClientIpCountry.deserialize(params['ClientIpCountry'])
end
unless params['Grpc'].nil?
@Grpc = Grpc.new
@Grpc.deserialize(params['Grpc'])
end
unless params['ImageOptimize'].nil?
@ImageOptimize = ImageOptimize.new
@ImageOptimize.deserialize(params['ImageOptimize'])
end
unless params['AccelerateMainland'].nil?
@AccelerateMainland = AccelerateMainland.new
@AccelerateMainland.deserialize(params['AccelerateMainland'])
end
unless params['StandardDebug'].nil?
@StandardDebug = StandardDebug.new
@StandardDebug.deserialize(params['StandardDebug'])
end
unless params['JITVideoProcess'].nil?
@JITVideoProcess = JITVideoProcess.new
@JITVideoProcess.deserialize(params['JITVideoProcess'])
end
end
end
end
end
end