blob: 9a71c67388d814e9caeaced4364e0defde2bb471 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
# frozen_string_literal: true
module Gitlab
module Ci
module Reports
module Sbom
class Report
# This represents the attributes defined in cycloneDX Schema
# https://gitlab.com/gitlab-org/gitlab/-/blob/master/app/validators/json_schemas/cyclonedx_report.json#L7
BOM_FORMAT = 'CycloneDX'
SPEC_VERSION = '1.4'
VERSION = 1
attr_reader :source, :errors
attr_accessor :sbom_attributes, :metadata, :components
def initialize
@sbom_attributes = {
bom_format: BOM_FORMAT,
spec_version: SPEC_VERSION,
serial_number: "urn:uuid:#{SecureRandom.uuid}",
version: VERSION
}
@components = []
@metadata = ::Gitlab::Ci::Reports::Sbom::Metadata.new
@errors = []
end
def valid?
errors.empty?
end
def add_error(error)
errors << error
end
def set_source(source)
self.source = source
end
def add_component(component)
components << component
end
private
attr_writer :source
end
end
end
end
end
|