How GUAC components work together

Table of contents

The full GUAC component deployment is a set of asynchronous services that combine to form a robust and scalable pipeline. In some of our demos, you may have seen these components work in concert. Read on to learn more of what goes on behind the hood!

GUAC Components

Guac Diagram

GraphQL Server

The GraphQL server serves the GUAC defined nodes through GraphQL queries. It is an abstraction layer for GUAC integrations and other GUAC components. Our setup docs use the built-in, in-memory backend for the server. Currently the server also supports a Neo4j backend. Any future backend database support added to GUAC will not affect the GraphQL interface that the server provides.

Ingestion Pipeline

Name Short Description
Collector Reads or watches locations for new documents and collects them when found
Ingestor Takes documents (ex: SBOMs) and parses them into the GUAC data model/ontology
Assembler Takes GUAC objects and puts them in a datastore, queryable by the GraphQL server
CollectSub Takes identifiers of interest and creates a subscription for collectors to follow

Collectors

Collectors gather data from various sources. These sources can be internal to the organization, public (like open source), or third-party vendors. There are different collectors for the different types of locations that GUAC can watch (files, storage buckets, Git repositories, etc.).

Collectors can be configured to use a CollectSub service to know which data sources are of interest. For example, a Git collector may subscribe to the CollectSub service to know which Git repositories it should get its data from. This is a way to get an idea of what data sources the instance of GUAC is looking at, at a glance.

Collectors and certifiers then take the documents and pass them onto the ingestor via Nats.

Certifiers

Another class of GUAC collector components are certifiers. Certifiers run outside the server, but are not part of the ingestion pipeline. They watch the server for new nodes in the server and add additional information attached to those nodes.

For example, the OSV certifier will watch GUAC for new packages, then try to discover OSV vulnerabilities for those packages. If any vulnerabilities are found, the certifier will attach a “CertifyVuln” node to the package to signify that the package is connected to the OSV vulnerability.

Ingestor

Ingestors take in documents and parse them into the GUAC data model/ontology. This process extracts meaning from documents and translates them into a common reasoning model (GUAC ontology). In the process, it also finds identifiers of interest that it passes to the CollectSub service to request additional information for.

Today, GUAC can understand multiple data formats like SPDX, CycloneDX, and SLSA. The ingestor listens for documents to parse via NATS, and talks to the assembler via a GraphQL API.

Assembler

The assembler takes the parsed GUAC ontology objects from the ingestor and creates entries within a database. This database is used as a source of truth for GUAC queries.

The assembler exposes a set of GraphQL mutate interfaces. The assembler is physically part of the GraphQL server, but logically part of ingestion.

CollectSub

The collect subscriber service provides a way to ask for a datasource to be used or indicate that more data about a software identifier is desired. For example, in parsing an SBOM, if it sees the use of a package with a pURL, the ingestor creates an entry to the CollectSub service to indicate more information about the pURL is desired (via gRPC).

The collectors all subscribe to this service and will automatically retrieve more information about the pURL (or other identifier/datasource) if they know how to handle it. For example, the deps.dev collector knows how to handle pURLs and retrieves more information about the pURL entries created from the ingestor parsing the SBOM.