Class: Google::Apis::OndemandscanningV1beta1::PackageData

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ PackageData

Returns a new instance of PackageData.



2103
2104
2105
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2103

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

Instance Attribute Details

#architectureString

The architecture of the package. Corresponds to the JSON property architecture

Returns:

  • (String)


2017
2018
2019
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2017

def architecture
  @architecture
end

#binary_versionGoogle::Apis::OndemandscanningV1beta1::PackageVersion

The binary package. This is significant when the source is different than the binary itself. Historically if they've differed, we've stored the name of the source and its version in the package/version fields, but we should also store the binary package info, as that's what's actually installed. See b/175908657# comment15. Corresponds to the JSON property binaryVersion



2026
2027
2028
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2026

def binary_version
  @binary_version
end

#cpe_uriString

The cpe_uri in cpe format in which the vulnerability may manifest. Examples include distro or storage location for vulnerable jar. Corresponds to the JSON property cpeUri

Returns:

  • (String)


2033
2034
2035
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2033

def cpe_uri
  @cpe_uri
end

#dependency_chainArray<Google::Apis::OndemandscanningV1beta1::LanguagePackageDependency>

The dependency chain between this package and the user's artifact. List in order from the customer's package under review first, to the current package last. Inclusive of the original package and the current package. Corresponds to the JSON property dependencyChain



2040
2041
2042
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2040

def dependency_chain
  @dependency_chain
end

#file_locationArray<Google::Apis::OndemandscanningV1beta1::FileLocation>

The path to the jar file / go binary file. Corresponds to the JSON property fileLocation



2045
2046
2047
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2045

def file_location
  @file_location
end

#hash_digestString

HashDigest stores the SHA512 hash digest of the jar file if the package is of type Maven. This field will be unset for non Maven packages. Corresponds to the JSON property hashDigest

Returns:

  • (String)


2051
2052
2053
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2051

def hash_digest
  @hash_digest
end

#maintainerGoogle::Apis::OndemandscanningV1beta1::Maintainer

The maintainer of the package. Corresponds to the JSON property maintainer



2056
2057
2058
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2056

def maintainer
  @maintainer
end

#osString

The OS affected by a vulnerability Used to generate the cpe_uri for OS packages Corresponds to the JSON property os

Returns:

  • (String)


2062
2063
2064
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2062

def os
  @os
end

#os_versionString

The version of the OS Used to generate the cpe_uri for OS packages Corresponds to the JSON property osVersion

Returns:

  • (String)


2067
2068
2069
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2067

def os_version
  @os_version
end

#packageString

The package being analysed for vulnerabilities Corresponds to the JSON property package

Returns:

  • (String)


2072
2073
2074
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2072

def package
  @package
end

#package_typeString

The type of package: os, maven, go, etc. Corresponds to the JSON property packageType

Returns:

  • (String)


2077
2078
2079
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2077

def package_type
  @package_type
end

#patched_cveArray<String>

CVEs that this package is no longer vulnerable to go/drydock-dd-custom-binary- scanning Corresponds to the JSON property patchedCve

Returns:

  • (Array<String>)


2083
2084
2085
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2083

def patched_cve
  @patched_cve
end

#source_versionGoogle::Apis::OndemandscanningV1beta1::PackageVersion

The source package. Similar to the above, this is significant when the source is different than the binary itself. Since the top-level package/version fields are based on an if/else, we need a separate field for both binary and source if we want to know definitively where the data is coming from. Corresponds to the JSON property sourceVersion



2091
2092
2093
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2091

def source_version
  @source_version
end

#unusedString

Corresponds to the JSON property unused

Returns:

  • (String)


2096
2097
2098
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2096

def unused
  @unused
end

#versionString

The version of the package being analysed Corresponds to the JSON property version

Returns:

  • (String)


2101
2102
2103
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2101

def version
  @version
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
# File 'lib/google/apis/ondemandscanning_v1beta1/classes.rb', line 2108

def update!(**args)
  @architecture = args[:architecture] if args.key?(:architecture)
  @binary_version = args[:binary_version] if args.key?(:binary_version)
  @cpe_uri = args[:cpe_uri] if args.key?(:cpe_uri)
  @dependency_chain = args[:dependency_chain] if args.key?(:dependency_chain)
  @file_location = args[:file_location] if args.key?(:file_location)
  @hash_digest = args[:hash_digest] if args.key?(:hash_digest)
  @maintainer = args[:maintainer] if args.key?(:maintainer)
  @os = args[:os] if args.key?(:os)
  @os_version = args[:os_version] if args.key?(:os_version)
  @package = args[:package] if args.key?(:package)
  @package_type = args[:package_type] if args.key?(:package_type)
  @patched_cve = args[:patched_cve] if args.key?(:patched_cve)
  @source_version = args[:source_version] if args.key?(:source_version)
  @unused = args[:unused] if args.key?(:unused)
  @version = args[:version] if args.key?(:version)
end