1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
|
// Copyright 2014 Canonical Ltd.
// Licensed under the LGPLv3, see LICENCE file for details.
package filestorage
import (
"github.com/juju/errors"
)
// Convert turns a Document into a Metadata if possible.
func Convert(doc Document) (Metadata, error) {
meta, ok := doc.(Metadata)
if !ok {
return nil, errors.Errorf("expected a Metadata doc, got %v", doc)
}
return meta, nil
}
// MetadataDocStorage provides the MetadataStorage methods than can be
// derived from DocStorage methods. To fully implement MetadataStorage,
// this type must be embedded in a type that implements the remaining
// methods.
type MetadataDocStorage struct {
DocStorage
}
// Metadata implements MetadataStorage.Metadata.
func (s *MetadataDocStorage) Metadata(id string) (Metadata, error) {
doc, err := s.Doc(id)
if err != nil {
return nil, errors.Trace(err)
}
meta, err := Convert(doc)
return meta, errors.Trace(err)
}
// ListMetadata implements MetadataStorage.ListMetadata.
func (s *MetadataDocStorage) ListMetadata() ([]Metadata, error) {
docs, err := s.ListDocs()
if err != nil {
return nil, errors.Trace(err)
}
var metaList []Metadata
for _, doc := range docs {
if doc == nil {
continue
}
meta, err := Convert(doc)
if err != nil {
return nil, errors.Trace(err)
}
metaList = append(metaList, meta)
}
return metaList, nil
}
// ListMetadata implements MetadataStorage.ListMetadata.
func (s *MetadataDocStorage) AddMetadata(meta Metadata) (string, error) {
id, err := s.AddDoc(meta)
return id, errors.Trace(err)
}
// ListMetadata implements MetadataStorage.ListMetadata.
func (s *MetadataDocStorage) RemoveMetadata(id string) error {
return errors.Trace(s.RemoveDoc(id))
}
|