|
|
|
/*
|
|
|
|
* MinIO Cloud Storage, (C) 2016-2020 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 cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
//go:generate msgp -file=$GOFILE
|
|
|
|
|
|
|
|
// DiskInfo is an extended type which returns current
|
|
|
|
// disk usage per path.
|
|
|
|
//msgp:tuple DiskInfo
|
|
|
|
// The above means that any added/deleted fields are incompatible.
|
|
|
|
type DiskInfo struct {
|
|
|
|
Total uint64
|
|
|
|
Free uint64
|
|
|
|
Used uint64
|
|
|
|
UsedInodes uint64
|
|
|
|
FSType string
|
|
|
|
RootDisk bool
|
|
|
|
Healing bool
|
|
|
|
Endpoint string
|
|
|
|
MountPath string
|
|
|
|
ID string
|
|
|
|
Error string // carries the error over the network
|
|
|
|
}
|
|
|
|
|
|
|
|
// VolsInfo is a collection of volume(bucket) information
|
|
|
|
type VolsInfo []VolInfo
|
|
|
|
|
|
|
|
// VolInfo - represents volume stat information.
|
|
|
|
//msgp:tuple VolInfo
|
|
|
|
// The above means that any added/deleted fields are incompatible.
|
|
|
|
type VolInfo struct {
|
|
|
|
// Name of the volume.
|
|
|
|
Name string
|
|
|
|
|
|
|
|
// Date and time when the volume was created.
|
|
|
|
Created time.Time
|
|
|
|
}
|
|
|
|
|
|
|
|
// FilesInfo represent a list of files, additionally
|
|
|
|
// indicates if the list is last.
|
|
|
|
type FilesInfo struct {
|
|
|
|
Files []FileInfo
|
|
|
|
IsTruncated bool
|
|
|
|
}
|
|
|
|
|
|
|
|
// FilesInfoVersions represents a list of file versions,
|
|
|
|
// additionally indicates if the list is last.
|
|
|
|
type FilesInfoVersions struct {
|
|
|
|
FilesVersions []FileInfoVersions
|
|
|
|
IsTruncated bool
|
|
|
|
}
|
|
|
|
|
|
|
|
// FileInfoVersions represent a list of versions for a given file.
|
|
|
|
type FileInfoVersions struct {
|
|
|
|
// Name of the volume.
|
|
|
|
Volume string
|
|
|
|
|
|
|
|
// Name of the file.
|
|
|
|
Name string
|
|
|
|
|
|
|
|
// Represents the latest mod time of the
|
|
|
|
// latest version.
|
|
|
|
LatestModTime time.Time
|
|
|
|
|
|
|
|
Versions []FileInfo
|
|
|
|
}
|
|
|
|
|
|
|
|
// forwardPastVersion will truncate the result to only contain versions after 'v'.
|
|
|
|
// If v is empty or the version isn't found no changes will be made.
|
|
|
|
func (f *FileInfoVersions) forwardPastVersion(v string) {
|
|
|
|
if v == "" {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
for i, ver := range f.Versions {
|
|
|
|
if ver.VersionID == v {
|
|
|
|
f.Versions = f.Versions[i+1:]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// FileInfo - represents file stat information.
|
|
|
|
//msgp:tuple FileInfo
|
|
|
|
// The above means that any added/deleted fields are incompatible.
|
|
|
|
type FileInfo struct {
|
|
|
|
// Name of the volume.
|
|
|
|
Volume string
|
|
|
|
|
|
|
|
// Name of the file.
|
|
|
|
Name string
|
|
|
|
|
|
|
|
// Version of the file.
|
|
|
|
VersionID string
|
|
|
|
|
|
|
|
// Indicates if the version is the latest
|
|
|
|
IsLatest bool
|
|
|
|
|
|
|
|
// Deleted is set when this FileInfo represents
|
|
|
|
// a deleted marker for a versioned bucket.
|
|
|
|
Deleted bool
|
|
|
|
|
|
|
|
// TransitionStatus is set to Pending/Complete for transitioned
|
|
|
|
// entries based on state of transition
|
|
|
|
TransitionStatus string
|
|
|
|
|
|
|
|
// DataDir of the file
|
|
|
|
DataDir string
|
|
|
|
|
|
|
|
// Indicates if this object is still in V1 format.
|
|
|
|
XLV1 bool
|
|
|
|
|
|
|
|
// Date and time when the file was last modified, if Deleted
|
|
|
|
// is 'true' this value represents when while was deleted.
|
|
|
|
ModTime time.Time
|
|
|
|
|
|
|
|
// Total file size.
|
|
|
|
Size int64
|
|
|
|
|
|
|
|
// File mode bits.
|
|
|
|
Mode uint32
|
|
|
|
|
|
|
|
// File metadata
|
|
|
|
Metadata map[string]string
|
|
|
|
|
|
|
|
// All the parts per object.
|
|
|
|
Parts []ObjectPartInfo
|
|
|
|
|
|
|
|
// Erasure info for all objects.
|
|
|
|
Erasure ErasureInfo
|
|
|
|
|
|
|
|
// DeleteMarkerReplicationStatus is set when this FileInfo represents
|
|
|
|
// replication on a DeleteMarker
|
|
|
|
MarkDeleted bool // mark this version as deleted
|
|
|
|
DeleteMarkerReplicationStatus string
|
|
|
|
VersionPurgeStatus VersionPurgeStatusType
|
|
|
|
}
|
|
|
|
|
|
|
|
// VersionPurgeStatusKey denotes purge status in metadata
|
|
|
|
const VersionPurgeStatusKey = "purgestatus"
|
|
|
|
|
|
|
|
// VersionPurgeStatusType represents status of a versioned delete or permanent delete w.r.t bucket replication
|
|
|
|
type VersionPurgeStatusType string
|
|
|
|
|
|
|
|
const (
|
|
|
|
// Pending - versioned delete replication is pending.
|
|
|
|
Pending VersionPurgeStatusType = "PENDING"
|
|
|
|
|
|
|
|
// Complete - versioned delete replication is now complete, erase version on disk.
|
|
|
|
Complete VersionPurgeStatusType = "COMPLETE"
|
|
|
|
|
|
|
|
// Failed - versioned delete replication failed.
|
|
|
|
Failed VersionPurgeStatusType = "FAILED"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Empty returns true if purge status was not set.
|
|
|
|
func (v VersionPurgeStatusType) Empty() bool {
|
|
|
|
return string(v) == ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pending returns true if the version is pending purge.
|
|
|
|
func (v VersionPurgeStatusType) Pending() bool {
|
|
|
|
return v == Pending || v == Failed
|
|
|
|
}
|
|
|
|
|
|
|
|
// newFileInfo - initializes new FileInfo, allocates a fresh erasure info.
|
|
|
|
func newFileInfo(object string, dataBlocks, parityBlocks int) (fi FileInfo) {
|
|
|
|
fi.Erasure = ErasureInfo{
|
|
|
|
Algorithm: erasureAlgorithm,
|
|
|
|
DataBlocks: dataBlocks,
|
|
|
|
ParityBlocks: parityBlocks,
|
|
|
|
BlockSize: blockSizeV1,
|
|
|
|
Distribution: hashOrder(object, dataBlocks+parityBlocks),
|
|
|
|
}
|
|
|
|
return fi
|
|
|
|
}
|