|
|
|
@ -22,15 +22,24 @@ import (
|
|
|
|
|
"log"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// Storage represents a storage engine for a Release.
|
|
|
|
|
type Storage struct {
|
|
|
|
|
driver.Driver
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get retrieves the release from storage. An error is returned
|
|
|
|
|
// if the storage driver failed to fetch the release, or the
|
|
|
|
|
// release identified by key does not exist.
|
|
|
|
|
func (s *Storage) Get(key string) (*rspb.Release, error) {
|
|
|
|
|
log.Printf("Getting release %q from storage\n", key)
|
|
|
|
|
return s.Driver.Get(key)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Create creates a new storage entry holding the release. An
|
|
|
|
|
// error is returned if the storage driver failed to store the
|
|
|
|
|
// release, or a release with identical an key already exists.
|
|
|
|
|
func (s *Storage) Create(rls *rspb.Release) error {
|
|
|
|
|
log.Printf("storage: create: %q\n", rls.Name)
|
|
|
|
|
log.Printf("Create release %q in storage\n", rls.Name)
|
|
|
|
|
return s.Driver.Create(rls)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -38,17 +47,7 @@ func (s *Storage) Create(rls *rspb.Release) error {
|
|
|
|
|
// storage backend fails to update the release or if the release
|
|
|
|
|
// does not exist.
|
|
|
|
|
func (s *Storage) Update(rls *rspb.Release) error {
|
|
|
|
|
// TODO:
|
|
|
|
|
// 1. Fetch most recent deployed release.
|
|
|
|
|
// 2. If it exists:
|
|
|
|
|
// - Then mark as 'SUPERSEDED'
|
|
|
|
|
// - Then store both new and old.
|
|
|
|
|
// 3. Else:
|
|
|
|
|
// - Create(rls)
|
|
|
|
|
log.Printf("storage: update: %q\n", rls.Name)
|
|
|
|
|
|
|
|
|
|
// fetch most recent deployed release
|
|
|
|
|
// old, err := s.Get(rls.Name)
|
|
|
|
|
log.Printf("Updating %q in storage\n", rls.Name)
|
|
|
|
|
return s.Driver.Update(rls)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -56,22 +55,21 @@ func (s *Storage) Update(rls *rspb.Release) error {
|
|
|
|
|
// the storage backend fails to delete the release or if the release
|
|
|
|
|
// does not exist.
|
|
|
|
|
func (s *Storage) Delete(key string) (*rspb.Release, error) {
|
|
|
|
|
// TODO: Mark the release as DELETED.
|
|
|
|
|
log.Printf("storage: delete: %q\n", key)
|
|
|
|
|
log.Printf("Deleting release %q from storage\n", key)
|
|
|
|
|
return s.Driver.Delete(key)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListReleases returns all releases from storage. An error is returned if the
|
|
|
|
|
// storage backend fails to retrieve the releases.
|
|
|
|
|
func (s *Storage) ListReleases() ([]*rspb.Release, error) {
|
|
|
|
|
log.Println("storage: list all releases")
|
|
|
|
|
log.Println("Listing all releases in storage")
|
|
|
|
|
return s.Driver.List(func(_ *rspb.Release) bool { return true })
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListDeleted returns all releases with Status == DELETED. An error is returned
|
|
|
|
|
// if the storage backend fails to retrieve the releases.
|
|
|
|
|
func (s *Storage) ListDeleted() ([]*rspb.Release, error) {
|
|
|
|
|
log.Println("storage: list deleted releases")
|
|
|
|
|
log.Println("List deleted releases in storage")
|
|
|
|
|
return s.Driver.List(func(rls *rspb.Release) bool {
|
|
|
|
|
return StatusFilter(rspb.Status_DELETED).Check(rls)
|
|
|
|
|
})
|
|
|
|
@ -80,7 +78,7 @@ func (s *Storage) ListDeleted() ([]*rspb.Release, error) {
|
|
|
|
|
// ListDeployed returns all releases with Status == DEPLOYED. An error is returned
|
|
|
|
|
// if the storage backend fails to retrieve the releases.
|
|
|
|
|
func (s *Storage) ListDeployed() ([]*rspb.Release, error) {
|
|
|
|
|
log.Println("storage: list deployed releases")
|
|
|
|
|
log.Println("Listing all deployed releases in storage")
|
|
|
|
|
return s.Driver.List(func(rls *rspb.Release) bool {
|
|
|
|
|
return StatusFilter(rspb.Status_DEPLOYED).Check(rls)
|
|
|
|
|
})
|
|
|
|
@ -90,7 +88,7 @@ func (s *Storage) ListDeployed() ([]*rspb.Release, error) {
|
|
|
|
|
// (filter0 && filter1 && ... && filterN), i.e. a Release is included in the results
|
|
|
|
|
// if and only if all filters return true.
|
|
|
|
|
func (s *Storage) ListFilterAll(filters ...FilterFunc) ([]*rspb.Release, error) {
|
|
|
|
|
log.Println("storage: list all releases with filter")
|
|
|
|
|
log.Println("Listing all releases with filter")
|
|
|
|
|
return s.Driver.List(func(rls *rspb.Release) bool {
|
|
|
|
|
return All(filters...).Check(rls)
|
|
|
|
|
})
|
|
|
|
@ -100,12 +98,14 @@ func (s *Storage) ListFilterAll(filters ...FilterFunc) ([]*rspb.Release, error)
|
|
|
|
|
// (filter0 || filter1 || ... || filterN), i.e. a Release is included in the results
|
|
|
|
|
// if at least one of the filters returns true.
|
|
|
|
|
func (s *Storage) ListFilterAny(filters ...FilterFunc) ([]*rspb.Release, error) {
|
|
|
|
|
log.Println("storage: list any releases with filter")
|
|
|
|
|
log.Println("Listing any releases with filter")
|
|
|
|
|
return s.Driver.List(func(rls *rspb.Release) bool {
|
|
|
|
|
return Any(filters...).Check(rls)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Init initializes a new storage backend with the driver d.
|
|
|
|
|
// If d is nil, the default in-memory driver is used.
|
|
|
|
|
func Init(d driver.Driver) *Storage {
|
|
|
|
|
if d == nil {
|
|
|
|
|
d = driver.NewMemory()
|
|
|
|
|