forked from thecodeteam/libstorage
/
types_drivers_executor.go
316 lines (259 loc) · 8.74 KB
/
types_drivers_executor.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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
package types
import (
"fmt"
"strconv"
"strings"
"time"
)
// DeviceScanType is a type of device scan algorithm.
type DeviceScanType int
const (
// LSXExitCodeNotImplemented is the exit code the executor binary uses to
// indicate a function is not implemented for a given storage driver on the
// current system.
LSXExitCodeNotImplemented = 2
// LSXExitCodeTimedOut is the exit code the executor binary uses to indicate
// a function timed out.
LSXExitCodeTimedOut = 255
// LSXCmdInstanceID is the command to execute to get the instance ID.
LSXCmdInstanceID = "instanceID"
// LSXCmdLocalDevices is the command to execute to get the local devices
// map.
LSXCmdLocalDevices = "localDevices"
// LSXCmdNextDevice is the command to execute to get the next device.
LSXCmdNextDevice = "nextDevice"
// LSXCmdWaitForDevice is the command to execute to wait until a device,
// identified by volume ID, is presented to the system.
LSXCmdWaitForDevice = "wait"
// LSXCmdSupported is the command to execute to find out if an executor
// is valid for a given platform on the current host.
LSXCmdSupported = "supported"
// LSXCmdMount is the command for mounting a device to a file system path.
LSXCmdMount = "mount"
// LSXCmdUmount is the command for unmounting mounted file systems.
LSXCmdUmount = "umount"
// LSXCmdMounts is the command for getting a list of mount info objects.
LSXCmdMounts = "mounts"
)
const (
// DeviceScanQuick performs a shallow, quick scan.
DeviceScanQuick DeviceScanType = iota
// DeviceScanDeep performs a deep, longer scan.
DeviceScanDeep
)
// String returns the string representation of a DeviceScanType.
func (st DeviceScanType) String() string {
switch st {
case DeviceScanQuick:
return "quick"
case DeviceScanDeep:
return "deep"
}
return ""
}
// ParseDeviceScanType parses a device scan type.
func ParseDeviceScanType(i interface{}) DeviceScanType {
switch ti := i.(type) {
case string:
lti := strings.ToLower(ti)
if lti == DeviceScanQuick.String() {
return DeviceScanQuick
} else if lti == DeviceScanDeep.String() {
return DeviceScanDeep
}
i, err := strconv.Atoi(ti)
if err != nil {
return DeviceScanQuick
}
return ParseDeviceScanType(i)
case int:
st := DeviceScanType(ti)
if st == DeviceScanQuick || st == DeviceScanDeep {
return st
}
return DeviceScanQuick
default:
return ParseDeviceScanType(fmt.Sprintf("%v", ti))
}
}
// LocalDevicesOpts are options when getting a list of local devices.
type LocalDevicesOpts struct {
ScanType DeviceScanType
Opts Store
}
// WaitForDeviceOpts are options when waiting on specific local device to
// appear.
type WaitForDeviceOpts struct {
LocalDevicesOpts
// Token is the value returned by a remote VolumeAttach call that the
// client can use to block until a specific device has appeared in the
// local devices list.
Token string
// Timeout is the maximum duration for which to wait for a device to
// appear in the local devices list.
Timeout time.Duration
}
// NewStorageExecutor is a function that constructs a new StorageExecutors.
type NewStorageExecutor func() StorageExecutor
// StorageExecutor is the part of a storage driver that is downloaded at
// runtime by the libStorage client.
type StorageExecutor interface {
Driver
StorageExecutorFunctions
}
// StorageExecutorFunctions is the collection of functions that are required of
// a StorageExecutor.
type StorageExecutorFunctions interface {
// InstanceID returns the local system's InstanceID.
InstanceID(
ctx Context,
opts Store) (*InstanceID, error)
// NextDevice returns the next available device.
NextDevice(
ctx Context,
opts Store) (string, error)
// LocalDevices returns a map of the system's local devices.
LocalDevices(
ctx Context,
opts *LocalDevicesOpts) (*LocalDevices, error)
}
// StorageExecutorWithSupported is an interface that executor implementations
// may use by defining the function "Supported(Context, Store) (bool, error)".
// This function indicates whether a storage platform is valid when executing
// the executor binary on a given client.
type StorageExecutorWithSupported interface {
StorageExecutorFunctions
// Supported returns a flag indicating whether or not the platform
// implementing the executor is valid for the host on which the executor
// resides.
Supported(
ctx Context,
opts Store) (bool, error)
}
// StorageExecutorWithMount is an interface that executor implementations
// may use to become part of the mount workflow.
type StorageExecutorWithMount interface {
// Mount mounts a device to a specified path.
Mount(
ctx Context,
deviceName, mountPoint string,
opts *DeviceMountOpts) error
}
// StorageExecutorWithMounts is an interface that executor implementations
// may use to become part of the mounts workflow.
type StorageExecutorWithMounts interface {
// Mounts get a list of mount points.
Mounts(
ctx Context,
opts Store) ([]*MountInfo, error)
}
// StorageExecutorWithUnmount is an interface that executor implementations
// may use to become part of unmount workflow.
type StorageExecutorWithUnmount interface {
// Unmount unmounts the underlying device from the specified path.
Unmount(
ctx Context,
mountPoint string,
opts Store) error
}
// ProvidesStorageExecutorCLI is a type that provides the StorageExecutorCLI.
type ProvidesStorageExecutorCLI interface {
// XCLI returns the StorageExecutorCLI.
XCLI() StorageExecutorCLI
}
// StorageExecutorCLI provides a way to interact with the CLI tool built with
// the driver implementations of the StorageExecutor interface.
type StorageExecutorCLI interface {
StorageExecutorFunctions
StorageExecutorWithMount
StorageExecutorWithMounts
StorageExecutorWithUnmount
// WaitForDevice blocks until the provided attach token appears in the
// map returned from LocalDevices or until the timeout expires, whichever
// occurs first.
//
// The return value is a boolean flag indicating whether or not a match was
// discovered as well as the result of the last LocalDevices call before a
// match is discovered or the timeout expires.
WaitForDevice(
ctx Context,
opts *WaitForDeviceOpts) (bool, *LocalDevices, error)
// Supported returns a flag indicating whether the executor supports
// specific functions for a storage platform on the current host.
Supported(
ctx Context,
opts Store) (LSXSupportedOp, error)
}
// LSXSupportedOp is a bit for the mask returned from an executor's Supported
// function.
type LSXSupportedOp int
const (
// LSXSOpInstanceID indicates an executor supports "InstanceID".
// "InstanceID" operation.
LSXSOpInstanceID LSXSupportedOp = 1 << iota // 1
// LSXSOpNextDevice indicates an executor supports "NextDevice".
LSXSOpNextDevice
// LSXSOpLocalDevices indicates an executor supports "LocalDevices".
LSXSOpLocalDevices
// LSXSOpWaitForDevice indicates an executor supports "WaitForDevice".
LSXSOpWaitForDevice
// LSXSOpMount indicates an executor supports "Mount".
LSXSOpMount
// LSXSOpUmount indicates an executor supports "Umount".
LSXSOpUmount
// LSXSOpMounts indicates an executor supports "Mounts".
LSXSOpMounts
)
const (
// LSXSOpNone indicates the executor is not supported for the platform.
LSXSOpNone LSXSupportedOp = 0
// LSXOpAll indicates the executor supports all operations.
LSXOpAll LSXSupportedOp = LSXSOpInstanceID |
LSXSOpNextDevice |
LSXSOpLocalDevices |
LSXSOpWaitForDevice |
LSXSOpMount |
LSXSOpUmount |
LSXSOpMounts
// LSXOpAllNoMount indicates the executor supports all operations except
// mount and unmount.
LSXOpAllNoMount = LSXOpAll & ^LSXSOpMount & ^LSXSOpUmount & ^LSXSOpMounts
)
// InstanceID returns a flag that indicates whether the LSXSOpInstanceID bit
// is set.
func (v LSXSupportedOp) InstanceID() bool {
return v.bitSet(LSXSOpInstanceID)
}
// NextDevice returns a flag that indicates whether the LSXSOpNextDevice bit
// is set.
func (v LSXSupportedOp) NextDevice() bool {
return v.bitSet(LSXSOpNextDevice)
}
// LocalDevices returns a flag that indicates whether the LSXSOpLocalDevices
// bit is set.
func (v LSXSupportedOp) LocalDevices() bool {
return v.bitSet(LSXSOpLocalDevices)
}
// WaitForDevice returns a flag that indicates whether the LSXSOpWaitForDevice
// bit is set.
func (v LSXSupportedOp) WaitForDevice() bool {
return v.bitSet(LSXSOpWaitForDevice)
}
// Mount returns a flag that indicates whether the LSXSOpMount bit
// is set.
func (v LSXSupportedOp) Mount() bool {
return v.bitSet(LSXSOpMount)
}
// Umount returns a flag that indicates whether the LSXSOpUmount bit
// is set.
func (v LSXSupportedOp) Umount() bool {
return v.bitSet(LSXSOpUmount)
}
// Mounts returns a flag that indicates whether the LSXSOpMounts bit
// is set.
func (v LSXSupportedOp) Mounts() bool {
return v.bitSet(LSXSOpMounts)
}
func (v LSXSupportedOp) bitSet(b LSXSupportedOp) bool {
return v&b == b
}