Class: Sbom::Enricher
- Inherits:
-
Object
- Object
- Sbom::Enricher
- Defined in:
- lib/sbom/enricher.rb
Instance Attribute Summary collapse
-
#errors ⇒ Object
readonly
Returns the value of attribute errors.
-
#sbom ⇒ Object
readonly
Returns the value of attribute sbom.
Class Method Summary collapse
- .apply_advisory_enrichment(package, advisories) ⇒ Object
- .apply_lookup_enrichment(package, data) ⇒ Object
- .enrich(sbom) ⇒ Object
- .enrich_package(package) ⇒ Object
- .find_purl_in_refs(package) ⇒ Object
Instance Method Summary collapse
- #enrich ⇒ Object
- #enrich_package(package) ⇒ Object
-
#initialize(sbom) ⇒ Enricher
constructor
A new instance of Enricher.
Constructor Details
#initialize(sbom) ⇒ Enricher
Returns a new instance of Enricher.
7 8 9 10 |
# File 'lib/sbom/enricher.rb', line 7 def initialize(sbom) @sbom = sbom @errors = [] end |
Instance Attribute Details
#errors ⇒ Object (readonly)
Returns the value of attribute errors.
5 6 7 |
# File 'lib/sbom/enricher.rb', line 5 def errors @errors end |
#sbom ⇒ Object (readonly)
Returns the value of attribute sbom.
5 6 7 |
# File 'lib/sbom/enricher.rb', line 5 def sbom @sbom end |
Class Method Details
.apply_advisory_enrichment(package, advisories) ⇒ Object
142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 |
# File 'lib/sbom/enricher.rb', line 142 def self.apply_advisory_enrichment(package, advisories) package[:advisories] ||= [] advisories.each do |advisory| package[:advisories] << { id: advisory[:id], title: advisory[:title], description: advisory[:description], severity: advisory[:severity], cvss_score: advisory[:cvss_score], url: advisory[:url], published_at: advisory[:published_at], source: advisory[:source_kind], references: advisory[:references] } end package end |
.apply_lookup_enrichment(package, data) ⇒ Object
98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 |
# File 'lib/sbom/enricher.rb', line 98 def self.apply_lookup_enrichment(package, data) pkg_data = data[:package] || {} version_data = data[:version] || {} package[:description] ||= pkg_data[:description] package[:homepage] ||= pkg_data[:homepage] package[:download_location] ||= version_data[:download_url] if pkg_data[:licenses] && !package[:license_concluded] package[:license_concluded] = pkg_data[:licenses] end package[:repository_url] ||= pkg_data[:repository_url] package[:registry_url] ||= pkg_data[:registry_url] package[:documentation_url] ||= pkg_data[:documentation_url] if pkg_data[:maintainers]&.any? && !package[:supplier] first_maintainer = pkg_data[:maintainers].first package[:supplier] = first_maintainer[:login] if first_maintainer package[:supplier_type] = "Organization" end if pkg_data[:keywords]&.any? package[:tags] ||= [] package[:tags].concat(pkg_data[:keywords]).uniq! end package[:properties] ||= [] if pkg_data[:latest_version] package[:properties] << ["ecosystems:latest_version", pkg_data[:latest_version]] end if pkg_data[:latest_version_published_at] package[:properties] << ["ecosystems:latest_version_published_at", pkg_data[:latest_version_published_at]] end if pkg_data[:versions_count] package[:properties] << ["ecosystems:versions_count", pkg_data[:versions_count].to_s] end if version_data[:published_at] package[:properties] << ["ecosystems:version_published_at", version_data[:published_at]] end package end |
.enrich(sbom) ⇒ Object
35 36 37 |
# File 'lib/sbom/enricher.rb', line 35 def self.enrich(sbom) new(sbom).enrich end |
.enrich_package(package) ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/sbom/enricher.rb', line 39 def self.enrich_package(package) purl_string = package[:purl] || find_purl_in_refs(package) return package unless purl_string parsed = Purl.parse(purl_string) return package unless parsed lookup_data = parsed.lookup apply_lookup_enrichment(package, lookup_data) if lookup_data advisories = parsed.advisories apply_advisory_enrichment(package, advisories) if advisories&.any? package rescue StandardError package end |
.find_purl_in_refs(package) ⇒ Object
64 65 66 67 |
# File 'lib/sbom/enricher.rb', line 64 def self.find_purl_in_refs(package) refs = package[:external_references] || [] refs.find { |_, type, _| type == "purl" }&.last end |
Instance Method Details
#enrich ⇒ Object
12 13 14 15 16 17 |
# File 'lib/sbom/enricher.rb', line 12 def enrich @sbom.packages.each do |package| enrich_package(package) end @sbom end |
#enrich_package(package) ⇒ Object
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
# File 'lib/sbom/enricher.rb', line 19 def enrich_package(package) purl_string = package[:purl] || find_purl_in_external_refs(package) return unless purl_string parsed = parse_purl(purl_string) return unless parsed lookup_data = fetch_lookup(parsed) enrich_from_lookup(package, lookup_data) if lookup_data advisories = fetch_advisories(parsed) enrich_from_advisories(package, advisories) if advisories&.any? rescue StandardError => e @errors << { purl: purl_string, error: e. } end |