# 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 Bsca
module V20210811
# 受漏洞影响的组件信息。
class AffectedComponent < TencentCloud::Common::AbstractModel
# @param Name: 受漏洞影响的组件名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param AffectedVersionList: 受漏洞影响的版本
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AffectedVersionList: Array
# @param FixedVersionList: 修复此漏洞的版本
# 注意:此字段可能返回 null,表示取不到有效值。
# @type FixedVersionList: Array
attr_accessor :Name, :AffectedVersionList, :FixedVersionList
def initialize(name=nil, affectedversionlist=nil, fixedversionlist=nil)
@Name = name
@AffectedVersionList = affectedversionlist
@FixedVersionList = fixedversionlist
end
def deserialize(params)
@Name = params['Name']
@AffectedVersionList = params['AffectedVersionList']
@FixedVersionList = params['FixedVersionList']
end
end
# CVSSv2.0详细信息。
class CVSSV2Info < TencentCloud::Common::AbstractModel
# @param CVSS: CVE评分。
# @type CVSS: Float
# @param AccessVector: AccessVector 攻击途径。
# 取值范围:
#
NETWORK 远程
# ADJACENT_NETWORK 近邻
# LOCAL 本地
# @type AccessVector: String
# @param AccessComplexity: AccessComplexity 攻击复杂度。
# 取值范围:
# HIGH 高
# MEDIUM 中
# LOW 低
# @type AccessComplexity: String
# @param Authentication: Authentication 身份验证。
# 取值范围:
# MULTIPLE 多系统认证
# SINGLE 单系统认证
# NONE 无
# @type Authentication: String
# @param ConImpact: ConfidentialityImpact 机密性影响。
# 取值范围:
# NONE 无
# PARTIAL 部分
# COMPLETE 完整
# @type ConImpact: String
# @param IntegrityImpact: IntegrityImpact 完整性影响。
# 取值范围:
# NONE 无
# PARTIAL 部分
# COMPLETE 完整
# @type IntegrityImpact: String
# @param AvailabilityImpact: AvailabilityImpact 可用性影响。
# 取值范围:
# NONE 无
# PARTIAL 部分
# COMPLETE 完整
# @type AvailabilityImpact: String
attr_accessor :CVSS, :AccessVector, :AccessComplexity, :Authentication, :ConImpact, :IntegrityImpact, :AvailabilityImpact
def initialize(cvss=nil, accessvector=nil, accesscomplexity=nil, authentication=nil, conimpact=nil, integrityimpact=nil, availabilityimpact=nil)
@CVSS = cvss
@AccessVector = accessvector
@AccessComplexity = accesscomplexity
@Authentication = authentication
@ConImpact = conimpact
@IntegrityImpact = integrityimpact
@AvailabilityImpact = availabilityimpact
end
def deserialize(params)
@CVSS = params['CVSS']
@AccessVector = params['AccessVector']
@AccessComplexity = params['AccessComplexity']
@Authentication = params['Authentication']
@ConImpact = params['ConImpact']
@IntegrityImpact = params['IntegrityImpact']
@AvailabilityImpact = params['AvailabilityImpact']
end
end
# Cvssv3.0详细信息。
class CVSSV3Info < TencentCloud::Common::AbstractModel
# @param CVSS: CVE评分。
# @type CVSS: Float
# @param AttackVector: AttackVector 攻击途径。
# 取值范围:
# NETWORK 远程
# ADJACENT_NETWORK 近邻
# LOCAL 本地
# PHYSICAL 物理
# @type AttackVector: String
# @param AttackComplexity: AttackComplexity 攻击复杂度。
# 取值范围:
# HIGH 高
# LOW 低
# @type AttackComplexity: String
# @param PrivilegesRequired: PrivilegesRequired 触发特权。
# 取值范围:
# HIGH 高
# LOW 低
# NONE 无
# @type PrivilegesRequired: String
# @param UserInteraction: UserInteraction 交互必要性。
# 取值范围:
# NONE 无
# REQUIRED 需要
# @type UserInteraction: String
# @param Scope: Scope 绕过安全边界。
# 取值范围:
# UNCHANGED 否
# CHANGED 能
# @type Scope: String
# @param ConImpact: ConfidentialityImpact 机密性影响。
# 取值范围:
# NONE 无
# LOW 低
# HIGH 高
# @type ConImpact: String
# @param IntegrityImpact: IntegrityImpact 完整性影响。
# 取值范围:
# NONE 无
# LOW 低
# HIGH 高
# @type IntegrityImpact: String
# @param AvailabilityImpact: AvailabilityImpact 可用性影响。
# 取值范围:
# NONE 无
# LOW 低
# HIGH 高
# @type AvailabilityImpact: String
attr_accessor :CVSS, :AttackVector, :AttackComplexity, :PrivilegesRequired, :UserInteraction, :Scope, :ConImpact, :IntegrityImpact, :AvailabilityImpact
def initialize(cvss=nil, attackvector=nil, attackcomplexity=nil, privilegesrequired=nil, userinteraction=nil, scope=nil, conimpact=nil, integrityimpact=nil, availabilityimpact=nil)
@CVSS = cvss
@AttackVector = attackvector
@AttackComplexity = attackcomplexity
@PrivilegesRequired = privilegesrequired
@UserInteraction = userinteraction
@Scope = scope
@ConImpact = conimpact
@IntegrityImpact = integrityimpact
@AvailabilityImpact = availabilityimpact
end
def deserialize(params)
@CVSS = params['CVSS']
@AttackVector = params['AttackVector']
@AttackComplexity = params['AttackComplexity']
@PrivilegesRequired = params['PrivilegesRequired']
@UserInteraction = params['UserInteraction']
@Scope = params['Scope']
@ConImpact = params['ConImpact']
@IntegrityImpact = params['IntegrityImpact']
@AvailabilityImpact = params['AvailabilityImpact']
end
end
# 描述一个第三方组件的源信息。
class Component < TencentCloud::Common::AbstractModel
# @param PURL: 第三方组件的PURL
# @type PURL: :class:`Tencentcloud::Bsca.v20210811.models.PURL`
# @param Homepage: 第三方组件的主页
# @type Homepage: String
# @param Summary: 第三方组件的简介
# @type Summary: String
# @param NicknameList: 第三方组件的别名列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NicknameList: Array
# @param CodeLocationList: 第三方组件的代码位置列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CodeLocationList: Array
# @param LicenseExpression: 第三方组件的许可证表达式
# @type LicenseExpression: String
attr_accessor :PURL, :Homepage, :Summary, :NicknameList, :CodeLocationList, :LicenseExpression
def initialize(purl=nil, homepage=nil, summary=nil, nicknamelist=nil, codelocationlist=nil, licenseexpression=nil)
@PURL = purl
@Homepage = homepage
@Summary = summary
@NicknameList = nicknamelist
@CodeLocationList = codelocationlist
@LicenseExpression = licenseexpression
end
def deserialize(params)
unless params['PURL'].nil?
@PURL = PURL.new
@PURL.deserialize(params['PURL'])
end
@Homepage = params['Homepage']
@Summary = params['Summary']
@NicknameList = params['NicknameList']
@CodeLocationList = params['CodeLocationList']
@LicenseExpression = params['LicenseExpression']
end
end
# 描述组件的一条版本信息。
class ComponentVersion < TencentCloud::Common::AbstractModel
# @param PURL: 该组件的PURL
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PURL: :class:`Tencentcloud::Bsca.v20210811.models.PURL`
# @param LicenseExpression: 该组件版本的许可证表达式
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LicenseExpression: String
attr_accessor :PURL, :LicenseExpression
def initialize(purl=nil, licenseexpression=nil)
@PURL = purl
@LicenseExpression = licenseexpression
end
def deserialize(params)
unless params['PURL'].nil?
@PURL = PURL.new
@PURL.deserialize(params['PURL'])
end
@LicenseExpression = params['LicenseExpression']
end
end
# 与输入组件相关的漏洞信息摘要信息。
class ComponentVulnerabilitySummary < TencentCloud::Common::AbstractModel
# @param PURL: 用于匹配漏洞的PURL
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PURL: :class:`Tencentcloud::Bsca.v20210811.models.PURL`
# @param CanBeFixed: 该组件是否包含修复漏洞的官方补丁
# @type CanBeFixed: Boolean
# @param FixedVersion: 修复漏洞的组件版本号
# @type FixedVersion: String
# @param AffectedVersion: 漏洞影响的组件版本号
# @type AffectedVersion: String
# @param AffectedComponent: 漏洞影响组件
# @type AffectedComponent: String
# @param RiskLevel: 漏洞在该产品中的风险等级
# Critical
# High
# Medium
# Low
# @type RiskLevel: String
attr_accessor :PURL, :CanBeFixed, :FixedVersion, :AffectedVersion, :AffectedComponent, :RiskLevel
def initialize(purl=nil, canbefixed=nil, fixedversion=nil, affectedversion=nil, affectedcomponent=nil, risklevel=nil)
@PURL = purl
@CanBeFixed = canbefixed
@FixedVersion = fixedversion
@AffectedVersion = affectedversion
@AffectedComponent = affectedcomponent
@RiskLevel = risklevel
end
def deserialize(params)
unless params['PURL'].nil?
@PURL = PURL.new
@PURL.deserialize(params['PURL'])
end
@CanBeFixed = params['CanBeFixed']
@FixedVersion = params['FixedVersion']
@AffectedVersion = params['AffectedVersion']
@AffectedComponent = params['AffectedComponent']
@RiskLevel = params['RiskLevel']
end
end
# 描述组件漏洞相关概览信息。
class ComponentVulnerabilityUnion < TencentCloud::Common::AbstractModel
# @param Summary: 漏洞概览信息
# @type Summary: :class:`Tencentcloud::Bsca.v20210811.models.VulnerabilitySummary`
# @param SummaryInComponent: 与组件相关的漏洞概览信息
# @type SummaryInComponent: :class:`Tencentcloud::Bsca.v20210811.models.ComponentVulnerabilitySummary`
attr_accessor :Summary, :SummaryInComponent
def initialize(summary=nil, summaryincomponent=nil)
@Summary = summary
@SummaryInComponent = summaryincomponent
end
def deserialize(params)
unless params['Summary'].nil?
@Summary = VulnerabilitySummary.new
@Summary.deserialize(params['Summary'])
end
unless params['SummaryInComponent'].nil?
@SummaryInComponent = ComponentVulnerabilitySummary.new
@SummaryInComponent.deserialize(params['SummaryInComponent'])
end
end
end
# DescribeKBComponent请求参数结构体
class DescribeKBComponentRequest < TencentCloud::Common::AbstractModel
# @param PURL: 组件的PURL
# @type PURL: :class:`Tencentcloud::Bsca.v20210811.models.PURL`
attr_accessor :PURL
def initialize(purl=nil)
@PURL = purl
end
def deserialize(params)
unless params['PURL'].nil?
@PURL = PURL.new
@PURL.deserialize(params['PURL'])
end
end
end
# DescribeKBComponent返回参数结构体
class DescribeKBComponentResponse < TencentCloud::Common::AbstractModel
# @param Component: 匹配的组件信息
# @type Component: :class:`Tencentcloud::Bsca.v20210811.models.Component`
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Component, :RequestId
def initialize(component=nil, requestid=nil)
@Component = component
@RequestId = requestid
end
def deserialize(params)
unless params['Component'].nil?
@Component = Component.new
@Component.deserialize(params['Component'])
end
@RequestId = params['RequestId']
end
end
# DescribeKBComponentVersionList请求参数结构体
class DescribeKBComponentVersionListRequest < TencentCloud::Common::AbstractModel
# @param PURL: 要查询的组件 PURL
# @type PURL: :class:`Tencentcloud::Bsca.v20210811.models.PURL`
attr_accessor :PURL
def initialize(purl=nil)
@PURL = purl
end
def deserialize(params)
unless params['PURL'].nil?
@PURL = PURL.new
@PURL.deserialize(params['PURL'])
end
end
end
# DescribeKBComponentVersionList返回参数结构体
class DescribeKBComponentVersionListResponse < TencentCloud::Common::AbstractModel
# @param VersionList: 该组件的版本列表信息
# @type VersionList: Array
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :VersionList, :RequestId
def initialize(versionlist=nil, requestid=nil)
@VersionList = versionlist
@RequestId = requestid
end
def deserialize(params)
unless params['VersionList'].nil?
@VersionList = []
params['VersionList'].each do |i|
componentversion_tmp = ComponentVersion.new
componentversion_tmp.deserialize(i)
@VersionList << componentversion_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeKBComponentVulnerability请求参数结构体
class DescribeKBComponentVulnerabilityRequest < TencentCloud::Common::AbstractModel
# @param PURL: 组件的PURL,其中Name和Version为必填字段
# @type PURL: :class:`Tencentcloud::Bsca.v20210811.models.PURL`
attr_accessor :PURL
def initialize(purl=nil)
@PURL = purl
end
def deserialize(params)
unless params['PURL'].nil?
@PURL = PURL.new
@PURL.deserialize(params['PURL'])
end
end
end
# DescribeKBComponentVulnerability返回参数结构体
class DescribeKBComponentVulnerabilityResponse < TencentCloud::Common::AbstractModel
# @param VulnerabilityList: 漏洞信息列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type VulnerabilityList: Array
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :VulnerabilityList, :RequestId
def initialize(vulnerabilitylist=nil, requestid=nil)
@VulnerabilityList = vulnerabilitylist
@RequestId = requestid
end
def deserialize(params)
unless params['VulnerabilityList'].nil?
@VulnerabilityList = []
params['VulnerabilityList'].each do |i|
componentvulnerabilityunion_tmp = ComponentVulnerabilityUnion.new
componentvulnerabilityunion_tmp.deserialize(i)
@VulnerabilityList << componentvulnerabilityunion_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeKBLicense请求参数结构体
class DescribeKBLicenseRequest < TencentCloud::Common::AbstractModel
# @param LicenseExpression: License表达式
# @type LicenseExpression: String
attr_accessor :LicenseExpression
def initialize(licenseexpression=nil)
@LicenseExpression = licenseexpression
end
def deserialize(params)
@LicenseExpression = params['LicenseExpression']
end
end
# DescribeKBLicense返回参数结构体
class DescribeKBLicenseResponse < TencentCloud::Common::AbstractModel
# @param LicenseList: 许可证列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LicenseList: Array
# @param NormalizedLicenseExpression: 用于匹配的License表达式
# @type NormalizedLicenseExpression: String
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :LicenseList, :NormalizedLicenseExpression, :RequestId
def initialize(licenselist=nil, normalizedlicenseexpression=nil, requestid=nil)
@LicenseList = licenselist
@NormalizedLicenseExpression = normalizedlicenseexpression
@RequestId = requestid
end
def deserialize(params)
unless params['LicenseList'].nil?
@LicenseList = []
params['LicenseList'].each do |i|
licenseunion_tmp = LicenseUnion.new
licenseunion_tmp.deserialize(i)
@LicenseList << licenseunion_tmp
end
end
@NormalizedLicenseExpression = params['NormalizedLicenseExpression']
@RequestId = params['RequestId']
end
end
# DescribeKBVulnerability请求参数结构体
class DescribeKBVulnerabilityRequest < TencentCloud::Common::AbstractModel
# @param CVEID: 根据CVE ID查询(不能与其他参数同时存在)
# @type CVEID: Array
# @param VulID: 根据Vul ID查询(不能与其他参数同时存在)
# @type VulID: Array
# @param CNVDID: 根据CNVD ID查询(不能与其他参数同时存在)
# @type CNVDID: Array
# @param CNNVDID: 根据CNNVD ID查询(不能与其他参数同时存在)
# @type CNNVDID: Array
attr_accessor :CVEID, :VulID, :CNVDID, :CNNVDID
def initialize(cveid=nil, vulid=nil, cnvdid=nil, cnnvdid=nil)
@CVEID = cveid
@VulID = vulid
@CNVDID = cnvdid
@CNNVDID = cnnvdid
end
def deserialize(params)
@CVEID = params['CVEID']
@VulID = params['VulID']
@CNVDID = params['CNVDID']
@CNNVDID = params['CNNVDID']
end
end
# DescribeKBVulnerability返回参数结构体
class DescribeKBVulnerabilityResponse < TencentCloud::Common::AbstractModel
# @param VulnerabilityDetailList: 漏洞详细信息列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type VulnerabilityDetailList: Array
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :VulnerabilityDetailList, :RequestId
def initialize(vulnerabilitydetaillist=nil, requestid=nil)
@VulnerabilityDetailList = vulnerabilitydetaillist
@RequestId = requestid
end
def deserialize(params)
unless params['VulnerabilityDetailList'].nil?
@VulnerabilityDetailList = []
params['VulnerabilityDetailList'].each do |i|
vulnerabilityunion_tmp = VulnerabilityUnion.new
vulnerabilityunion_tmp.deserialize(i)
@VulnerabilityDetailList << vulnerabilityunion_tmp
end
end
@RequestId = params['RequestId']
end
end
# 描述许可证的详细信息。
class LicenseDetail < TencentCloud::Common::AbstractModel
# @param Content: 许可证内容
# @type Content: String
# @param ConditionSet: 许可证允许信息列表
# @type ConditionSet: Array
# @param ForbiddenSet: 许可证要求信息列表
# @type ForbiddenSet: Array
# @param PermissionSet: 许可证禁止信息列表
# @type PermissionSet: Array
attr_accessor :Content, :ConditionSet, :ForbiddenSet, :PermissionSet
def initialize(content=nil, conditionset=nil, forbiddenset=nil, permissionset=nil)
@Content = content
@ConditionSet = conditionset
@ForbiddenSet = forbiddenset
@PermissionSet = permissionset
end
def deserialize(params)
@Content = params['Content']
unless params['ConditionSet'].nil?
@ConditionSet = []
params['ConditionSet'].each do |i|
licenserestriction_tmp = LicenseRestriction.new
licenserestriction_tmp.deserialize(i)
@ConditionSet << licenserestriction_tmp
end
end
unless params['ForbiddenSet'].nil?
@ForbiddenSet = []
params['ForbiddenSet'].each do |i|
licenserestriction_tmp = LicenseRestriction.new
licenserestriction_tmp.deserialize(i)
@ForbiddenSet << licenserestriction_tmp
end
end
unless params['PermissionSet'].nil?
@PermissionSet = []
params['PermissionSet'].each do |i|
licenserestriction_tmp = LicenseRestriction.new
licenserestriction_tmp.deserialize(i)
@PermissionSet << licenserestriction_tmp
end
end
end
end
# License约束信息。
class LicenseRestriction < TencentCloud::Common::AbstractModel
# @param Name: license约束的名称。
# @type Name: String
# @param Description: license约束的描述。
# @type Description: String
attr_accessor :Name, :Description
def initialize(name=nil, description=nil)
@Name = name
@Description = description
end
def deserialize(params)
@Name = params['Name']
@Description = params['Description']
end
end
# 描述许可证的概览信息。
class LicenseSummary < TencentCloud::Common::AbstractModel
# @param Key: 许可证标识符
# @type Key: String
# @param SPDXKey: 许可证的SPDX标识符,见 https://spdx.org/licenses/
# @type SPDXKey: String
# @param ShortName: 许可证短名称
# @type ShortName: String
# @param Name: 许可证完整名称
# @type Name: String
# @param Risk: License风险等级
# NotDefined
# LowRisk
# MediumRisk
# HighRisk
# @type Risk: String
# @param Source: 许可证来源URL
# @type Source: String
attr_accessor :Key, :SPDXKey, :ShortName, :Name, :Risk, :Source
def initialize(key=nil, spdxkey=nil, shortname=nil, name=nil, risk=nil, source=nil)
@Key = key
@SPDXKey = spdxkey
@ShortName = shortname
@Name = name
@Risk = risk
@Source = source
end
def deserialize(params)
@Key = params['Key']
@SPDXKey = params['SPDXKey']
@ShortName = params['ShortName']
@Name = params['Name']
@Risk = params['Risk']
@Source = params['Source']
end
end
# 许可证详细信息。
class LicenseUnion < TencentCloud::Common::AbstractModel
# @param LicenseSummary: 许可证概览信息
# @type LicenseSummary: :class:`Tencentcloud::Bsca.v20210811.models.LicenseSummary`
# @param LicenseDetail: 许可证详细信息
# @type LicenseDetail: :class:`Tencentcloud::Bsca.v20210811.models.LicenseDetail`
attr_accessor :LicenseSummary, :LicenseDetail
def initialize(licensesummary=nil, licensedetail=nil)
@LicenseSummary = licensesummary
@LicenseDetail = licensedetail
end
def deserialize(params)
unless params['LicenseSummary'].nil?
@LicenseSummary = LicenseSummary.new
@LicenseSummary.deserialize(params['LicenseSummary'])
end
unless params['LicenseDetail'].nil?
@LicenseDetail = LicenseDetail.new
@LicenseDetail.deserialize(params['LicenseDetail'])
end
end
end
# MatchKBPURLList请求参数结构体
class MatchKBPURLListRequest < TencentCloud::Common::AbstractModel
# @param SHA1: SHA1。
# @type SHA1: String
attr_accessor :SHA1
def initialize(sha1=nil)
@SHA1 = sha1
end
def deserialize(params)
@SHA1 = params['SHA1']
end
end
# MatchKBPURLList返回参数结构体
class MatchKBPURLListResponse < TencentCloud::Common::AbstractModel
# @param PURLList: 组件列表。
# @type PURLList: Array
# @param Hit: 是否命中数据库。
# @type Hit: Boolean
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PURLList, :Hit, :RequestId
def initialize(purllist=nil, hit=nil, requestid=nil)
@PURLList = purllist
@Hit = hit
@RequestId = requestid
end
def deserialize(params)
unless params['PURLList'].nil?
@PURLList = []
params['PURLList'].each do |i|
purl_tmp = PURL.new
purl_tmp.deserialize(i)
@PURLList << purl_tmp
end
end
@Hit = params['Hit']
@RequestId = params['RequestId']
end
end
# PURL(Package URL)用于定位一个产品或组件,见 https://github.com/package-url/purl-spec。
class PURL < TencentCloud::Common::AbstractModel
# @param Name: 组件名称
# @type Name: String
# @param Protocol: 组件所属的类型,如:github, gitlab, generic, deb, rpm, maven 等
# @type Protocol: String
# @param Namespace: 组件名的前缀名,如github和gitlab的用户名,deb的操作系统,maven包的group id等
# @type Namespace: String
# @param Qualifiers: 修饰组件的额外属性
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Qualifiers: Array
# @param Subpath: 相对于组件包根位置的子目录
# @type Subpath: String
# @param Version: 组件版本号
# @type Version: String
attr_accessor :Name, :Protocol, :Namespace, :Qualifiers, :Subpath, :Version
def initialize(name=nil, protocol=nil, namespace=nil, qualifiers=nil, subpath=nil, version=nil)
@Name = name
@Protocol = protocol
@Namespace = namespace
@Qualifiers = qualifiers
@Subpath = subpath
@Version = version
end
def deserialize(params)
@Name = params['Name']
@Protocol = params['Protocol']
@Namespace = params['Namespace']
unless params['Qualifiers'].nil?
@Qualifiers = []
params['Qualifiers'].each do |i|
qualifier_tmp = Qualifier.new
qualifier_tmp.deserialize(i)
@Qualifiers << qualifier_tmp
end
end
@Subpath = params['Subpath']
@Version = params['Version']
end
end
# PURL下的Qualifier属性类型,用于定义第三方组件的额外属性,见 https://github.com/package-url/purl-spec。
class Qualifier < TencentCloud::Common::AbstractModel
# @param Key: 额外属性的名称。
# @type Key: String
# @param Value: 额外属性的值。
# @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
# SearchKBComponent请求参数结构体
class SearchKBComponentRequest < TencentCloud::Common::AbstractModel
# @param Query: 需要搜索的组件名
# @type Query: String
# @param Protocol: 需要搜索的组件类型
# @type Protocol: String
# @param PageNumber: 分页参数,从 0 开始
# @type PageNumber: Integer
# @param PageSize: 分页参数,设置每页返回的结果数量
# @type PageSize: Integer
attr_accessor :Query, :Protocol, :PageNumber, :PageSize
def initialize(query=nil, protocol=nil, pagenumber=nil, pagesize=nil)
@Query = query
@Protocol = protocol
@PageNumber = pagenumber
@PageSize = pagesize
end
def deserialize(params)
@Query = params['Query']
@Protocol = params['Protocol']
@PageNumber = params['PageNumber']
@PageSize = params['PageSize']
end
end
# SearchKBComponent返回参数结构体
class SearchKBComponentResponse < TencentCloud::Common::AbstractModel
# @param ComponentList: 满足搜索条件的组件列表
# @type ComponentList: Array
# @param Total: 满足搜索条件的总个数
# @type Total: Integer
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :ComponentList, :Total, :RequestId
def initialize(componentlist=nil, total=nil, requestid=nil)
@ComponentList = componentlist
@Total = total
@RequestId = requestid
end
def deserialize(params)
unless params['ComponentList'].nil?
@ComponentList = []
params['ComponentList'].each do |i|
component_tmp = Component.new
component_tmp.deserialize(i)
@ComponentList << component_tmp
end
end
@Total = params['Total']
@RequestId = params['RequestId']
end
end
# 描述漏洞详细信息。
class VulnerabilityDetail < TencentCloud::Common::AbstractModel
# @param Category: 漏洞类别
# @type Category: String
# @param CategoryType: 漏洞分类
# @type CategoryType: String
# @param Description: 漏洞描述
# @type Description: String
# @param OfficialSolution: 漏洞官方解决方案
# @type OfficialSolution: String
# @param ReferenceList: 漏洞信息参考列表
# @type ReferenceList: Array
# @param DefenseSolution: 漏洞防御方案
# @type DefenseSolution: String
# @param CVSSv2Info: 漏洞CVSSv2信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CVSSv2Info: :class:`Tencentcloud::Bsca.v20210811.models.CVSSV2Info`
# @param CVSSv3Info: 漏洞CVSSv3信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CVSSv3Info: :class:`Tencentcloud::Bsca.v20210811.models.CVSSV3Info`
# @param SubmitTime: 漏洞提交时间
# @type SubmitTime: String
# @param CWEID: CWE编号
# @type CWEID: String
# @param CVSSv2Vector: 漏洞CVSSv2向量
# @type CVSSv2Vector: String
# @param CVSSv3Vector: 漏洞CVSSv3向量
# @type CVSSv3Vector: String
# @param AffectedComponentList: 漏洞影响的组件列表,仅当查询单个漏洞时有效
# @type AffectedComponentList: Array
attr_accessor :Category, :CategoryType, :Description, :OfficialSolution, :ReferenceList, :DefenseSolution, :CVSSv2Info, :CVSSv3Info, :SubmitTime, :CWEID, :CVSSv2Vector, :CVSSv3Vector, :AffectedComponentList
def initialize(category=nil, categorytype=nil, description=nil, officialsolution=nil, referencelist=nil, defensesolution=nil, cvssv2info=nil, cvssv3info=nil, submittime=nil, cweid=nil, cvssv2vector=nil, cvssv3vector=nil, affectedcomponentlist=nil)
@Category = category
@CategoryType = categorytype
@Description = description
@OfficialSolution = officialsolution
@ReferenceList = referencelist
@DefenseSolution = defensesolution
@CVSSv2Info = cvssv2info
@CVSSv3Info = cvssv3info
@SubmitTime = submittime
@CWEID = cweid
@CVSSv2Vector = cvssv2vector
@CVSSv3Vector = cvssv3vector
@AffectedComponentList = affectedcomponentlist
end
def deserialize(params)
@Category = params['Category']
@CategoryType = params['CategoryType']
@Description = params['Description']
@OfficialSolution = params['OfficialSolution']
@ReferenceList = params['ReferenceList']
@DefenseSolution = params['DefenseSolution']
unless params['CVSSv2Info'].nil?
@CVSSv2Info = CVSSV2Info.new
@CVSSv2Info.deserialize(params['CVSSv2Info'])
end
unless params['CVSSv3Info'].nil?
@CVSSv3Info = CVSSV3Info.new
@CVSSv3Info.deserialize(params['CVSSv3Info'])
end
@SubmitTime = params['SubmitTime']
@CWEID = params['CWEID']
@CVSSv2Vector = params['CVSSv2Vector']
@CVSSv3Vector = params['CVSSv3Vector']
unless params['AffectedComponentList'].nil?
@AffectedComponentList = []
params['AffectedComponentList'].each do |i|
affectedcomponent_tmp = AffectedComponent.new
affectedcomponent_tmp.deserialize(i)
@AffectedComponentList << affectedcomponent_tmp
end
end
end
end
# 描述漏洞的摘要信息。
class VulnerabilitySummary < TencentCloud::Common::AbstractModel
# @param VulID: 漏洞ID
# @type VulID: String
# @param CVEID: 漏洞所属CVE编号
# @type CVEID: String
# @param CNVDID: 漏洞所属CNVD编号
# @type CNVDID: String
# @param CNNVDID: 漏洞所属CNNVD编号
# @type CNNVDID: String
# @param Name: 漏洞名称
# @type Name: String
# @param IsSuggest: 该漏洞是否是需重点关注的漏洞
# @type IsSuggest: Boolean
# @param Severity: 漏洞风险等级
# Critical
# High
# Medium
# Low
# @type Severity: String
attr_accessor :VulID, :CVEID, :CNVDID, :CNNVDID, :Name, :IsSuggest, :Severity
def initialize(vulid=nil, cveid=nil, cnvdid=nil, cnnvdid=nil, name=nil, issuggest=nil, severity=nil)
@VulID = vulid
@CVEID = cveid
@CNVDID = cnvdid
@CNNVDID = cnnvdid
@Name = name
@IsSuggest = issuggest
@Severity = severity
end
def deserialize(params)
@VulID = params['VulID']
@CVEID = params['CVEID']
@CNVDID = params['CNVDID']
@CNNVDID = params['CNNVDID']
@Name = params['Name']
@IsSuggest = params['IsSuggest']
@Severity = params['Severity']
end
end
# 描述漏洞的详细信息。
class VulnerabilityUnion < TencentCloud::Common::AbstractModel
# @param Summary: 漏洞概览信息
# @type Summary: :class:`Tencentcloud::Bsca.v20210811.models.VulnerabilitySummary`
# @param Detail: 漏洞详细信息
# @type Detail: :class:`Tencentcloud::Bsca.v20210811.models.VulnerabilityDetail`
attr_accessor :Summary, :Detail
def initialize(summary=nil, detail=nil)
@Summary = summary
@Detail = detail
end
def deserialize(params)
unless params['Summary'].nil?
@Summary = VulnerabilitySummary.new
@Summary.deserialize(params['Summary'])
end
unless params['Detail'].nil?
@Detail = VulnerabilityDetail.new
@Detail.deserialize(params['Detail'])
end
end
end
end
end
end