2014-12-11 00:32:32 -08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2014-12-12 02:50:47 -08:00
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
2014-12-11 00:32:32 -08:00
|
|
|
"io"
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
|
|
|
|
"github.com/minio-io/minio/pkgs/storage"
|
|
|
|
es "github.com/minio-io/minio/pkgs/storage/encodedstorage"
|
|
|
|
)
|
|
|
|
|
|
|
|
func erasureGetList(config inputConfig) (io.Reader, error) {
|
2014-12-12 02:50:47 -08:00
|
|
|
var objectStorage storage.ObjectStorage
|
|
|
|
rootDir := path.Join(config.rootDir, config.storageDriver)
|
|
|
|
objectStorage, err := es.NewStorage(rootDir, config.k, config.m, config.blockSize)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
objectDescList, err := objectStorage.List()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
var objectDescListBytes []byte
|
|
|
|
if objectDescListBytes, err = json.Marshal(objectDescList); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
objectDescListBuffer := bytes.NewBuffer(objectDescListBytes)
|
|
|
|
|
|
|
|
return objectDescListBuffer, nil
|
2014-12-11 00:32:32 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
func erasureGet(config inputConfig, objectPath string) (io.Reader, error) {
|
|
|
|
var objectStorage storage.ObjectStorage
|
|
|
|
rootDir := path.Join(config.rootDir, config.storageDriver)
|
2014-12-11 22:56:10 -08:00
|
|
|
objectStorage, err := es.NewStorage(rootDir, config.k, config.m, config.blockSize)
|
2014-12-11 00:32:32 -08:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
object, err := objectStorage.Get(objectPath)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return object, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func erasurePut(config inputConfig, objectPath string, reader io.Reader) error {
|
|
|
|
var err error
|
|
|
|
rootDir := path.Join(config.rootDir, config.storageDriver)
|
|
|
|
if err := os.MkdirAll(rootDir, 0700); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
var objectStorage storage.ObjectStorage
|
2014-12-11 22:56:10 -08:00
|
|
|
if objectStorage, err = es.NewStorage(rootDir, config.k, config.m, config.blockSize); err != nil {
|
2014-12-11 00:32:32 -08:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err = objectStorage.Put(objectPath, reader); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|