Documentation ¶
Index ¶
- Constants
- Variables
- func BuildSecurityDatabase(ctx context.Context, opts BuildSecurityDatabaseOptions) ([]byte, error)
- func Create(ctx context.Context, req Request, opts CreateOptions) error
- func Discover(ctx context.Context, opts DiscoverOptions) error
- func DiscoverAliases(ctx context.Context, opts DiscoverAliasesOptions) error
- func ExportCSV(opts ExportOptions) (io.Reader, error)
- func ExportOSV(opts ExportOptions, output string) error
- func ExportYAML(opts ExportOptions) (io.Reader, error)
- func ImporAdvisoriesYAML(inputData []byte) (tempDir string, documents *configs.Index[v2.Document], err error)
- func Update(ctx context.Context, req Request, opts UpdateOptions) error
- func Validate(ctx context.Context, opts ValidateOptions) error
- type AliasFinder
- type BuildSecurityDatabaseOptions
- type CreateOptions
- type DataSession
- func (ds *DataSession) Append(ctx context.Context, req Request) error
- func (ds DataSession) Close() error
- func (ds *DataSession) Create(ctx context.Context, req Request) error
- func (ds DataSession) Dir() string
- func (ds DataSession) Index() *configs.Index[v2.Document]
- func (ds DataSession) Modified() bool
- func (ds DataSession) OpenPullRequest(ctx context.Context) (*PullRequest, error)
- func (ds DataSession) Push(ctx context.Context) error
- func (ds *DataSession) Update(ctx context.Context, req Request) error
- type DataSessionOptions
- type DiffResult
- type DiscoverAliasesOptions
- type DiscoverOptions
- type DocumentDiffResult
- type DuplicateAdvisoryIDError
- type EventDiffResult
- type ExportOptions
- type HTTPAliasFinder
- type IndexDiffResult
- type PullRequest
- type Request
- type UpdateOptions
- type ValidateOptions
Constants ¶
const OSVSchema = "https://raw.githubusercontent.com/ossf/osv-schema/main/validation/schema.json"
Variables ¶
var ( ErrNoPackageSecurityData = errors.New("no package security data found") ErrorPackageCollision = errors.New("found multiple advisory documents for the same package") )
Functions ¶
func BuildSecurityDatabase ¶
func BuildSecurityDatabase(ctx context.Context, opts BuildSecurityDatabaseOptions) ([]byte, error)
BuildSecurityDatabase builds an Alpine-style security database from the given options.
func Create ¶
func Create(ctx context.Context, req Request, opts CreateOptions) error
Create creates a new advisory in the `advisories` section of the document at the provided path.
func Discover ¶
func Discover(ctx context.Context, opts DiscoverOptions) error
Discover searches for new vulnerabilities that match packages in a config index, and adds new advisories to configs for vulnerabilities that haven't been noted yet.
func DiscoverAliases ¶
func DiscoverAliases(ctx context.Context, opts DiscoverAliasesOptions) error
DiscoverAliases queries external data sources for aliases for the vulnerabilities described in the selected advisories and updates the advisory documents with the discovered aliases.
func ExportCSV ¶
func ExportCSV(opts ExportOptions) (io.Reader, error)
ExportCSV returns a reader of advisory data encoded as CSV.
func ExportOSV ¶
func ExportOSV(opts ExportOptions, output string) error
func ExportYAML ¶
func ExportYAML(opts ExportOptions) (io.Reader, error)
ExportYAML returns a reader of advisory data encoded as YAML.
func ImporAdvisoriesYAML ¶
func ImporAdvisoriesYAML(inputData []byte) (tempDir string, documents *configs.Index[v2.Document], err error)
ImporAdvisoriesYAML import and yaml Advisories data and present as a config index struct
Types ¶
type AliasFinder ¶
type BuildSecurityDatabaseOptions ¶
type BuildSecurityDatabaseOptions struct { AdvisoryDocIndices []*configs.Index[v2.Document] URLPrefix string Archs []string Repo string }
BuildSecurityDatabaseOptions contains the options for building a database.
type CreateOptions ¶
type CreateOptions struct { // AdvisoryDocs is the Index of advisory documents on which to operate. AdvisoryDocs *configs.Index[v2.Document] }
CreateOptions configures the Create operation.
type DataSession ¶
type DataSession struct {
// contains filtered or unexported fields
}
func NewDataSession ¶
func NewDataSession(ctx context.Context, opts DataSessionOptions) (*DataSession, error)
NewDataSession initializes a new advisory data session for the specified distro and returns a reference to the session. This call will retrieve the data and manage it in a local temp directory until the session is closed. The session should be closed by calling Close() when it is no longer needed.
func (*DataSession) Append ¶
func (ds *DataSession) Append(ctx context.Context, req Request) error
Append creates a new event for an advisory if the advisory already exists, or creates a new advisory with the event if the advisory does not already exist.
func (DataSession) Close ¶
func (ds DataSession) Close() error
Close closes the advisory data session and cleans up any temporary data that was downloaded.
func (*DataSession) Create ¶
func (ds *DataSession) Create(ctx context.Context, req Request) error
Create creates a new advisory within the context of the data session.
func (DataSession) Dir ¶
func (ds DataSession) Dir() string
Dir returns the path to the temporary directory where the session's advisory data is currently stored.
func (DataSession) Index ¶
func (ds DataSession) Index() *configs.Index[v2.Document]
Index returns the index of advisory documents for the session.
func (DataSession) Modified ¶
func (ds DataSession) Modified() bool
Modified returns true if any changes have been made to the advisory data during the session.
func (DataSession) OpenPullRequest ¶
func (ds DataSession) OpenPullRequest(ctx context.Context) (*PullRequest, error)
OpenPullRequest opens a pull request for the changes made during the session.
type DataSessionOptions ¶
type DiffResult ¶
type DiffResult struct { ID string Added v2.Advisory Removed v2.Advisory AddedEvents []v2.Event RemovedEvents []v2.Event }
DiffResult is the result of diffing two advisories.
func (DiffResult) IsZero ¶
func (r DiffResult) IsZero() bool
IsZero returns true if there is no difference between the compared advisories.
type DiscoverAliasesOptions ¶
type DiscoverAliasesOptions struct { // AdvisoryDocs is the Index of advisory documents on which to operate. AdvisoryDocs *configs.Index[v2.Document] // AliasFinder is the alias finder to use for discovering aliases for the given // vulnerabilities. AliasFinder AliasFinder // SelectedPackages is the set of packages to operate on. If empty, all packages // will be operated on. SelectedPackages map[string]struct{} }
DiscoverAliasesOptions is the set of options for the DiscoverAliases function.
type DiscoverOptions ¶
type DiscoverOptions struct { // SelectedPackages is a list of packages to include in search. If empty, all // packages will be included in search. SelectedPackages []string // BuildCfgs is the Index of build configurations on which to operate. BuildCfgs *configs.Index[config.Configuration] // AdvisoryDocs is the Index of advisory documents on which to operate. AdvisoryDocs *configs.Index[v2.Document] // PackageRepositoryURL is the URL to the distro's package repository (e.g. // "https://packages.cvedb.dev/os"). PackageRepositoryURL string // The Arches to select during discovery (e.g. "x86_64"). Arches []string // VulnerabilityDetector is how Discover finds vulnerabilities for packages. VulnerabilityDetector vuln.Detector // VulnEvents is a channel of events that occur during vulnerability discovery. VulnEvents chan<- interface{} }
type DocumentDiffResult ¶
type DocumentDiffResult struct { Name string Added v2.Advisories Removed v2.Advisories Modified []DiffResult }
DocumentDiffResult is the result of diffing two advisory documents.
func (DocumentDiffResult) IsZero ¶
func (r DocumentDiffResult) IsZero() bool
IsZero returns true if there is no difference between the compared advisory documents.
type DuplicateAdvisoryIDError ¶
type DuplicateAdvisoryIDError struct { // Package is the name of the package that already has an advisory with the same // ID. Package string // AdvisoryID is the ID of the advisory that already exists in the document. AdvisoryID string }
DuplicateAdvisoryIDError is returned when an attempt is made to add an advisory with an ID that already exists in the document.
func (DuplicateAdvisoryIDError) Error ¶
func (e DuplicateAdvisoryIDError) Error() string
type ExportOptions ¶
type HTTPAliasFinder ¶
type HTTPAliasFinder struct {
// contains filtered or unexported fields
}
func NewHTTPAliasFinder ¶
func NewHTTPAliasFinder(client *http.Client) *HTTPAliasFinder
func NewHTTPAliasFinderWithToken ¶
func NewHTTPAliasFinderWithToken(client *http.Client, ghToken string) *HTTPAliasFinder
func (*HTTPAliasFinder) CVEForGHSA ¶
func (*HTTPAliasFinder) GHSAsForCVE ¶
type IndexDiffResult ¶
type IndexDiffResult struct { Added []v2.Document Removed []v2.Document Modified []DocumentDiffResult }
IndexDiffResult is the result of diffing two advisory document indexes.
func IndexDiff ¶
func IndexDiff(a, b *configs.Index[v2.Document]) IndexDiffResult
IndexDiff takes two advisory document indexes and returns a diff of the advisory data between them.
func (IndexDiffResult) IsZero ¶
func (r IndexDiffResult) IsZero() bool
IsZero returns true there is no difference between the compared advisory document indexes.
type PullRequest ¶
type PullRequest struct {
URL string
}
type Request ¶
Request specifies the parameters for creating a new advisory or updating an existing advisory.
func (Request) ResolveAliases ¶
ResolveAliases ensures that the request ID is a CVE and that any known GHSA IDs are discovered and stored as Aliases.
type UpdateOptions ¶
type UpdateOptions struct { // AdvisoryDocs is the Index of advisory documents on which to operate. AdvisoryDocs *configs.Index[v2.Document] }
UpdateOptions configures the Update operation.
type ValidateOptions ¶
type ValidateOptions struct { // AdvisoryDocs is the Index of advisories on which to operate. AdvisoryDocs *configs.Index[v2.Document] // BaseAdvisoryDocs is the Index of advisories used as a comparison basis to // understand what is changing in AdvisoryDocs. If nil, no comparison-based // validation will be performed. BaseAdvisoryDocs *configs.Index[v2.Document] // SelectedPackages is the set of packages to operate on. If empty, all packages // will be operated on. SelectedPackages map[string]struct{} // Now is the time to use as the current time for recency validation. Now time.Time // AliasFinder is the alias finder to use for discovering aliases for the given // vulnerabilities. AliasFinder AliasFinder // PackageConfigurations is the index of distro package configurations to use // for validating the advisories. PackageConfigurations *configs.Index[config.Configuration] // APKIndex is the index of APK packages to use for validating the advisories. APKIndex *apk.APKIndex // contains filtered or unexported fields }