mirror of
https://github.com/ceph/ceph-csi.git
synced 2024-11-14 18:30:21 +00:00
61 lines
1.5 KiB
Go
61 lines
1.5 KiB
Go
|
// +build !luminous,!mimic
|
||
|
|
||
|
package admin
|
||
|
|
||
|
// For APIs that accept extra sets of "boolean" flags we may end up wanting
|
||
|
// multiple different sets of supported flags. Example: most rm functions
|
||
|
// accept a force flag, but only subvolume delete has retain snapshots.
|
||
|
// To make this somewhat uniform in the admin package we define a utility
|
||
|
// interface and helper function to merge flags with naming options.
|
||
|
|
||
|
type flagSet interface {
|
||
|
flags() map[string]bool
|
||
|
}
|
||
|
|
||
|
type commonRmFlags struct {
|
||
|
force bool
|
||
|
}
|
||
|
|
||
|
func (f commonRmFlags) flags() map[string]bool {
|
||
|
o := make(map[string]bool)
|
||
|
if f.force {
|
||
|
o["force"] = true
|
||
|
}
|
||
|
return o
|
||
|
}
|
||
|
|
||
|
// SubVolRmFlags does not embed other types to simplify and keep the
|
||
|
// interface with the type flat and simple. At the cost of some code
|
||
|
// duplication we get a nicer UX for those using the library.
|
||
|
|
||
|
// SubVolRmFlags may be used to specify behavior modifying flags when
|
||
|
// removing sub volumes.
|
||
|
type SubVolRmFlags struct {
|
||
|
Force bool
|
||
|
RetainSnapshots bool
|
||
|
}
|
||
|
|
||
|
func (f SubVolRmFlags) flags() map[string]bool {
|
||
|
o := make(map[string]bool)
|
||
|
if f.Force {
|
||
|
o["force"] = true
|
||
|
}
|
||
|
if f.RetainSnapshots {
|
||
|
o["retain-snapshots"] = true
|
||
|
}
|
||
|
return o
|
||
|
}
|
||
|
|
||
|
// mergeFlags combines a set of key-value settings with any type implementing
|
||
|
// the flagSet interface.
|
||
|
func mergeFlags(m map[string]string, f flagSet) map[string]interface{} {
|
||
|
o := make(map[string]interface{})
|
||
|
for k, v := range m {
|
||
|
o[k] = v
|
||
|
}
|
||
|
for k, v := range f.flags() {
|
||
|
o[k] = v
|
||
|
}
|
||
|
return o
|
||
|
}
|