Runtime library to serialize/deserialize CycloneDX BOM with protocol buffers. The project was generated using protoc-gen-es from the official proto specification.
import { cdx_16, cdx_17 } from "@appthreat/cdx-proto";
import {
fromBinary,
fromJsonString,
toBinary,
toJson,
} from "@bufbuild/protobuf";
// Create .proto files
let bomSchema =
+bomJson.specVersion === 1.6 ? cdx_16.BomSchema : cdx_17.BomSchema;
writeFileSync(
binFile,
toBinary(
bomSchema,
fromJsonString(bomSchema, stringifyIfNeeded(bomJson), {
ignoreUnknownFields: true,
}),
),
{
writeUnknownFields: true,
},
);
// Read .proto files
const bomObject = fromBinary(bomSchema, readFileSync(binFile), {
readUnknownFields: true,
});
const jsonstr = toJson(bomSchema, bomObject, { emitDefaultValues: true });Apache-2.0