sbom-cyclonedx 0.1.0 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.gitignore +15 -0
- data/.gitlab-ci.yml +49 -0
- data/.rspec +3 -0
- data/.rubocop.yml +72 -0
- data/.vscode/settings.json +6 -0
- data/CHANGELOG.md +9 -0
- data/CODE_OF_CONDUCT.md +132 -0
- data/Gemfile +26 -0
- data/Gemfile.lock +179 -0
- data/LICENSE.txt +21 -0
- data/README.md +39 -0
- data/Rakefile +36 -0
- data/Steepfile +14 -0
- data/bin/console +11 -0
- data/bin/rbs_spec +9 -0
- data/bin/setup +8 -0
- data/bom-1.6.schema.json +7334 -0
- data/lib/email_address_extension.rb +26 -0
- data/lib/sbom/cyclone_dx/enum.rb +2178 -0
- data/lib/sbom/cyclone_dx/field.rb +404 -0
- data/lib/sbom/cyclone_dx/pattern.rb +43 -0
- data/lib/sbom/cyclone_dx/record/advisory.rb +17 -0
- data/lib/sbom/cyclone_dx/record/annotation.rb +46 -0
- data/lib/sbom/cyclone_dx/record/attachment.rb +21 -0
- data/lib/sbom/cyclone_dx/record/base.rb +244 -0
- data/lib/sbom/cyclone_dx/record/cipher_suite.rb +23 -0
- data/lib/sbom/cyclone_dx/record/co2_measure.rb +18 -0
- data/lib/sbom/cyclone_dx/record/command.rb +18 -0
- data/lib/sbom/cyclone_dx/record/commit.rb +25 -0
- data/lib/sbom/cyclone_dx/record/component.rb +126 -0
- data/lib/sbom/cyclone_dx/record/component_data.rb +46 -0
- data/lib/sbom/cyclone_dx/record/component_evidence.rb +68 -0
- data/lib/sbom/cyclone_dx/record/component_identity_evidence.rb +36 -0
- data/lib/sbom/cyclone_dx/record/composition.rb +33 -0
- data/lib/sbom/cyclone_dx/record/condition.rb +20 -0
- data/lib/sbom/cyclone_dx/record/copyright.rb +16 -0
- data/lib/sbom/cyclone_dx/record/crypto_properties.rb +137 -0
- data/lib/sbom/cyclone_dx/record/data_governance.rb +21 -0
- data/lib/sbom/cyclone_dx/record/data_governance_responsible_party.rb +22 -0
- data/lib/sbom/cyclone_dx/record/declarations.rb +193 -0
- data/lib/sbom/cyclone_dx/record/definitions.rb +17 -0
- data/lib/sbom/cyclone_dx/record/dependency.rb +21 -0
- data/lib/sbom/cyclone_dx/record/diff.rb +18 -0
- data/lib/sbom/cyclone_dx/record/energy_consumption.rb +31 -0
- data/lib/sbom/cyclone_dx/record/energy_measure.rb +18 -0
- data/lib/sbom/cyclone_dx/record/energy_provider.rb +31 -0
- data/lib/sbom/cyclone_dx/record/environmental_consideration.rb +20 -0
- data/lib/sbom/cyclone_dx/record/event.rb +31 -0
- data/lib/sbom/cyclone_dx/record/external_reference.rb +25 -0
- data/lib/sbom/cyclone_dx/record/fairness_assessment.rb +22 -0
- data/lib/sbom/cyclone_dx/record/formula.rb +29 -0
- data/lib/sbom/cyclone_dx/record/graphic.rb +19 -0
- data/lib/sbom/cyclone_dx/record/graphics_collection.rb +19 -0
- data/lib/sbom/cyclone_dx/record/hash_data.rb +18 -0
- data/lib/sbom/cyclone_dx/record/identifiable_action.rb +21 -0
- data/lib/sbom/cyclone_dx/record/input.rb +34 -0
- data/lib/sbom/cyclone_dx/record/input_output_ml_parameter.rb +17 -0
- data/lib/sbom/cyclone_dx/record/issue.rb +36 -0
- data/lib/sbom/cyclone_dx/record/license.rb +90 -0
- data/lib/sbom/cyclone_dx/record/license_choice.rb +35 -0
- data/lib/sbom/cyclone_dx/record/metadata.rb +55 -0
- data/lib/sbom/cyclone_dx/record/model_card.rb +89 -0
- data/lib/sbom/cyclone_dx/record/note.rb +20 -0
- data/lib/sbom/cyclone_dx/record/organizational_contact.rb +26 -0
- data/lib/sbom/cyclone_dx/record/organizational_entity.rb +28 -0
- data/lib/sbom/cyclone_dx/record/output.rb +34 -0
- data/lib/sbom/cyclone_dx/record/parameter.rb +20 -0
- data/lib/sbom/cyclone_dx/record/patch.rb +23 -0
- data/lib/sbom/cyclone_dx/record/performance_metric.rb +30 -0
- data/lib/sbom/cyclone_dx/record/postal_address.rb +34 -0
- data/lib/sbom/cyclone_dx/record/property.rb +18 -0
- data/lib/sbom/cyclone_dx/record/rating.rb +27 -0
- data/lib/sbom/cyclone_dx/record/release_notes.rb +44 -0
- data/lib/sbom/cyclone_dx/record/resource_reference_choice.rb +22 -0
- data/lib/sbom/cyclone_dx/record/risk.rb +18 -0
- data/lib/sbom/cyclone_dx/record/root.rb +63 -0
- data/lib/sbom/cyclone_dx/record/secured_by.rb +20 -0
- data/lib/sbom/cyclone_dx/record/service.rb +54 -0
- data/lib/sbom/cyclone_dx/record/service_data.rb +32 -0
- data/lib/sbom/cyclone_dx/record/signature.rb +85 -0
- data/lib/sbom/cyclone_dx/record/standard.rb +72 -0
- data/lib/sbom/cyclone_dx/record/step.rb +24 -0
- data/lib/sbom/cyclone_dx/record/swid.rb +29 -0
- data/lib/sbom/cyclone_dx/record/task.rb +56 -0
- data/lib/sbom/cyclone_dx/record/tools.rb +20 -0
- data/lib/sbom/cyclone_dx/record/trigger.rb +48 -0
- data/lib/sbom/cyclone_dx/record/version.rb +24 -0
- data/lib/sbom/cyclone_dx/record/volume.rb +33 -0
- data/lib/sbom/cyclone_dx/record/vulnerability.rb +119 -0
- data/lib/sbom/cyclone_dx/record/vulnerability_source.rb +20 -0
- data/lib/sbom/cyclone_dx/record/workflow.rb +59 -0
- data/lib/sbom/cyclone_dx/record/workspace.rb +45 -0
- data/lib/sbom/cyclone_dx/record.rb +12 -0
- data/lib/sbom/cyclone_dx/validator/array_validator.rb +66 -0
- data/lib/sbom/cyclone_dx/validator/base_validator.rb +43 -0
- data/lib/sbom/cyclone_dx/validator/boolean_validator.rb +16 -0
- data/lib/sbom/cyclone_dx/validator/date_time_validator.rb +29 -0
- data/lib/sbom/cyclone_dx/validator/email_address_validator.rb +31 -0
- data/lib/sbom/cyclone_dx/validator/float_validator.rb +30 -0
- data/lib/sbom/cyclone_dx/validator/integer_validator.rb +30 -0
- data/lib/sbom/cyclone_dx/validator/record_validator.rb +26 -0
- data/lib/sbom/cyclone_dx/validator/string_validator.rb +33 -0
- data/lib/sbom/cyclone_dx/validator/union_validator.rb +39 -0
- data/lib/sbom/cyclone_dx/validator/uri_validator.rb +32 -0
- data/lib/sbom/cyclone_dx/validator.rb +32 -0
- data/lib/sbom/cyclone_dx/version.rb +7 -0
- data/lib/sbom/cyclone_dx.rb +39 -0
- data/rbs_collection.lock.yaml +288 -0
- data/rbs_collection.yaml +31 -0
- data/sbom-cyclone_dx.gemspec +32 -0
- data/sig/email_address_extension.rbs +14 -0
- data/sig/sbom/cyclone_dx/enum.rbs +93 -0
- data/sig/sbom/cyclone_dx/field.rbs +434 -0
- data/sig/sbom/cyclone_dx/pattern.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/advisory.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/annotation.rbs +63 -0
- data/sig/sbom/cyclone_dx/record/attachment.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/base.rbs +62 -0
- data/sig/sbom/cyclone_dx/record/cipher_suite.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/co2_measure.rbs +14 -0
- data/sig/sbom/cyclone_dx/record/command.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/commit.rbs +34 -0
- data/sig/sbom/cyclone_dx/record/component.rbs +203 -0
- data/sig/sbom/cyclone_dx/record/component_data.rbs +73 -0
- data/sig/sbom/cyclone_dx/record/component_evidence.rbs +115 -0
- data/sig/sbom/cyclone_dx/record/component_identity_evidence.rbs +53 -0
- data/sig/sbom/cyclone_dx/record/composition.rbs +39 -0
- data/sig/sbom/cyclone_dx/record/condition.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/copyright.rbs +14 -0
- data/sig/sbom/cyclone_dx/record/crypto_properties.rbs +268 -0
- data/sig/sbom/cyclone_dx/record/data_governance.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/data_governance_responsible_party.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/declarations.rbs +352 -0
- data/sig/sbom/cyclone_dx/record/definitions.rbs +14 -0
- data/sig/sbom/cyclone_dx/record/dependency.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/diff.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/energy_consumption.rbs +39 -0
- data/sig/sbom/cyclone_dx/record/energy_measure.rbs +14 -0
- data/sig/sbom/cyclone_dx/record/energy_provider.rbs +39 -0
- data/sig/sbom/cyclone_dx/record/environmental_consideration.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/event.rbs +44 -0
- data/sig/sbom/cyclone_dx/record/external_reference.rbs +29 -0
- data/sig/sbom/cyclone_dx/record/fairness_assessment.rbs +29 -0
- data/sig/sbom/cyclone_dx/record/formula.rbs +34 -0
- data/sig/sbom/cyclone_dx/record/graphic.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/graphics_collection.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/hash_data.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/identifiable_action.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/input.rbs +44 -0
- data/sig/sbom/cyclone_dx/record/input_output_ml_parameter.rbs +14 -0
- data/sig/sbom/cyclone_dx/record/issue.rbs +53 -0
- data/sig/sbom/cyclone_dx/record/license.rbs +134 -0
- data/sig/sbom/cyclone_dx/record/license_choice.rbs +39 -0
- data/sig/sbom/cyclone_dx/record/metadata.rbs +82 -0
- data/sig/sbom/cyclone_dx/record/model_card.rbs +143 -0
- data/sig/sbom/cyclone_dx/record/note.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/organizational_contact.rbs +29 -0
- data/sig/sbom/cyclone_dx/record/organizational_entity.rbs +34 -0
- data/sig/sbom/cyclone_dx/record/output.rbs +44 -0
- data/sig/sbom/cyclone_dx/record/parameter.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/patch.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/performance_metric.rbs +43 -0
- data/sig/sbom/cyclone_dx/record/postal_address.rbs +44 -0
- data/sig/sbom/cyclone_dx/record/property.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/rating.rbs +39 -0
- data/sig/sbom/cyclone_dx/record/release_notes.rbs +64 -0
- data/sig/sbom/cyclone_dx/record/resource_reference_choice.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/risk.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/root.rbs +84 -0
- data/sig/sbom/cyclone_dx/record/secured_by.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/service.rbs +99 -0
- data/sig/sbom/cyclone_dx/record/service_data.rbs +44 -0
- data/sig/sbom/cyclone_dx/record/signature.rbs +130 -0
- data/sig/sbom/cyclone_dx/record/standard.rbs +132 -0
- data/sig/sbom/cyclone_dx/record/step.rbs +29 -0
- data/sig/sbom/cyclone_dx/record/swid.rbs +44 -0
- data/sig/sbom/cyclone_dx/record/task.rbs +84 -0
- data/sig/sbom/cyclone_dx/record/tools.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/trigger.rbs +69 -0
- data/sig/sbom/cyclone_dx/record/version.rbs +24 -0
- data/sig/sbom/cyclone_dx/record/volume.rbs +49 -0
- data/sig/sbom/cyclone_dx/record/vulnerability.rbs +209 -0
- data/sig/sbom/cyclone_dx/record/vulnerability_source.rbs +19 -0
- data/sig/sbom/cyclone_dx/record/workflow.rbs +94 -0
- data/sig/sbom/cyclone_dx/record/workspace.rbs +69 -0
- data/sig/sbom/cyclone_dx/record.rbs +161 -0
- data/sig/sbom/cyclone_dx/type.rbs +16 -0
- data/sig/sbom/cyclone_dx/validator/array_validator.rbs +31 -0
- data/sig/sbom/cyclone_dx/validator/base_validator.rbs +21 -0
- data/sig/sbom/cyclone_dx/validator/boolean_validator.rbs +9 -0
- data/sig/sbom/cyclone_dx/validator/date_time_validator.rbs +10 -0
- data/sig/sbom/cyclone_dx/validator/email_address_validator.rbs +10 -0
- data/sig/sbom/cyclone_dx/validator/float_validator.rbs +12 -0
- data/sig/sbom/cyclone_dx/validator/integer_validator.rbs +12 -0
- data/sig/sbom/cyclone_dx/validator/record_validator.rbs +12 -0
- data/sig/sbom/cyclone_dx/validator/string_validator.rbs +14 -0
- data/sig/sbom/cyclone_dx/validator/union_validator.rbs +24 -0
- data/sig/sbom/cyclone_dx/validator/uri_validator.rbs +10 -0
- data/sig/sbom/cyclone_dx/validator.rbs +66 -0
- data/sig/sbom/cyclone_dx.rbs +13 -0
- data/sig/types.rbs +45 -0
- data/spec/email_address_extension_spec.rb +27 -0
- data/spec/factories/factory_helper.rb +78 -0
- data/spec/factories/record/advisory_factory.rb +11 -0
- data/spec/factories/record/annotation_factory.rb +63 -0
- data/spec/factories/record/attachment_factory.rb +9 -0
- data/spec/factories/record/cipher_suite_factory.rb +26 -0
- data/spec/factories/record/co2_measure_factory.rb +9 -0
- data/spec/factories/record/command_factory.rb +10 -0
- data/spec/factories/record/commit_factory.rb +13 -0
- data/spec/factories/record/component_data_factory.rb +28 -0
- data/spec/factories/record/component_evidence_factory.rb +44 -0
- data/spec/factories/record/component_factory.rb +102 -0
- data/spec/factories/record/component_identity_evidence_factory.rb +25 -0
- data/spec/factories/record/composition_factory.rb +20 -0
- data/spec/factories/record/condition_factory.rb +11 -0
- data/spec/factories/record/copyright_factory.rb +9 -0
- data/spec/factories/record/crypto_properties_factory.rb +191 -0
- data/spec/factories/record/data_governance_factory.rb +11 -0
- data/spec/factories/record/data_governance_responsible_party_factory.rb +31 -0
- data/spec/factories/record/declarations_factory.rb +145 -0
- data/spec/factories/record/definitions_factory.rb +9 -0
- data/spec/factories/record/dependency_factory.rb +12 -0
- data/spec/factories/record/diff_factory.rb +24 -0
- data/spec/factories/record/energy_consumption_factory.rb +15 -0
- data/spec/factories/record/energy_measure_factory.rb +9 -0
- data/spec/factories/record/energy_provider_factory.rb +15 -0
- data/spec/factories/record/environmental_consideration_factory.rb +10 -0
- data/spec/factories/record/event_factory.rb +15 -0
- data/spec/factories/record/external_reference_factory.rb +13 -0
- data/spec/factories/record/fairness_assessment_factory.rb +12 -0
- data/spec/factories/record/formula_factory.rb +13 -0
- data/spec/factories/record/graphic_factory.rb +10 -0
- data/spec/factories/record/graphics_collection_factory.rb +10 -0
- data/spec/factories/record/hash_data_factory.rb +10 -0
- data/spec/factories/record/identifiable_action_factory.rb +11 -0
- data/spec/factories/record/input_factory.rb +36 -0
- data/spec/factories/record/input_output_ml_parameter_factory.rb +9 -0
- data/spec/factories/record/issue_factory.rb +22 -0
- data/spec/factories/record/license_choice_factory.rb +23 -0
- data/spec/factories/record/license_factory.rb +99 -0
- data/spec/factories/record/metadata_factory.rb +38 -0
- data/spec/factories/record/model_card_factory.rb +59 -0
- data/spec/factories/record/note_factory.rb +11 -0
- data/spec/factories/record/organizational_contact_factory.rb +12 -0
- data/spec/factories/record/organizational_entity_factory.rb +13 -0
- data/spec/factories/record/output_factory.rb +32 -0
- data/spec/factories/record/parameter_factory.rb +11 -0
- data/spec/factories/record/patch_factory.rb +12 -0
- data/spec/factories/record/performance_metric_factory.rb +20 -0
- data/spec/factories/record/postal_address_factory.rb +14 -0
- data/spec/factories/record/property_factory.rb +11 -0
- data/spec/factories/record/rating_factory.rb +14 -0
- data/spec/factories/record/release_notes_factory.rb +20 -0
- data/spec/factories/record/resource_reference_choice_factory.rb +27 -0
- data/spec/factories/record/risk_factory.rb +10 -0
- data/spec/factories/record/root_factory.rb +23 -0
- data/spec/factories/record/secured_by_factory.rb +10 -0
- data/spec/factories/record/service_data_factory.rb +16 -0
- data/spec/factories/record/service_factory.rb +27 -0
- data/spec/factories/record/signature_factory.rb +50 -0
- data/spec/factories/record/standard_factory.rb +37 -0
- data/spec/factories/record/step_factory.rb +12 -0
- data/spec/factories/record/swid_factory.rb +16 -0
- data/spec/factories/record/task_factory.rb +24 -0
- data/spec/factories/record/tools_factory.rb +10 -0
- data/spec/factories/record/trigger_factory.rb +21 -0
- data/spec/factories/record/version_factory.rb +19 -0
- data/spec/factories/record/volume_factory.rb +16 -0
- data/spec/factories/record/vulnerability_factory.rb +70 -0
- data/spec/factories/record/vulnerability_source_factory.rb +10 -0
- data/spec/factories/record/workflow_factory.rb +26 -0
- data/spec/factories/record/workspace_factory.rb +21 -0
- data/spec/factories/record_factory.rb +159 -0
- data/spec/fixtures/cipher_info.yml +948 -0
- data/spec/fixtures/purl_data.yml +0 -0
- data/spec/sbom/cyclone_dx/enum_spec.rb +30 -0
- data/spec/sbom/cyclone_dx/field_spec.rb +104 -0
- data/spec/sbom/cyclone_dx/pattern_spec.rb +18 -0
- data/spec/sbom/cyclone_dx/record/advisory_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/annotation_spec.rb +31 -0
- data/spec/sbom/cyclone_dx/record/attachment_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/base_spec.rb +363 -0
- data/spec/sbom/cyclone_dx/record/cipher_suite_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/co2_measure_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/command_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/commit_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/component_data_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/component_evidence_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/component_identity_evidence_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/component_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/composition_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/condition_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/copyright_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/crypto_properties_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/data_governance_responsible_party_spec.rb +19 -0
- data/spec/sbom/cyclone_dx/record/data_governance_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/declarations_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/definitions_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/dependency_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/diff_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/energy_consumption_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/energy_measure_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/energy_provider_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/environmental_consideration_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/event_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/external_reference_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/fairness_assessment_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/formula_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/graphic_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/graphics_collection_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/hash_data_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/identifiable_action_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/input_output_ml_parameter_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/input_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/issue_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/license_choice_spec.rb +26 -0
- data/spec/sbom/cyclone_dx/record/license_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/metadata_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/model_card_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/note_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/organizational_contact_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/organizational_entity_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/output_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/parameter_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/patch_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/performance_metric_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/postal_address_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/property_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/rating_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/release_notes_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/resource_reference_choice_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/risk_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/root_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/secured_by_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/service_data_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/service_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/signature_spec.rb +26 -0
- data/spec/sbom/cyclone_dx/record/standard_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/step_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/swid_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/task_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/tools_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/trigger_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/version_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/volume_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/vulnerability_source_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/vulnerability_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/workflow_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record/workspace_spec.rb +14 -0
- data/spec/sbom/cyclone_dx/record_spec.rb +7 -0
- data/spec/sbom/cyclone_dx/validator/array_validator_spec.rb +184 -0
- data/spec/sbom/cyclone_dx/validator/base_validator_spec.rb +71 -0
- data/spec/sbom/cyclone_dx/validator/boolean_validator_spec.rb +26 -0
- data/spec/sbom/cyclone_dx/validator/date_time_validator_spec.rb +28 -0
- data/spec/sbom/cyclone_dx/validator/email_address_validator_spec.rb +23 -0
- data/spec/sbom/cyclone_dx/validator/float_validator_spec.rb +71 -0
- data/spec/sbom/cyclone_dx/validator/integer_validator_spec.rb +71 -0
- data/spec/sbom/cyclone_dx/validator/record_validator_spec.rb +35 -0
- data/spec/sbom/cyclone_dx/validator/string_validator_spec.rb +94 -0
- data/spec/sbom/cyclone_dx/validator/union_validator_spec.rb +65 -0
- data/spec/sbom/cyclone_dx/validator/uri_validator_spec.rb +21 -0
- data/spec/sbom/cyclone_dx/validator_spec.rb +38 -0
- data/spec/sbom/cyclone_dx/version_spec.rb +9 -0
- data/spec/sbom/cyclone_dx_spec.rb +7 -0
- data/spec/spec_helper.rb +39 -0
- metadata +377 -6
@@ -0,0 +1,84 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class Root < Base
|
5
|
+
def initialize: (?serial_number: String?, ?version: Integer, ?metadata: Metadata?, ?components: Array[Component]?, ?services: Array[Service]?, ?external_references: Array[ExternalReference]?, ?dependencies: Array[Dependency]?, ?compositions: Array[Composition]?, ?vulnerabilities: Array[Vulnerability]?, ?annotations: Array[Annotation]?, ?formulation: Array[Formula]?, ?declarations: Declarations?, ?definitions: Definitions?, ?properties: Array[Property]?, ?signature: Signature::signatureChoice?) -> void
|
6
|
+
|
7
|
+
def serial_number: () -> String?
|
8
|
+
def serial_number=: (String?) -> String?
|
9
|
+
def serial_number?: () -> bool
|
10
|
+
def serial_number_valid?: () -> bool
|
11
|
+
|
12
|
+
def version: () -> Integer
|
13
|
+
def version=: (Integer) -> Integer
|
14
|
+
def version?: () -> bool
|
15
|
+
def version_valid?: () -> bool
|
16
|
+
|
17
|
+
def metadata: () -> Metadata?
|
18
|
+
def metadata=: (Metadata?) -> Metadata?
|
19
|
+
def metadata?: () -> bool
|
20
|
+
def metadata_valid?: () -> bool
|
21
|
+
|
22
|
+
def components: () -> Array[Component]?
|
23
|
+
def components=: (Array[Component]?) -> Array[Component]?
|
24
|
+
def components?: () -> bool
|
25
|
+
def components_valid?: () -> bool
|
26
|
+
|
27
|
+
def services: () -> Array[Service]?
|
28
|
+
def services=: (Array[Service]?) -> Array[Service]?
|
29
|
+
def services?: () -> bool
|
30
|
+
def services_valid?: () -> bool
|
31
|
+
|
32
|
+
def external_references: () -> Array[ExternalReference]?
|
33
|
+
def external_references=: (Array[ExternalReference]?) -> Array[ExternalReference]?
|
34
|
+
def external_references?: () -> bool
|
35
|
+
def external_references_valid?: () -> bool
|
36
|
+
|
37
|
+
def dependencies: () -> Array[Dependency]?
|
38
|
+
def dependencies=: (Array[Dependency]?) -> Array[Dependency]?
|
39
|
+
def dependencies?: () -> bool
|
40
|
+
def dependencies_valid?: () -> bool
|
41
|
+
|
42
|
+
def compositions: () -> Array[Composition]?
|
43
|
+
def compositions=: (Array[Composition]?) -> Array[Composition]?
|
44
|
+
def compositions?: () -> bool
|
45
|
+
def compositions_valid?: () -> bool
|
46
|
+
|
47
|
+
def vulnerabilities: () -> Array[Vulnerability]?
|
48
|
+
def vulnerabilities=: (Array[Vulnerability]?) -> Array[Vulnerability]?
|
49
|
+
def vulnerabilities?: () -> bool
|
50
|
+
def vulnerabilities_valid?: () -> bool
|
51
|
+
|
52
|
+
def annotations: () -> Array[Annotation]?
|
53
|
+
def annotations=: (Array[Annotation]?) -> Array[Annotation]?
|
54
|
+
def annotations?: () -> bool
|
55
|
+
def annotations_valid?: () -> bool
|
56
|
+
|
57
|
+
def formulation: () -> Array[Formula]?
|
58
|
+
def formulation=: (Array[Formula]?) -> Array[Formula]?
|
59
|
+
def formulation?: () -> bool
|
60
|
+
def formulation_valid?: () -> bool
|
61
|
+
|
62
|
+
def declarations: () -> Declarations?
|
63
|
+
def declarations=: (Declarations?) -> Declarations?
|
64
|
+
def declarations?: () -> bool
|
65
|
+
def declarations_valid?: () -> bool
|
66
|
+
|
67
|
+
def definitions: () -> Definitions?
|
68
|
+
def definitions=: (Definitions?) -> Definitions?
|
69
|
+
def definitions?: () -> bool
|
70
|
+
def definitions_valid?: () -> bool
|
71
|
+
|
72
|
+
def properties: () -> Array[Property]?
|
73
|
+
def properties=: (Array[Property]?) -> Array[Property]?
|
74
|
+
def properties?: () -> bool
|
75
|
+
def properties_valid?: () -> bool
|
76
|
+
|
77
|
+
def signature: () -> Signature::signatureChoice?
|
78
|
+
def signature=: (Signature::signatureChoice?) -> Signature::signatureChoice?
|
79
|
+
def signature?: () -> bool
|
80
|
+
def signature_valid?: () -> bool
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class SecuredBy < Base
|
5
|
+
def initialize: (?mechanism: String?, ?algorithm_ref: String?) -> void
|
6
|
+
|
7
|
+
def mechanism: () -> String?
|
8
|
+
def mechanism=: (String?) -> String?
|
9
|
+
def mechanism?: () -> bool
|
10
|
+
def mechanism_valid?: () -> bool
|
11
|
+
|
12
|
+
def algorithm_ref: () -> String?
|
13
|
+
def algorithm_ref=: (String?) -> String?
|
14
|
+
def algorithm_ref?: () -> bool
|
15
|
+
def algorithm_ref_valid?: () -> bool
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,99 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class Service < Base
|
5
|
+
def initialize: (?bom_ref: String?, ?provider: OrganizationalEntity?, ?group: String?, name: String, ?version: String?, ?description: String?, ?endpoints: Array[uri]?, ?authenticated: bool?, ?x_trust_boundary: bool?, ?trust_zone: String?, ?data: Array[ServiceData]?, ?licenses: Array[LicenseChoice::licenseChoice]?, ?external_references: Array[ExternalReference]?, ?services: Array[Service]?, ?release_notes: ReleaseNotes?, ?properties: Array[Property]?, ?tags: Array[String]?, ?signature: Signature::signatureChoice?) -> void
|
6
|
+
|
7
|
+
def bom_ref: () -> String?
|
8
|
+
def bom_ref=: (String?) -> String?
|
9
|
+
def bom_ref?: () -> bool
|
10
|
+
def bom_ref_valid?: () -> bool
|
11
|
+
|
12
|
+
def provider: () -> OrganizationalEntity?
|
13
|
+
def provider=: (OrganizationalEntity?) -> OrganizationalEntity?
|
14
|
+
def provider?: () -> bool
|
15
|
+
def provider_valid?: () -> bool
|
16
|
+
|
17
|
+
def group: () -> String?
|
18
|
+
def group=: (String?) -> String?
|
19
|
+
def group?: () -> bool
|
20
|
+
def group_valid?: () -> bool
|
21
|
+
|
22
|
+
def name: () -> String
|
23
|
+
def name=: (String) -> String
|
24
|
+
def name?: () -> bool
|
25
|
+
def name_valid?: () -> bool
|
26
|
+
|
27
|
+
def version: () -> String?
|
28
|
+
def version=: (String?) -> String?
|
29
|
+
def version?: () -> bool
|
30
|
+
def version_valid?: () -> bool
|
31
|
+
|
32
|
+
def description: () -> String?
|
33
|
+
def description=: (String?) -> String?
|
34
|
+
def description?: () -> bool
|
35
|
+
def description_valid?: () -> bool
|
36
|
+
|
37
|
+
def endpoints: () -> Array[uri]?
|
38
|
+
def endpoints=: (Array[uri]?) -> Array[uri]?
|
39
|
+
def endpoints?: () -> bool
|
40
|
+
def endpoints_valid?: () -> bool
|
41
|
+
|
42
|
+
def authenticated: () -> bool?
|
43
|
+
def authenticated=: (bool?) -> bool?
|
44
|
+
def authenticated?: () -> bool
|
45
|
+
def authenticated_valid?: () -> bool
|
46
|
+
|
47
|
+
def x_trust_boundary: () -> bool?
|
48
|
+
def x_trust_boundary=: (bool?) -> bool?
|
49
|
+
def x_trust_boundary?: () -> bool
|
50
|
+
def x_trust_boundary_valid?: () -> bool
|
51
|
+
|
52
|
+
def trust_zone: () -> String?
|
53
|
+
def trust_zone=: (String?) -> String?
|
54
|
+
def trust_zone?: () -> bool
|
55
|
+
def trust_zone_valid?: () -> bool
|
56
|
+
|
57
|
+
def data: () -> Array[ServiceData]?
|
58
|
+
def data=: (Array[ServiceData]?) -> Array[ServiceData]?
|
59
|
+
def data?: () -> bool
|
60
|
+
def data_valid?: () -> bool
|
61
|
+
|
62
|
+
def licenses: () -> Array[LicenseChoice::licenseChoice]?
|
63
|
+
def licenses=: (Array[LicenseChoice::licenseChoice]?) -> Array[LicenseChoice::licenseChoice]?
|
64
|
+
def licenses?: () -> bool
|
65
|
+
def licenses_valid?: () -> bool
|
66
|
+
|
67
|
+
def external_references: () -> Array[ExternalReference]?
|
68
|
+
def external_references=: (Array[ExternalReference]?) -> Array[ExternalReference]?
|
69
|
+
def external_references?: () -> bool
|
70
|
+
def external_references_valid?: () -> bool
|
71
|
+
|
72
|
+
def services: () -> Array[Service]?
|
73
|
+
def services=: (Array[Service]?) -> Array[Service]?
|
74
|
+
def services?: () -> bool
|
75
|
+
def services_valid?: () -> bool
|
76
|
+
|
77
|
+
def release_notes: () -> ReleaseNotes?
|
78
|
+
def release_notes=: (ReleaseNotes?) -> ReleaseNotes?
|
79
|
+
def release_notes?: () -> bool
|
80
|
+
def release_notes_valid?: () -> bool
|
81
|
+
|
82
|
+
def properties: () -> Array[Property]?
|
83
|
+
def properties=: (Array[Property]?) -> Array[Property]?
|
84
|
+
def properties?: () -> bool
|
85
|
+
def properties_valid?: () -> bool
|
86
|
+
|
87
|
+
def tags: () -> Array[String]?
|
88
|
+
def tags=: (Array[String]?) -> Array[String]?
|
89
|
+
def tags?: () -> bool
|
90
|
+
def tags_valid?: () -> bool
|
91
|
+
|
92
|
+
def signature: () -> Signature::signatureChoice?
|
93
|
+
def signature=: (Signature::signatureChoice?) -> Signature::signatureChoice?
|
94
|
+
def signature?: () -> bool
|
95
|
+
def signature_valid?: () -> bool
|
96
|
+
end
|
97
|
+
end
|
98
|
+
end
|
99
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class ServiceData < Base
|
5
|
+
def initialize: (flow: String, classification: String, ?name: String?, ?description: String?, ?governance: DataGovernance?, source: uri | String, destination: uri | String) -> void
|
6
|
+
|
7
|
+
def flow: () -> String
|
8
|
+
def flow=: (String) -> String
|
9
|
+
def flow?: () -> bool
|
10
|
+
def flow_valid?: () -> bool
|
11
|
+
|
12
|
+
def classification: () -> String
|
13
|
+
def classification=: (String) -> String
|
14
|
+
def classification?: () -> bool
|
15
|
+
def classification_valid?: () -> bool
|
16
|
+
|
17
|
+
def name: () -> String?
|
18
|
+
def name=: (String?) -> String?
|
19
|
+
def name?: () -> bool
|
20
|
+
def name_valid?: () -> bool
|
21
|
+
|
22
|
+
def description: () -> String?
|
23
|
+
def description=: (String?) -> String?
|
24
|
+
def description?: () -> bool
|
25
|
+
def description_valid?: () -> bool
|
26
|
+
|
27
|
+
def governance: () -> DataGovernance?
|
28
|
+
def governance=: (DataGovernance?) -> DataGovernance?
|
29
|
+
def governance?: () -> bool
|
30
|
+
def governance_valid?: () -> bool
|
31
|
+
|
32
|
+
def source: () -> (uri | String)
|
33
|
+
def source=: (uri | String) -> (uri | String)
|
34
|
+
def source?: () -> bool
|
35
|
+
def source_valid?: () -> bool
|
36
|
+
|
37
|
+
def destination: () -> (uri | String)
|
38
|
+
def destination=: (uri | String) -> (uri | String)
|
39
|
+
def destination?: () -> bool
|
40
|
+
def destination_valid?: () -> bool
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,130 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
module Signature
|
5
|
+
type signatureChoice = JSFSignature | SignatureChain | SignerList
|
6
|
+
|
7
|
+
UNION_TYPE: [singleton(JSFSignature), singleton(SignatureChain), singleton(SignerList)]
|
8
|
+
|
9
|
+
class JSFSignature < Base
|
10
|
+
module PublicKey
|
11
|
+
type publicKeyChoice = EC | OKP | RSA
|
12
|
+
|
13
|
+
UNION_TYPE: [singleton(EC), singleton(OKP), singleton(RSA)]
|
14
|
+
|
15
|
+
class EC < Base
|
16
|
+
def initialize: (crv: String, x: String, y: String) -> void
|
17
|
+
|
18
|
+
def kty: () -> "EC"
|
19
|
+
def kty?: () -> true
|
20
|
+
def kty_valid?: () -> true
|
21
|
+
|
22
|
+
def crv: () -> String
|
23
|
+
def crv=: (String) -> String
|
24
|
+
def crv?: () -> bool
|
25
|
+
def crv_valid?: () -> bool
|
26
|
+
|
27
|
+
def x: () -> String
|
28
|
+
def x=: (String) -> String
|
29
|
+
def x?: () -> bool
|
30
|
+
def x_valid?: () -> bool
|
31
|
+
|
32
|
+
def y: () -> String
|
33
|
+
def y=: (String) -> String
|
34
|
+
def y?: () -> bool
|
35
|
+
def y_valid?: () -> bool
|
36
|
+
end
|
37
|
+
|
38
|
+
class OKP < Base
|
39
|
+
def initialize: (crv: String, x: String) -> void
|
40
|
+
|
41
|
+
def kty: () -> "OKP"
|
42
|
+
def kty?: () -> true
|
43
|
+
def kty_valid?: () -> true
|
44
|
+
|
45
|
+
def crv: () -> String
|
46
|
+
def crv=: (String) -> String
|
47
|
+
def crv?: () -> bool
|
48
|
+
def crv_valid?: () -> bool
|
49
|
+
|
50
|
+
def x: () -> String
|
51
|
+
def x=: (String) -> String
|
52
|
+
def x?: () -> bool
|
53
|
+
def x_valid?: () -> bool
|
54
|
+
end
|
55
|
+
|
56
|
+
class RSA < Base
|
57
|
+
def initialize: (n: String, e: String) -> void
|
58
|
+
|
59
|
+
def kty: () -> "RSA"
|
60
|
+
def kty?: () -> true
|
61
|
+
def kty_valid?: () -> true
|
62
|
+
|
63
|
+
def n: () -> String
|
64
|
+
def n=: (String) -> String
|
65
|
+
def n?: () -> bool
|
66
|
+
def n_valid?: () -> bool
|
67
|
+
|
68
|
+
def e: () -> String
|
69
|
+
def e=: (String) -> String
|
70
|
+
def e?: () -> bool
|
71
|
+
def e_valid?: () -> bool
|
72
|
+
end
|
73
|
+
|
74
|
+
def self.new: (kty: String, crv: String, x: String, y: String, n: String, e: String) -> publicKeyChoice
|
75
|
+
end
|
76
|
+
|
77
|
+
def initialize: (algorithm: uri | String, ?key_id: String?, ?public_key: PublicKey::publicKeyChoice?, ?certificate_path: Array[String]?, ?excludes: Array[String]?, value: String) -> void
|
78
|
+
|
79
|
+
def algorithm: () -> ((uri | String))
|
80
|
+
def algorithm=: (uri | String) -> ((uri | String))
|
81
|
+
def algorithm?: () -> bool
|
82
|
+
def algorithm_valid?: () -> bool
|
83
|
+
|
84
|
+
def key_id: () -> String?
|
85
|
+
def key_id=: (String?) -> String?
|
86
|
+
def key_id?: () -> bool
|
87
|
+
def key_id_valid?: () -> bool
|
88
|
+
|
89
|
+
def public_key: () -> PublicKey::publicKeyChoice?
|
90
|
+
def public_key=: (PublicKey::publicKeyChoice?) -> PublicKey::publicKeyChoice?
|
91
|
+
def public_key?: () -> bool
|
92
|
+
def public_key_valid?: () -> bool
|
93
|
+
|
94
|
+
def certificate_path: () -> Array[String]?
|
95
|
+
def certificate_path=: (Array[String]?) -> Array[String]?
|
96
|
+
def certificate_path?: () -> bool
|
97
|
+
def certificate_path_valid?: () -> bool
|
98
|
+
|
99
|
+
def excludes: () -> Array[String]?
|
100
|
+
def excludes=: (Array[String]?) -> Array[String]?
|
101
|
+
def excludes?: () -> bool
|
102
|
+
def excludes_valid?: () -> bool
|
103
|
+
|
104
|
+
def value: () -> String
|
105
|
+
def value=: (String) -> String
|
106
|
+
def value?: () -> bool
|
107
|
+
def value_valid?: () -> bool
|
108
|
+
end
|
109
|
+
|
110
|
+
class SignatureChain < Base
|
111
|
+
def initialize: (?signatures: Array[JSFSignature]?) -> void
|
112
|
+
|
113
|
+
def signatures: () -> Array[JSFSignature]?
|
114
|
+
def signatures=: (Array[JSFSignature]?) -> Array[JSFSignature]?
|
115
|
+
def signatures?: () -> bool
|
116
|
+
def signatures_valid?: () -> bool
|
117
|
+
end
|
118
|
+
|
119
|
+
class SignerList < Base
|
120
|
+
def initialize: (?signers: Array[JSFSignature]?) -> void
|
121
|
+
|
122
|
+
def signers: () -> Array[JSFSignature]?
|
123
|
+
def signers=: (Array[JSFSignature]?) -> Array[JSFSignature]?
|
124
|
+
def signers?: () -> bool
|
125
|
+
def signers_valid?: () -> bool
|
126
|
+
end
|
127
|
+
end
|
128
|
+
end
|
129
|
+
end
|
130
|
+
end
|
@@ -0,0 +1,132 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class Standard < Base
|
5
|
+
class Level < Base
|
6
|
+
def initialize: (?bom_ref: String?, ?identifier: String?, ?title: String?, ?description: String?, ?requirements: Array[String]?) -> void
|
7
|
+
|
8
|
+
def bom_ref: () -> String?
|
9
|
+
def bom_ref=: (String?) -> String?
|
10
|
+
def bom_ref?: () -> bool
|
11
|
+
def bom_ref_valid?: () -> bool
|
12
|
+
|
13
|
+
def identifier: () -> String?
|
14
|
+
def identifier=: (String?) -> String?
|
15
|
+
def identifier?: () -> bool
|
16
|
+
def identifier_valid?: () -> bool
|
17
|
+
|
18
|
+
def title: () -> String?
|
19
|
+
def title=: (String?) -> String?
|
20
|
+
def title?: () -> bool
|
21
|
+
def title_valid?: () -> bool
|
22
|
+
|
23
|
+
def description: () -> String?
|
24
|
+
def description=: (String?) -> String?
|
25
|
+
def description?: () -> bool
|
26
|
+
def description_valid?: () -> bool
|
27
|
+
|
28
|
+
def requirements: () -> Array[String]?
|
29
|
+
def requirements=: (Array[String]?) -> Array[String]?
|
30
|
+
def requirements?: () -> bool
|
31
|
+
def requirements_valid?: () -> bool
|
32
|
+
end
|
33
|
+
|
34
|
+
class Requirement < Base
|
35
|
+
def initialize: (?bom_ref: String?, ?identifier: String?, ?title: String?, ?text: String?, ?descriptions: Array[String]?, ?open_cre: Array[String]?, ?parent: String?, ?properties: Array[Property]?, ?external_references: Array[ExternalReference]?) -> void
|
36
|
+
|
37
|
+
def bom_ref: () -> String?
|
38
|
+
def bom_ref=: (String?) -> String?
|
39
|
+
def bom_ref?: () -> bool
|
40
|
+
def bom_ref_valid?: () -> bool
|
41
|
+
|
42
|
+
def identifier: () -> String?
|
43
|
+
def identifier=: (String?) -> String?
|
44
|
+
def identifier?: () -> bool
|
45
|
+
def identifier_valid?: () -> bool
|
46
|
+
|
47
|
+
def title: () -> String?
|
48
|
+
def title=: (String?) -> String?
|
49
|
+
def title?: () -> bool
|
50
|
+
def title_valid?: () -> bool
|
51
|
+
|
52
|
+
def text: () -> String?
|
53
|
+
def text=: (String?) -> String?
|
54
|
+
def text?: () -> bool
|
55
|
+
def text_valid?: () -> bool
|
56
|
+
|
57
|
+
def descriptions: () -> Array[String]?
|
58
|
+
def descriptions=: (Array[String]?) -> Array[String]?
|
59
|
+
def descriptions?: () -> bool
|
60
|
+
def descriptions_valid?: () -> bool
|
61
|
+
|
62
|
+
def open_cre: () -> Array[String]?
|
63
|
+
def open_cre=: (Array[String]?) -> Array[String]?
|
64
|
+
def open_cre?: () -> bool
|
65
|
+
def open_cre_valid?: () -> bool
|
66
|
+
|
67
|
+
def parent: () -> String?
|
68
|
+
def parent=: (String?) -> String?
|
69
|
+
def parent?: () -> bool
|
70
|
+
def parent_valid?: () -> bool
|
71
|
+
|
72
|
+
def properties: () -> Array[Property]?
|
73
|
+
def properties=: (Array[Property]?) -> Array[Property]?
|
74
|
+
def properties?: () -> bool
|
75
|
+
def properties_valid?: () -> bool
|
76
|
+
|
77
|
+
def external_references: () -> Array[ExternalReference]?
|
78
|
+
def external_references=: (Array[ExternalReference]?) -> Array[ExternalReference]?
|
79
|
+
def external_references?: () -> bool
|
80
|
+
def external_references_valid?: () -> bool
|
81
|
+
end
|
82
|
+
|
83
|
+
def initialize: (?bom_ref: String?, ?name: String?, ?version: String?, ?description: String?, ?owner: String?, ?requirements: Array[Requirement]?, ?levels: Array[Level]?, ?external_references: Array[ExternalReference]?, ?signature: Signature::signatureChoice?) -> void
|
84
|
+
|
85
|
+
def bom_ref: () -> String?
|
86
|
+
def bom_ref=: (String?) -> String?
|
87
|
+
def bom_ref?: () -> bool
|
88
|
+
def bom_ref_valid?: () -> bool
|
89
|
+
|
90
|
+
def name: () -> String?
|
91
|
+
def name=: (String?) -> String?
|
92
|
+
def name?: () -> bool
|
93
|
+
def name_valid?: () -> bool
|
94
|
+
|
95
|
+
def version: () -> String?
|
96
|
+
def version=: (String?) -> String?
|
97
|
+
def version?: () -> bool
|
98
|
+
def version_valid?: () -> bool
|
99
|
+
|
100
|
+
def description: () -> String?
|
101
|
+
def description=: (String?) -> String?
|
102
|
+
def description?: () -> bool
|
103
|
+
def description_valid?: () -> bool
|
104
|
+
|
105
|
+
def owner: () -> String?
|
106
|
+
def owner=: (String?) -> String?
|
107
|
+
def owner?: () -> bool
|
108
|
+
def owner_valid?: () -> bool
|
109
|
+
|
110
|
+
def requirements: () -> Array[Requirement]?
|
111
|
+
def requirements=: (Array[Requirement]?) -> Array[Requirement]?
|
112
|
+
def requirements?: () -> bool
|
113
|
+
def requirements_valid?: () -> bool
|
114
|
+
|
115
|
+
def levels: () -> Array[Level]?
|
116
|
+
def levels=: (Array[Level]?) -> Array[Level]?
|
117
|
+
def levels?: () -> bool
|
118
|
+
def levels_valid?: () -> bool
|
119
|
+
|
120
|
+
def external_references: () -> Array[ExternalReference]?
|
121
|
+
def external_references=: (Array[ExternalReference]?) -> Array[ExternalReference]?
|
122
|
+
def external_references?: () -> bool
|
123
|
+
def external_references_valid?: () -> bool
|
124
|
+
|
125
|
+
def signature: () -> Signature::signatureChoice?
|
126
|
+
def signature=: (Signature::signatureChoice?) -> Signature::signatureChoice?
|
127
|
+
def signature?: () -> bool
|
128
|
+
def signature_valid?: () -> bool
|
129
|
+
end
|
130
|
+
end
|
131
|
+
end
|
132
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class Step < Base
|
5
|
+
def initialize: (?name: String?, ?description: String?, ?commands: Array[Command]?, ?properties: Array[Property]?) -> void
|
6
|
+
|
7
|
+
def name: () -> String?
|
8
|
+
def name=: (String?) -> String?
|
9
|
+
def name?: () -> bool
|
10
|
+
def name_valid?: () -> bool
|
11
|
+
|
12
|
+
def description: () -> String?
|
13
|
+
def description=: (String?) -> String?
|
14
|
+
def description?: () -> bool
|
15
|
+
def description_valid?: () -> bool
|
16
|
+
|
17
|
+
def commands: () -> Array[Command]?
|
18
|
+
def commands=: (Array[Command]?) -> Array[Command]?
|
19
|
+
def commands?: () -> bool
|
20
|
+
def commands_valid?: () -> bool
|
21
|
+
|
22
|
+
def properties: () -> Array[Property]?
|
23
|
+
def properties=: (Array[Property]?) -> Array[Property]?
|
24
|
+
def properties?: () -> bool
|
25
|
+
def properties_valid?: () -> bool
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class SWID < Base
|
5
|
+
def initialize: (tag_id: String, name: String, ?version: String?, ?tag_version: Integer?, ?patch: bool?, ?text: Attachment?, ?url: uri?) -> void
|
6
|
+
|
7
|
+
def tag_id: () -> String
|
8
|
+
def tag_id=: (String) -> String
|
9
|
+
def tag_id?: () -> bool
|
10
|
+
def tag_id_valid?: () -> bool
|
11
|
+
|
12
|
+
def name: () -> String
|
13
|
+
def name=: (String) -> String
|
14
|
+
def name?: () -> bool
|
15
|
+
def name_valid?: () -> bool
|
16
|
+
|
17
|
+
def version: () -> String?
|
18
|
+
def version=: (String?) -> String?
|
19
|
+
def version?: () -> bool
|
20
|
+
def version_valid?: () -> bool
|
21
|
+
|
22
|
+
def tag_version: () -> Integer?
|
23
|
+
def tag_version=: (Integer?) -> Integer?
|
24
|
+
def tag_version?: () -> bool
|
25
|
+
def tag_version_valid?: () -> bool
|
26
|
+
|
27
|
+
def patch: () -> bool?
|
28
|
+
def patch=: (bool?) -> bool?
|
29
|
+
def patch?: () -> bool
|
30
|
+
def patch_valid?: () -> bool
|
31
|
+
|
32
|
+
def text: () -> Attachment?
|
33
|
+
def text=: (Attachment?) -> Attachment?
|
34
|
+
def text?: () -> bool
|
35
|
+
def text_valid?: () -> bool
|
36
|
+
|
37
|
+
def url: () -> uri?
|
38
|
+
def url=: (uri?) -> uri?
|
39
|
+
def url?: () -> bool
|
40
|
+
def url_valid?: () -> bool
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,84 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class Task < Base
|
5
|
+
def initialize: (bom_ref: String, uid: String, ?name: String?, ?description: String?, ?resource_references: Array[ResourceReferenceChoice]?, ?task_types: Array[String]?, ?trigger: Trigger?, ?steps: Array[Step]?, ?inputs: Array[Input]?, ?outputs: Array[Output]?, ?time_start: dateTime?, ?time_end: dateTime?, ?workspaces: Array[Workspace]?, ?runtime_topology: Array[Dependency]?, ?properties: Array[Property]?) -> void
|
6
|
+
|
7
|
+
def bom_ref: () -> String
|
8
|
+
def bom_ref=: (String) -> String
|
9
|
+
def bom_ref?: () -> bool
|
10
|
+
def bom_ref_valid?: () -> bool
|
11
|
+
|
12
|
+
def uid: () -> String
|
13
|
+
def uid=: (String) -> String
|
14
|
+
def uid?: () -> bool
|
15
|
+
def uid_valid?: () -> bool
|
16
|
+
|
17
|
+
def name: () -> String?
|
18
|
+
def name=: (String?) -> String?
|
19
|
+
def name?: () -> bool
|
20
|
+
def name_valid?: () -> bool
|
21
|
+
|
22
|
+
def description: () -> String?
|
23
|
+
def description=: (String?) -> String?
|
24
|
+
def description?: () -> bool
|
25
|
+
def description_valid?: () -> bool
|
26
|
+
|
27
|
+
def resource_references: () -> Array[ResourceReferenceChoice]?
|
28
|
+
def resource_references=: (Array[ResourceReferenceChoice]?) -> Array[ResourceReferenceChoice]?
|
29
|
+
def resource_references?: () -> bool
|
30
|
+
def resource_references_valid?: () -> bool
|
31
|
+
|
32
|
+
def task_types: () -> Array[String]?
|
33
|
+
def task_types=: (Array[String]?) -> Array[String]?
|
34
|
+
def task_types?: () -> bool
|
35
|
+
def task_types_valid?: () -> bool
|
36
|
+
|
37
|
+
def trigger: () -> Trigger?
|
38
|
+
def trigger=: (Trigger?) -> Trigger?
|
39
|
+
def trigger?: () -> bool
|
40
|
+
def trigger_valid?: () -> bool
|
41
|
+
|
42
|
+
def steps: () -> Array[Step]?
|
43
|
+
def steps=: (Array[Step]?) -> Array[Step]?
|
44
|
+
def steps?: () -> bool
|
45
|
+
def steps_valid?: () -> bool
|
46
|
+
|
47
|
+
def inputs: () -> Array[Input]?
|
48
|
+
def inputs=: (Array[Input]?) -> Array[Input]?
|
49
|
+
def inputs?: () -> bool
|
50
|
+
def inputs_valid?: () -> bool
|
51
|
+
|
52
|
+
def outputs: () -> Array[Output]?
|
53
|
+
def outputs=: (Array[Output]?) -> Array[Output]?
|
54
|
+
def outputs?: () -> bool
|
55
|
+
def outputs_valid?: () -> bool
|
56
|
+
|
57
|
+
def time_start: () -> dateTime?
|
58
|
+
def time_start=: (dateTime?) -> dateTime?
|
59
|
+
def time_start?: () -> bool
|
60
|
+
def time_start_valid?: () -> bool
|
61
|
+
|
62
|
+
def time_end: () -> dateTime?
|
63
|
+
def time_end=: (dateTime?) -> dateTime?
|
64
|
+
def time_end?: () -> bool
|
65
|
+
def time_end_valid?: () -> bool
|
66
|
+
|
67
|
+
def workspaces: () -> Array[Workspace]?
|
68
|
+
def workspaces=: (Array[Workspace]?) -> Array[Workspace]?
|
69
|
+
def workspaces?: () -> bool
|
70
|
+
def workspaces_valid?: () -> bool
|
71
|
+
|
72
|
+
def runtime_topology: () -> Array[Dependency]?
|
73
|
+
def runtime_topology=: (Array[Dependency]?) -> Array[Dependency]?
|
74
|
+
def runtime_topology?: () -> bool
|
75
|
+
def runtime_topology_valid?: () -> bool
|
76
|
+
|
77
|
+
def properties: () -> Array[Property]?
|
78
|
+
def properties=: (Array[Property]?) -> Array[Property]?
|
79
|
+
def properties?: () -> bool
|
80
|
+
def properties_valid?: () -> bool
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
module SBOM
|
2
|
+
module CycloneDX
|
3
|
+
module Record
|
4
|
+
class Tools < Base
|
5
|
+
def initialize: (?components: Array[Component]?, ?services: Array[Service]?) -> void
|
6
|
+
|
7
|
+
def components: () -> Array[Component]?
|
8
|
+
def components=: (Array[Component]?) -> Array[Component]?
|
9
|
+
def components?: () -> bool
|
10
|
+
def components_valid?: () -> bool
|
11
|
+
|
12
|
+
def services: () -> Array[Service]?
|
13
|
+
def services=: (Array[Service]?) -> Array[Service]?
|
14
|
+
def services?: () -> bool
|
15
|
+
def services_valid?: () -> bool
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|