update
This commit is contained in:
parent
0731df972c
commit
2d1ac2c4d5
@ -32,72 +32,47 @@ import (
|
|||||||
"github.com/coreos/clair/pkg/pagination"
|
"github.com/coreos/clair/pkg/pagination"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// Enforce the interface at compile time.
|
||||||
|
var _ database.Session = &pgSession{}
|
||||||
|
|
||||||
type pgSession struct {
|
type pgSession struct {
|
||||||
*sql.Tx
|
*sql.Tx
|
||||||
|
|
||||||
key pagination.Key
|
key pagination.Key
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *pgSession) Commit() error {
|
|
||||||
return tx.Tx.Commit()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Rollback drops changes to datastore.
|
|
||||||
//
|
|
||||||
// Rollback call after Commit does no-op.
|
|
||||||
func (tx *pgSession) Rollback() error {
|
|
||||||
return tx.Tx.Rollback()
|
|
||||||
}
|
|
||||||
|
|
||||||
// UpsertAncestry inserts or replaces an ancestry and its namespaced
|
|
||||||
// features and processors used to scan the ancestry.
|
|
||||||
func (tx *pgSession) UpsertAncestry(a database.Ancestry) error {
|
func (tx *pgSession) UpsertAncestry(a database.Ancestry) error {
|
||||||
return ancestry.UpsertAncestry(tx.Tx, a)
|
return ancestry.UpsertAncestry(tx.Tx, a)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FindAncestry retrieves an ancestry with all detected
|
|
||||||
// namespaced features. If the ancestry is not found, return false.
|
|
||||||
func (tx *pgSession) FindAncestry(name string) (database.Ancestry, bool, error) {
|
func (tx *pgSession) FindAncestry(name string) (database.Ancestry, bool, error) {
|
||||||
return ancestry.FindAncestry(tx.Tx, name)
|
return ancestry.FindAncestry(tx.Tx, name)
|
||||||
}
|
}
|
||||||
|
|
||||||
// PersistDetector inserts a slice of detectors if not in the database.
|
|
||||||
func (tx *pgSession) PersistDetectors(detectors []database.Detector) error {
|
func (tx *pgSession) PersistDetectors(detectors []database.Detector) error {
|
||||||
return detector.PersistDetectors(tx.Tx, detectors)
|
return detector.PersistDetectors(tx.Tx, detectors)
|
||||||
}
|
}
|
||||||
|
|
||||||
// PersistFeatures inserts a set of features if not in the database.
|
|
||||||
func (tx *pgSession) PersistFeatures(features []database.Feature) error {
|
func (tx *pgSession) PersistFeatures(features []database.Feature) error {
|
||||||
return feature.PersistFeatures(tx.Tx, features)
|
return feature.PersistFeatures(tx.Tx, features)
|
||||||
}
|
}
|
||||||
|
|
||||||
// PersistNamespacedFeatures inserts a set of namespaced features if not in
|
|
||||||
// the database.
|
|
||||||
func (tx *pgSession) PersistNamespacedFeatures(features []database.NamespacedFeature) error {
|
func (tx *pgSession) PersistNamespacedFeatures(features []database.NamespacedFeature) error {
|
||||||
return feature.PersistNamespacedFeatures(tx.Tx, features)
|
return feature.PersistNamespacedFeatures(tx.Tx, features)
|
||||||
}
|
}
|
||||||
|
|
||||||
// CacheAffectedNamespacedFeatures relates the namespaced features with the
|
|
||||||
// vulnerabilities affecting these features.
|
|
||||||
//
|
|
||||||
// NOTE(Sida): it's not necessary for every database implementation and so
|
|
||||||
// this function may have a better home.
|
|
||||||
func (tx *pgSession) CacheAffectedNamespacedFeatures(features []database.NamespacedFeature) error {
|
func (tx *pgSession) CacheAffectedNamespacedFeatures(features []database.NamespacedFeature) error {
|
||||||
return vulnerability.CacheAffectedNamespacedFeatures(tx.Tx, features)
|
return vulnerability.CacheAffectedNamespacedFeatures(tx.Tx, features)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FindAffectedNamespacedFeatures retrieves a set of namespaced features
|
|
||||||
// with affecting vulnerabilities.
|
|
||||||
func (tx *pgSession) FindAffectedNamespacedFeatures(features []database.NamespacedFeature) ([]database.NullableAffectedNamespacedFeature, error) {
|
func (tx *pgSession) FindAffectedNamespacedFeatures(features []database.NamespacedFeature) ([]database.NullableAffectedNamespacedFeature, error) {
|
||||||
return vulnerability.FindAffectedNamespacedFeatures(tx.Tx, features)
|
return vulnerability.FindAffectedNamespacedFeatures(tx.Tx, features)
|
||||||
}
|
}
|
||||||
|
|
||||||
// PersistNamespaces inserts a set of namespaces if not in the database.
|
|
||||||
func (tx *pgSession) PersistNamespaces(namespaces []database.Namespace) error {
|
func (tx *pgSession) PersistNamespaces(namespaces []database.Namespace) error {
|
||||||
return namespace.PersistNamespaces(tx.Tx, namespaces)
|
return namespace.PersistNamespaces(tx.Tx, namespaces)
|
||||||
}
|
}
|
||||||
|
|
||||||
// PersistLayer appends a layer's content in the database.
|
|
||||||
func (tx *pgSession) PersistLayer(hash string, features []database.LayerFeature, namespaces []database.LayerNamespace, detectedBy []database.Detector) error {
|
func (tx *pgSession) PersistLayer(hash string, features []database.LayerFeature, namespaces []database.LayerNamespace, detectedBy []database.Detector) error {
|
||||||
return layer.PersistLayer(tx.Tx, hash, features, namespaces, detectedBy)
|
return layer.PersistLayer(tx.Tx, hash, features, namespaces, detectedBy)
|
||||||
}
|
}
|
||||||
@ -106,28 +81,18 @@ func (tx *pgSession) FindLayer(hash string) (database.Layer, bool, error) {
|
|||||||
return layer.FindLayer(tx.Tx, hash)
|
return layer.FindLayer(tx.Tx, hash)
|
||||||
}
|
}
|
||||||
|
|
||||||
// InsertVulnerabilities inserts a set of UNIQUE vulnerabilities with
|
|
||||||
// affected features into database, assuming that all vulnerabilities
|
|
||||||
// provided are NOT in database and all vulnerabilities' namespaces are
|
|
||||||
// already in the database.
|
|
||||||
func (tx *pgSession) InsertVulnerabilities(vulns []database.VulnerabilityWithAffected) error {
|
func (tx *pgSession) InsertVulnerabilities(vulns []database.VulnerabilityWithAffected) error {
|
||||||
return vulnerability.InsertVulnerabilities(tx.Tx, vulns)
|
return vulnerability.InsertVulnerabilities(tx.Tx, vulns)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FindVulnerability retrieves a set of Vulnerabilities with affected
|
|
||||||
// features.
|
|
||||||
func (tx *pgSession) FindVulnerabilities(ids []database.VulnerabilityID) ([]database.NullableVulnerability, error) {
|
func (tx *pgSession) FindVulnerabilities(ids []database.VulnerabilityID) ([]database.NullableVulnerability, error) {
|
||||||
return vulnerability.FindVulnerabilities(tx.Tx, ids)
|
return vulnerability.FindVulnerabilities(tx.Tx, ids)
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeleteVulnerability removes a set of Vulnerabilities assuming that the
|
|
||||||
// requested vulnerabilities are in the database.
|
|
||||||
func (tx *pgSession) DeleteVulnerabilities(ids []database.VulnerabilityID) error {
|
func (tx *pgSession) DeleteVulnerabilities(ids []database.VulnerabilityID) error {
|
||||||
return vulnerability.DeleteVulnerabilities(tx.Tx, ids)
|
return vulnerability.DeleteVulnerabilities(tx.Tx, ids)
|
||||||
}
|
}
|
||||||
|
|
||||||
// InsertVulnerabilityNotifications inserts a set of unique vulnerability
|
|
||||||
// notifications into datastore, assuming that they are not in the database.
|
|
||||||
func (tx *pgSession) InsertVulnerabilityNotifications(notifications []database.VulnerabilityNotification) error {
|
func (tx *pgSession) InsertVulnerabilityNotifications(notifications []database.VulnerabilityNotification) error {
|
||||||
return notification.InsertVulnerabilityNotifications(tx.Tx, notifications)
|
return notification.InsertVulnerabilityNotifications(tx.Tx, notifications)
|
||||||
}
|
}
|
||||||
@ -140,46 +105,30 @@ func (tx *pgSession) FindVulnerabilityNotification(name string, limit int, oldVu
|
|||||||
return notification.FindVulnerabilityNotification(tx.Tx, name, limit, oldVulnerabilityPage, newVulnerabilityPage, tx.key)
|
return notification.FindVulnerabilityNotification(tx.Tx, name, limit, oldVulnerabilityPage, newVulnerabilityPage, tx.key)
|
||||||
}
|
}
|
||||||
|
|
||||||
// MarkNotificationAsRead marks a Notification as notified now, assuming
|
|
||||||
// the requested notification is in the database.
|
|
||||||
func (tx *pgSession) MarkNotificationAsRead(name string) error {
|
func (tx *pgSession) MarkNotificationAsRead(name string) error {
|
||||||
return notification.MarkNotificationAsRead(tx.Tx, name)
|
return notification.MarkNotificationAsRead(tx.Tx, name)
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeleteNotification removes a Notification in the database.
|
|
||||||
func (tx *pgSession) DeleteNotification(name string) error {
|
func (tx *pgSession) DeleteNotification(name string) error {
|
||||||
return notification.DeleteNotification(tx.Tx, name)
|
return notification.DeleteNotification(tx.Tx, name)
|
||||||
}
|
}
|
||||||
|
|
||||||
// UpdateKeyValue stores or updates a simple key/value pair.
|
|
||||||
func (tx *pgSession) UpdateKeyValue(key, value string) error {
|
func (tx *pgSession) UpdateKeyValue(key, value string) error {
|
||||||
return keyvalue.UpdateKeyValue(tx.Tx, key, value)
|
return keyvalue.UpdateKeyValue(tx.Tx, key, value)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FindKeyValue retrieves a value from the given key.
|
|
||||||
func (tx *pgSession) FindKeyValue(key string) (value string, found bool, err error) {
|
func (tx *pgSession) FindKeyValue(key string) (value string, found bool, err error) {
|
||||||
return keyvalue.FindKeyValue(tx.Tx, key)
|
return keyvalue.FindKeyValue(tx.Tx, key)
|
||||||
}
|
}
|
||||||
|
|
||||||
// AcquireLock acquires a brand new lock in the database with a given name
|
|
||||||
// for the given duration.
|
|
||||||
//
|
|
||||||
// A lock can only have one owner.
|
|
||||||
// This method should NOT block until a lock is acquired.
|
|
||||||
func (tx *pgSession) AcquireLock(name, owner string, duration time.Duration) (acquired bool, expiration time.Time, err error) {
|
func (tx *pgSession) AcquireLock(name, owner string, duration time.Duration) (acquired bool, expiration time.Time, err error) {
|
||||||
return lock.AcquireLock(tx.Tx, name, owner, duration)
|
return lock.AcquireLock(tx.Tx, name, owner, duration)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ExtendLock extends an existing lock such that the lock will expire at the
|
|
||||||
// current time plus the provided duration.
|
|
||||||
//
|
|
||||||
// This method should return immediately with an error if the lock does not
|
|
||||||
// exist.
|
|
||||||
func (tx *pgSession) ExtendLock(name, owner string, duration time.Duration) (extended bool, expiration time.Time, err error) {
|
func (tx *pgSession) ExtendLock(name, owner string, duration time.Duration) (extended bool, expiration time.Time, err error) {
|
||||||
return lock.ExtendLock(tx.Tx, name, owner, duration)
|
return lock.ExtendLock(tx.Tx, name, owner, duration)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ReleaseLock releases an existing lock.
|
|
||||||
func (tx *pgSession) ReleaseLock(name, owner string) error {
|
func (tx *pgSession) ReleaseLock(name, owner string) error {
|
||||||
return lock.ReleaseLock(tx.Tx, name, owner)
|
return lock.ReleaseLock(tx.Tx, name, owner)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user