minio/pkg/storage/donut/erasure/erasure_v1/erasure.go

107 lines
2.4 KiB
Go
Raw Normal View History

/*
* Mini Object Storage, (C) 2015 Minio, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package erasure
2015-03-01 03:27:52 -05:00
2015-03-01 14:32:30 -05:00
import (
"bytes"
"encoding/binary"
"encoding/gob"
"fmt"
2015-03-01 14:32:30 -05:00
"io"
)
2015-03-01 03:27:52 -05:00
2015-03-06 00:09:16 -05:00
// Metadata map
type Metadata map[string]string
2015-03-06 00:09:16 -05:00
// DataHeader struct
2015-03-01 03:27:52 -05:00
type DataHeader struct {
Key string
2015-03-01 17:43:11 -05:00
Part uint8
Metadata Metadata
2015-03-01 03:27:52 -05:00
EncoderParams EncoderParams
}
2015-03-06 00:09:16 -05:00
// EncoderTechnique type
type EncoderTechnique int
2015-03-06 00:09:16 -05:00
// EncoderTechniques
const (
Vandermonde EncoderTechnique = iota
Cauchy
)
2015-03-06 00:09:16 -05:00
// EncoderParams struct
2015-03-01 03:27:52 -05:00
type EncoderParams struct {
2015-03-01 17:43:11 -05:00
Length uint32
K uint8
M uint8
Technique EncoderTechnique
2015-03-01 03:27:52 -05:00
}
2015-03-06 00:09:16 -05:00
// NewHeader populate new header
2015-03-01 17:43:11 -05:00
func NewHeader(key string, part uint8, metadata Metadata, encoderParams EncoderParams) DataHeader {
header := DataHeader{}
header.Key = key
header.Part = part
header.Metadata = metadata
header.EncoderParams = EncoderParams{
Length: encoderParams.Length,
K: encoderParams.K,
M: encoderParams.M,
Technique: encoderParams.Technique,
}
return header
}
2015-03-06 00:09:16 -05:00
// ValidateHeader validate populated header
func ValidateHeader(header DataHeader) bool {
if header.Key == "" || header.Part < 0 || len(header.Metadata) < 2 {
return false
}
if header.EncoderParams.Length < 0 || header.EncoderParams.Technique > 1 {
return false
}
return true
}
2015-03-06 00:09:16 -05:00
// WriteData write data, returns error upon any failure
func WriteData(target io.Writer, header DataHeader, data io.Reader) error {
if !ValidateHeader(header) {
return fmt.Errorf("Invalid header")
}
2015-03-01 14:32:30 -05:00
var headerBuffer bytes.Buffer
// encode header
encoder := gob.NewEncoder(&headerBuffer)
encoder.Encode(header)
2015-03-01 18:13:09 -05:00
// write version
binary.Write(target, binary.LittleEndian, uint32(1))
2015-03-01 14:32:30 -05:00
// write encoded header
if _, err := io.Copy(target, &headerBuffer); err != nil {
return err
}
// write data
if _, err := io.Copy(target, data); err != nil {
return err
}
return nil
2015-03-01 03:27:52 -05:00
}