Class: Google::Apis::ContaineranalysisV1::VulnerabilityOccurrence

Inherits:
Object
  • Object
show all
Includes:
Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
Defined in:
lib/google/apis/containeranalysis_v1/classes.rb,
lib/google/apis/containeranalysis_v1/representations.rb,
lib/google/apis/containeranalysis_v1/representations.rb

Overview

An occurrence of a severity vulnerability on a resource.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ VulnerabilityOccurrence

Returns a new instance of VulnerabilityOccurrence.



4890
4891
4892
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4890

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#cvss_scoreFloat

Output only. The CVSS score of this vulnerability. CVSS score is on a scale of 0 - 10 where 0 indicates low severity and 10 indicates high severity. Corresponds to the JSON property cvssScore

Returns:

  • (Float)


4829
4830
4831
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4829

def cvss_score
  @cvss_score
end

#cvssv3Google::Apis::ContaineranalysisV1::Cvss

Common Vulnerability Scoring System. For details, see https://www.first.org/ cvss/specification-document This is a message we will try to use for storing multiple versions of CVSS. The intention is that as new versions of CVSS scores get added, we will be able to modify this message rather than adding new protos for each new version of the score. Corresponds to the JSON property cvssv3



4838
4839
4840
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4838

def cvssv3
  @cvssv3
end

#effective_severityString

The distro assigned severity for this vulnerability when it is available, otherwise this is the note provider assigned severity. When there are multiple PackageIssues for this vulnerability, they can have different effective severities because some might be provided by the distro while others are provided by the language ecosystem for a language pack. For this reason, it is advised to use the effective severity on the PackageIssue level. In the case where multiple PackageIssues have differing effective severities, this field should be the highest severity for any of the PackageIssues. Corresponds to the JSON property effectiveSeverity

Returns:

  • (String)


4850
4851
4852
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4850

def effective_severity
  @effective_severity
end

#fix_availableBoolean Also known as: fix_available?

Output only. Whether at least one of the affected packages has a fix available. Corresponds to the JSON property fixAvailable

Returns:

  • (Boolean)


4855
4856
4857
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4855

def fix_available
  @fix_available
end

#long_descriptionString

Output only. A detailed description of this vulnerability. Corresponds to the JSON property longDescription

Returns:

  • (String)


4861
4862
4863
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4861

def long_description
  @long_description
end

#package_issueArray<Google::Apis::ContaineranalysisV1::PackageIssue>

Required. The set of affected locations and their fixes (if available) within the associated resource. Corresponds to the JSON property packageIssue



4867
4868
4869
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4867

def package_issue
  @package_issue
end

Output only. URLs related to this vulnerability. Corresponds to the JSON property relatedUrls



4872
4873
4874
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4872

def related_urls
  @related_urls
end

#severityString

Output only. The note provider assigned severity of this vulnerability. Corresponds to the JSON property severity

Returns:

  • (String)


4877
4878
4879
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4877

def severity
  @severity
end

#short_descriptionString

Output only. A one sentence description of this vulnerability. Corresponds to the JSON property shortDescription

Returns:

  • (String)


4882
4883
4884
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4882

def short_description
  @short_description
end

#typeString

The type of package; whether native or non native (e.g., ruby gems, node.js packages, etc.). Corresponds to the JSON property type

Returns:

  • (String)


4888
4889
4890
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4888

def type
  @type
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



4895
4896
4897
4898
4899
4900
4901
4902
4903
4904
4905
4906
# File 'lib/google/apis/containeranalysis_v1/classes.rb', line 4895

def update!(**args)
  @cvss_score = args[:cvss_score] if args.key?(:cvss_score)
  @cvssv3 = args[:cvssv3] if args.key?(:cvssv3)
  @effective_severity = args[:effective_severity] if args.key?(:effective_severity)
  @fix_available = args[:fix_available] if args.key?(:fix_available)
  @long_description = args[:long_description] if args.key?(:long_description)
  @package_issue = args[:package_issue] if args.key?(:package_issue)
  @related_urls = args[:related_urls] if args.key?(:related_urls)
  @severity = args[:severity] if args.key?(:severity)
  @short_description = args[:short_description] if args.key?(:short_description)
  @type = args[:type] if args.key?(:type)
end