-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvolume.go
44 lines (34 loc) · 1.29 KB
/
volume.go
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
// Copyright 2015 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package storage
import "github.com/juju/names"
// Volume describes a volume (disk, logical volume, etc.)
type Volume struct {
// Name is a unique name assigned by Juju to the volume.
Tag names.VolumeTag
// VolumeId is a unique provider-supplied ID for the volume.
// VolumeId is required to be unique for the lifetime of the
// volume, but may be reused.
VolumeId string
// Serial is the volume's serial number. Not all volumes have a serial
// number, so this may be left blank.
Serial string
// Size is the size of the volume, in MiB.
Size uint64
// TODO(axw) record volume persistence
}
// VolumeAttachment decsribes machine-specific volume attachment information,
// including how the volume is exposed on the machine.
type VolumeAttachment struct {
// Volume is the unique tag assigned by Juju for the volume
// that this attachment corresponds to.
Volume names.VolumeTag
// Machine is the unique tag assigned by Juju for the machine that
// this attachment corresponds to.
Machine names.MachineTag
// DeviceName is the volume's OS-specific device name (e.g. "sdb").
//
// If the device name may change (e.g. on machine restart), then this
// field must be left blank.
DeviceName string
}