2018-04-11 14:31:09 -07:00
|
|
|
def construct_lvol_store(client, bdev_name, lvs_name, cluster_sz=None):
|
|
|
|
"""Construct a logical volume store.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
bdev_name: bdev on which to construct logical volume store
|
|
|
|
lvs_name: name of the logical volume store to create
|
|
|
|
cluster_sz: cluster size of the logical volume store in bytes (optional)
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
UUID of created logical volume store.
|
|
|
|
"""
|
|
|
|
params = {'bdev_name': bdev_name, 'lvs_name': lvs_name}
|
|
|
|
if cluster_sz:
|
|
|
|
params['cluster_sz'] = cluster_sz
|
2018-03-27 14:31:52 -07:00
|
|
|
return client.call('construct_lvol_store', params)
|
2017-06-06 14:22:03 -07:00
|
|
|
|
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
def rename_lvol_store(client, old_name, new_name):
|
|
|
|
"""Rename a logical volume store.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
old_name: existing logical volume store name
|
|
|
|
new_name: new logical volume store name
|
|
|
|
"""
|
2018-01-10 11:03:39 +01:00
|
|
|
params = {
|
2018-04-11 14:31:09 -07:00
|
|
|
'old_name': old_name,
|
|
|
|
'new_name': new_name
|
2018-01-10 11:03:39 +01:00
|
|
|
}
|
2018-03-27 14:31:52 -07:00
|
|
|
return client.call('rename_lvol_store', params)
|
2018-01-10 11:03:39 +01:00
|
|
|
|
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
def construct_lvol_bdev(client, lvol_name, size, thin_provision=False, uuid=None, lvs_name=None):
|
|
|
|
"""Create a logical volume on a logical volume store.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
lvol_name: name of logical volume to create
|
|
|
|
size: desired size of logical volume in bytes (will be rounded up to a multiple of cluster size)
|
|
|
|
thin_provision: True to enable thin provisioning
|
|
|
|
uuid: UUID of logical volume store to create logical volume on (optional)
|
|
|
|
lvs_name: name of logical volume store to create logical volume on (optional)
|
|
|
|
|
|
|
|
Either uuid or lvs_name must be specified, but not both.
|
|
|
|
"""
|
|
|
|
if (uuid and lvs_name) or (not uuid and not lvs_name):
|
|
|
|
raise ValueError("Either uuid or lvs_name must be specified, but not both")
|
|
|
|
|
|
|
|
params = {'lvol_name': lvol_name, 'size': size}
|
|
|
|
if thin_provision:
|
|
|
|
params['thin_provision'] = thin_provision
|
|
|
|
if uuid:
|
|
|
|
params['uuid'] = uuid
|
|
|
|
if lvs_name:
|
|
|
|
params['lvs_name'] = lvs_name
|
|
|
|
return client.call('construct_lvol_bdev', params)
|
2017-06-06 14:22:03 -07:00
|
|
|
|
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
def snapshot_lvol_bdev(client, lvol_name, snapshot_name):
|
|
|
|
"""Capture a snapshot of the current state of a logical volume.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
lvol_name: logical volume to create a snapshot from
|
|
|
|
snapshot_name: name for the newly created snapshot
|
|
|
|
"""
|
2018-02-22 07:29:49 -05:00
|
|
|
params = {
|
2018-04-11 14:31:09 -07:00
|
|
|
'lvol_name': lvol_name,
|
|
|
|
'snapshot_name': snapshot_name
|
2018-02-22 07:29:49 -05:00
|
|
|
}
|
|
|
|
return client.call('snapshot_lvol_bdev', params)
|
|
|
|
|
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
def clone_lvol_bdev(client, snapshot_name, clone_name):
|
|
|
|
"""Create a logical volume based on a snapshot.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
snapshot_name: snapshot to clone
|
|
|
|
clone_name: name of logical volume to create
|
|
|
|
"""
|
2018-02-22 07:29:49 -05:00
|
|
|
params = {
|
2018-04-11 14:31:09 -07:00
|
|
|
'snapshot_name': snapshot_name,
|
|
|
|
'clone_name': clone_name
|
2018-02-22 07:29:49 -05:00
|
|
|
}
|
|
|
|
return client.call('clone_lvol_bdev', params)
|
|
|
|
|
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
def rename_lvol_bdev(client, old_name, new_name):
|
|
|
|
"""Rename a logical volume.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
old_name: existing logical volume name
|
|
|
|
new_name: new logical volume name
|
|
|
|
"""
|
2018-01-10 11:02:27 +01:00
|
|
|
params = {
|
2018-04-11 14:31:09 -07:00
|
|
|
'old_name': old_name,
|
|
|
|
'new_name': new_name
|
2018-01-10 11:02:27 +01:00
|
|
|
}
|
2018-03-27 14:31:52 -07:00
|
|
|
return client.call('rename_lvol_bdev', params)
|
2018-01-10 11:02:27 +01:00
|
|
|
|
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
def resize_lvol_bdev(client, name, size):
|
|
|
|
"""Resize a logical volume.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
name: name of logical volume to resize
|
|
|
|
size: desired size of logical volume in bytes (will be rounded up to a multiple of cluster size)
|
|
|
|
"""
|
2018-02-07 14:57:05 +01:00
|
|
|
params = {
|
2018-04-11 14:31:09 -07:00
|
|
|
'name': name,
|
|
|
|
'size': size,
|
2018-02-07 14:57:05 +01:00
|
|
|
}
|
|
|
|
return client.call('resize_lvol_bdev', params)
|
2017-06-06 14:22:03 -07:00
|
|
|
|
|
|
|
|
2018-04-11 15:12:13 -07:00
|
|
|
def destroy_lvol_bdev(client, name):
|
|
|
|
"""Destroy a logical volume.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
name: name of logical volume to destroy
|
|
|
|
"""
|
|
|
|
params = {
|
|
|
|
'name': name,
|
|
|
|
}
|
|
|
|
return client.call('destroy_lvol_bdev', params)
|
|
|
|
|
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
def destroy_lvol_store(client, uuid=None, lvs_name=None):
|
|
|
|
"""Destroy a logical volume store.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
uuid: UUID of logical volume store to destroy (optional)
|
|
|
|
lvs_name: name of logical volume store to destroy (optional)
|
|
|
|
|
|
|
|
Either uuid or lvs_name must be specified, but not both.
|
|
|
|
"""
|
|
|
|
if (uuid and lvs_name) or (not uuid and not lvs_name):
|
|
|
|
raise ValueError("Exactly one of uuid or lvs_name must be specified")
|
|
|
|
|
2017-06-06 14:22:03 -07:00
|
|
|
params = {}
|
2018-04-11 14:31:09 -07:00
|
|
|
if uuid:
|
|
|
|
params['uuid'] = uuid
|
|
|
|
if lvs_name:
|
|
|
|
params['lvs_name'] = lvs_name
|
|
|
|
return client.call('destroy_lvol_store', params)
|
|
|
|
|
|
|
|
|
|
|
|
def get_lvol_stores(client, uuid=None, lvs_name=None):
|
|
|
|
"""List logical volume stores.
|
2017-06-06 14:22:03 -07:00
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
Args:
|
|
|
|
uuid: UUID of logical volume store to retrieve information about (optional)
|
|
|
|
lvs_name: name of logical volume store to retrieve information about (optional)
|
2017-06-06 14:22:03 -07:00
|
|
|
|
2018-04-11 14:31:09 -07:00
|
|
|
Either uuid or lvs_name may be specified, but not both.
|
|
|
|
If both uuid and lvs_name are omitted, information about all logical volume stores is returned.
|
|
|
|
"""
|
|
|
|
if (uuid and lvs_name):
|
|
|
|
raise ValueError("Exactly one of uuid or lvs_name may be specified")
|
2018-01-29 02:09:35 -05:00
|
|
|
params = {}
|
2018-04-11 14:31:09 -07:00
|
|
|
if uuid:
|
|
|
|
params['uuid'] = uuid
|
|
|
|
if lvs_name:
|
|
|
|
params['lvs_name'] = lvs_name
|
2018-03-27 14:31:52 -07:00
|
|
|
return client.call('get_lvol_stores', params)
|