7b5356f32d
Change-Id: I95b72434a8a44f737f5ee9a44b6ecbf8f4162a7a
57 lines
2.0 KiB
Python
57 lines
2.0 KiB
Python
# 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.
|
|
|
|
|
|
def resize_share(conn, share_id, share_size):
|
|
# Be explicit about not wanting to use force if the share
|
|
# will be extended.
|
|
use_force = False
|
|
print('Resize the share to the given size:')
|
|
conn.share.resize_share(share_id, share_size, use_force)
|
|
|
|
|
|
def resize_shares_without_shrink(conn, min_size):
|
|
# Sometimes, extending shares without shrinking
|
|
# them (effectively setting a min size) is desirable.
|
|
|
|
# Get list of shares from the connection.
|
|
shares = conn.share.shares()
|
|
|
|
# Loop over the shares:
|
|
for share in shares:
|
|
# Extend shares smaller than min_size to min_size,
|
|
# but don't shrink shares larger than min_size.
|
|
conn.share.resize_share(share.id, min_size, no_shrink=True)
|
|
|
|
|
|
def manage_share(conn, protocol, export_path, service_host, **params):
|
|
# Manage a share with the given protocol, export path, service host, and
|
|
# optional additional parameters
|
|
managed_share = conn.share.manage_share(
|
|
protocol, export_path, service_host, **params
|
|
)
|
|
|
|
# Can get the ID of the share, which is now being managed with Manila
|
|
managed_share_id = managed_share.id
|
|
print("The ID of the share which was managed: %s", managed_share_id)
|
|
|
|
|
|
def unmanage_share(conn, share_id):
|
|
# Unmanage the share with the given share ID
|
|
conn.share.unmanage_share(share_id)
|
|
|
|
try:
|
|
# Getting the share will raise an exception as it has been unmanaged
|
|
conn.share.get_share(share_id)
|
|
except Exception:
|
|
pass
|