Skip to content

Commit

Permalink
feat: allow processing CDX 1.6
Browse files Browse the repository at this point in the history
  • Loading branch information
ctron committed Dec 5, 2024
1 parent 464de8e commit cae7c74
Show file tree
Hide file tree
Showing 32 changed files with 267 additions and 118 deletions.
70 changes: 67 additions & 3 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,6 @@ criterion = "0.5.1"
csaf = { version = "0.5.0", default-features = false }
csaf-walker = { version = "0.10.0", default-features = false }
cve = "0.3.1"
cyclonedx-bom = "0.8.0"
env_logger = "0.11.0"
futures = "0.3.30"
futures-util = "0.3"
Expand Down Expand Up @@ -115,6 +114,7 @@ sea-orm-migration = "1"
sea-query = "0.32.0"
semver = "1"
serde = "1.0.183"
serde-cyclonedx = "0.9.1"
serde_json = "1.0.114"
serde_with = "3.11.0"
serde_yml = "0.0.12"
Expand Down
2 changes: 1 addition & 1 deletion entity/src/sbom.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ pub struct Model {
pub sbom_id: Uuid,
pub node_id: String,

pub document_id: String,
pub document_id: Option<String>,

pub published: Option<OffsetDateTime>,
pub authors: Vec<String>,
Expand Down
2 changes: 2 additions & 0 deletions migration/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,7 @@ mod m0000720_alter_sbom_fix_null_array;
mod m0000730_alter_importer_add_progress;
mod m0000740_ensure_get_purl_fns;
mod m0000750_alter_advisory_add_document_id;
mod m0000760_alter_sbom_alter_document_id;

pub struct Migrator;

Expand Down Expand Up @@ -193,6 +194,7 @@ impl MigratorTrait for Migrator {
Box::new(m0000730_alter_importer_add_progress::Migration),
Box::new(m0000740_ensure_get_purl_fns::Migration),
Box::new(m0000750_alter_advisory_add_document_id::Migration),
Box::new(m0000760_alter_sbom_alter_document_id::Migration),
]
}
}
Expand Down
55 changes: 55 additions & 0 deletions migration/src/m0000760_alter_sbom_alter_document_id.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
use sea_orm_migration::prelude::*;

#[derive(DeriveMigrationName)]
pub struct Migration;

#[async_trait::async_trait]
impl MigrationTrait for Migration {
async fn up(&self, manager: &SchemaManager) -> Result<(), DbErr> {
// modify, allow null

manager
.alter_table(
Table::alter()
.table(Sbom::Table)
.modify_column(ColumnDef::new(Sbom::DocumentId).string().null().to_owned())
.to_owned(),
)
.await?;

// bring back the null value, or consider it null if we already did not have a real value

manager
.get_connection()
.execute_unprepared(r#"UPDATE sbom SET document_id = NULL where document_id=''"#)
.await?;

Ok(())
}

async fn down(&self, manager: &SchemaManager) -> Result<(), DbErr> {
// set an empty string, works and is required

manager
.get_connection()
.execute_unprepared(r#"UPDATE sbom SET document_id = '' where document_id IS NULL"#)
.await?;

manager
.alter_table(
Table::alter()
.table(Sbom::Table)
.modify_column(ColumnDef::new(Sbom::DocumentId).string().not_null())
.to_owned(),
)
.await?;

Ok(())
}
}

#[derive(DeriveIden)]
enum Sbom {
Table,
DocumentId,
}
1 change: 0 additions & 1 deletion modules/analysis/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@ actix-http = { workspace = true }
bytes = { workspace = true }
bytesize = { workspace = true }
chrono = { workspace = true }
cyclonedx-bom = { workspace = true }
hex = { workspace = true }
humantime = { workspace = true }
jsonpath-rust = { workspace = true }
Expand Down
4 changes: 2 additions & 2 deletions modules/fundamental/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,6 @@ chrono = { workspace = true }
criterion = { workspace = true, features = ["html_reports", "async_tokio"] }
csaf = { workspace = true }
cve = { workspace = true }
cyclonedx-bom = { workspace = true }
hex = { workspace = true }
humantime = { workspace = true }
jsonpath-rust = { workspace = true }
Expand All @@ -58,11 +57,13 @@ packageurl = { workspace = true }
regex = { workspace = true }
roxmltree = { workspace = true }
semver = { workspace = true }
serde-cyclonedx = { workspace = true }
serde_json = { workspace = true }
serde_yml = { workspace = true }
sha2 = { workspace = true }
spdx-rs = { workspace = true }
strum = { workspace = true }
termimad = "0.31.0"
test-context = { workspace = true }
test-log = { workspace = true, features = ["log", "trace"] }
tokio-util = { workspace = true }
Expand All @@ -71,7 +72,6 @@ trustify-test-context = { workspace = true }
urlencoding = { workspace = true }
walkdir = { workspace = true }
zip = { workspace = true }
termimad = "0.31.0"

[[bench]]
name = "bench"
Expand Down
14 changes: 10 additions & 4 deletions modules/fundamental/src/advisory/endpoints/test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -349,7 +349,10 @@ async fn upload_default_csaf_format(ctx: &TrustifyContext) -> Result<(), anyhow:
let result: IngestResult = app.call_and_read_body_json(request).await;
log::debug!("{result:?}");
assert!(matches!(result.id, Id::Uuid(_)));
assert_eq!(result.document_id, "https://www.redhat.com/#CVE-2023-33201");
assert_eq!(
result.document_id,
Some("https://www.redhat.com/#CVE-2023-33201".to_string())
);

Ok(())
}
Expand Down Expand Up @@ -407,7 +410,7 @@ async fn upload_osv_format(ctx: &TrustifyContext) -> Result<(), anyhow::Error> {

let result: IngestResult = app.call_and_read_body_json(request).await;
assert!(matches!(result.id, Id::Uuid(_)));
assert_eq!(result.document_id, "RUSTSEC-2021-0079");
assert_eq!(result.document_id, Some("RUSTSEC-2021-0079".to_string()));

Ok(())
}
Expand All @@ -426,7 +429,7 @@ async fn upload_cve_format(ctx: &TrustifyContext) -> Result<(), anyhow::Error> {

let result: IngestResult = app.call_and_read_body_json(request).await;
assert!(matches!(result.id, Id::Uuid(_)));
assert_eq!(result.document_id, "CVE-2024-27088");
assert_eq!(result.document_id, Some("CVE-2024-27088".to_string()));

Ok(())
}
Expand Down Expand Up @@ -466,7 +469,10 @@ async fn upload_with_labels(ctx: &TrustifyContext) -> Result<(), anyhow::Error>
let result: IngestResult = app.call_and_read_body_json(request).await;
log::debug!("{result:?}");
assert!(matches!(result.id, Id::Uuid(_)));
assert_eq!(result.document_id, "https://www.redhat.com/#CVE-2023-33201");
assert_eq!(
result.document_id,
Some("https://www.redhat.com/#CVE-2023-33201".to_string())
);

// now check the labels

Expand Down
2 changes: 1 addition & 1 deletion modules/fundamental/src/ai/service/test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ pub async fn ingest_fixtures(ctx: &TrustifyContext) -> Result<(), anyhow::Error>
.ingest_sbom(
("source", "http://redhat.com/test.json"),
&Digests::digest("RHSA-1"),
"a",
Some("a".to_string()),
(),
&ctx.db,
)
Expand Down
4 changes: 2 additions & 2 deletions modules/fundamental/src/product/service/test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ async fn all_products(ctx: &TrustifyContext) -> Result<(), anyhow::Error> {
.ingest_sbom(
("source", "http://redhat.com/test.json"),
&Digests::digest("RHSA-1"),
"a",
Some("a".to_string()),
(),
&ctx.db,
)
Expand Down Expand Up @@ -77,7 +77,7 @@ async fn link_sbom_to_product(ctx: &TrustifyContext) -> Result<(), anyhow::Error
.ingest_sbom(
("source", "http://redhat.com/test.json"),
&Digests::digest("RHSA-1"),
"a",
Some("a".to_string()),
(),
&ctx.db,
)
Expand Down
2 changes: 1 addition & 1 deletion modules/fundamental/src/sbom/model/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ pub struct SbomHead {
#[schema(value_type=String)]
pub id: Uuid,

pub document_id: String,
pub document_id: Option<String>,
pub labels: Labels,
pub data_licenses: Vec<String>,

Expand Down
Loading

0 comments on commit cae7c74

Please sign in to comment.