mypy: set no_implicit_optional
The current version of PEP-484 indicates that type checkers should not allow implicit optional parameters. - https://www.python.org/dev/peps/pep-0484/#union-types - https://github.com/python/mypy/issues/9091 Change-Id: I49e5729a4d754934e861d4d0fd25fd8b2a80602e
This commit is contained in:
parent
e8ad14365d
commit
d3afa4db00
@ -119,12 +119,12 @@ class API(base.Base):
|
|||||||
|
|
||||||
def get_all(self,
|
def get_all(self,
|
||||||
context: context.RequestContext,
|
context: context.RequestContext,
|
||||||
search_opts: dict = None,
|
search_opts: Optional[dict] = None,
|
||||||
marker: str = None,
|
marker: Optional[str] = None,
|
||||||
limit: int = None,
|
limit: Optional[int] = None,
|
||||||
offset: int = None,
|
offset: Optional[int] = None,
|
||||||
sort_keys: List[str] = None,
|
sort_keys: Optional[List[str]] = None,
|
||||||
sort_dirs: List[str] = None) -> 'objects.BackupList':
|
sort_dirs: Optional[List[str]] = None) -> 'objects.BackupList':
|
||||||
context.authorize(policy.GET_ALL_POLICY)
|
context.authorize(policy.GET_ALL_POLICY)
|
||||||
|
|
||||||
search_opts = search_opts or {}
|
search_opts = search_opts or {}
|
||||||
@ -223,10 +223,10 @@ class API(base.Base):
|
|||||||
volume_id: str,
|
volume_id: str,
|
||||||
container: str,
|
container: str,
|
||||||
incremental: bool = False,
|
incremental: bool = False,
|
||||||
availability_zone: str = None,
|
availability_zone: Optional[str] = None,
|
||||||
force: bool = False,
|
force: bool = False,
|
||||||
snapshot_id: Optional[str] = None,
|
snapshot_id: Optional[str] = None,
|
||||||
metadata: dict = None) -> 'objects.Backup':
|
metadata: Optional[dict] = None) -> 'objects.Backup':
|
||||||
"""Make the RPC call to create a volume backup."""
|
"""Make the RPC call to create a volume backup."""
|
||||||
volume = self.volume_api.get(context, volume_id)
|
volume = self.volume_api.get(context, volume_id)
|
||||||
context.authorize(policy.CREATE_POLICY, target_obj=volume)
|
context.authorize(policy.CREATE_POLICY, target_obj=volume)
|
||||||
@ -365,8 +365,8 @@ class API(base.Base):
|
|||||||
def restore(self,
|
def restore(self,
|
||||||
context: context.RequestContext,
|
context: context.RequestContext,
|
||||||
backup_id: str,
|
backup_id: str,
|
||||||
volume_id: str = None,
|
volume_id: Optional[str] = None,
|
||||||
name: str = None) -> dict:
|
name: Optional[str] = None) -> dict:
|
||||||
"""Make the RPC call to restore a volume backup."""
|
"""Make the RPC call to restore a volume backup."""
|
||||||
backup = self.get(context, backup_id)
|
backup = self.get(context, backup_id)
|
||||||
context.authorize(policy.RESTORE_POLICY, target_obj=backup)
|
context.authorize(policy.RESTORE_POLICY, target_obj=backup)
|
||||||
|
@ -21,7 +21,7 @@ import inspect
|
|||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
import sys
|
import sys
|
||||||
from typing import Callable
|
from typing import Callable, Optional # noqa: H301
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
import decorator
|
import decorator
|
||||||
@ -56,7 +56,7 @@ class Coordinator(object):
|
|||||||
meaningful prefix.
|
meaningful prefix.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, agent_id: str = None, prefix: str = ''):
|
def __init__(self, agent_id: Optional[str] = None, prefix: str = ''):
|
||||||
self.coordinator = None
|
self.coordinator = None
|
||||||
self.agent_id = agent_id or str(uuid.uuid4())
|
self.agent_id = agent_id or str(uuid.uuid4())
|
||||||
self.started = False
|
self.started = False
|
||||||
|
@ -22,7 +22,7 @@ SHOULD include dedicated exception logging.
|
|||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from typing import Union
|
from typing import Optional, Union # noqa: H301
|
||||||
|
|
||||||
from oslo_log import log as logging
|
from oslo_log import log as logging
|
||||||
from oslo_versionedobjects import exception as obj_exc
|
from oslo_versionedobjects import exception as obj_exc
|
||||||
@ -72,7 +72,7 @@ class CinderException(Exception):
|
|||||||
headers: dict = {}
|
headers: dict = {}
|
||||||
safe = False
|
safe = False
|
||||||
|
|
||||||
def __init__(self, message: Union[str, tuple] = None, **kwargs):
|
def __init__(self, message: Optional[Union[str, tuple]] = None, **kwargs):
|
||||||
self.kwargs = kwargs
|
self.kwargs = kwargs
|
||||||
self.kwargs['message'] = message
|
self.kwargs['message'] = message
|
||||||
|
|
||||||
|
@ -183,10 +183,11 @@ def _get_qemu_convert_luks_cmd(src: str,
|
|||||||
src_format: Optional[str] = None,
|
src_format: Optional[str] = None,
|
||||||
out_subformat: Optional[str] = None,
|
out_subformat: Optional[str] = None,
|
||||||
cache_mode: Optional[str] = None,
|
cache_mode: Optional[str] = None,
|
||||||
prefix: tuple = None,
|
prefix: Optional[tuple] = None,
|
||||||
cipher_spec: Optional[dict] = None,
|
cipher_spec: Optional[dict] = None,
|
||||||
passphrase_file: Optional[str] = None,
|
passphrase_file: Optional[str] = None,
|
||||||
src_passphrase_file: str = None) -> List[str]:
|
src_passphrase_file: Optional[str] = None) \
|
||||||
|
-> List[str]:
|
||||||
|
|
||||||
cmd = ['qemu-img', 'convert']
|
cmd = ['qemu-img', 'convert']
|
||||||
|
|
||||||
@ -214,14 +215,15 @@ def _get_qemu_convert_luks_cmd(src: str,
|
|||||||
def _get_qemu_convert_cmd(src: str,
|
def _get_qemu_convert_cmd(src: str,
|
||||||
dest: str,
|
dest: str,
|
||||||
out_format: str,
|
out_format: str,
|
||||||
src_format: str = None,
|
src_format: Optional[str] = None,
|
||||||
out_subformat: str = None,
|
out_subformat: Optional[str] = None,
|
||||||
cache_mode: str = None,
|
cache_mode: Optional[str] = None,
|
||||||
prefix: tuple = None,
|
prefix: Optional[tuple] = None,
|
||||||
cipher_spec: dict = None,
|
cipher_spec: Optional[dict] = None,
|
||||||
passphrase_file: str = None,
|
passphrase_file: Optional[str] = None,
|
||||||
compress: bool = False,
|
compress: bool = False,
|
||||||
src_passphrase_file: str = None) -> List[str]:
|
src_passphrase_file: Optional[str] = None) \
|
||||||
|
-> List[str]:
|
||||||
|
|
||||||
if src_passphrase_file is not None:
|
if src_passphrase_file is not None:
|
||||||
if passphrase_file is None:
|
if passphrase_file is None:
|
||||||
@ -314,13 +316,13 @@ def _convert_image(prefix: tuple,
|
|||||||
source: str,
|
source: str,
|
||||||
dest: str,
|
dest: str,
|
||||||
out_format: str,
|
out_format: str,
|
||||||
out_subformat: str = None,
|
out_subformat: Optional[str] = None,
|
||||||
src_format: str = None,
|
src_format: Optional[str] = None,
|
||||||
run_as_root: bool = True,
|
run_as_root: bool = True,
|
||||||
cipher_spec: dict = None,
|
cipher_spec: Optional[dict] = None,
|
||||||
passphrase_file: str = None,
|
passphrase_file: Optional[str] = None,
|
||||||
compress: bool = False,
|
compress: bool = False,
|
||||||
src_passphrase_file: str = None) -> None:
|
src_passphrase_file: Optional[str] = None) -> None:
|
||||||
"""Convert image to other format.
|
"""Convert image to other format.
|
||||||
|
|
||||||
NOTE: If the qemu-img convert command fails and this function raises an
|
NOTE: If the qemu-img convert command fails and this function raises an
|
||||||
@ -421,14 +423,14 @@ def _convert_image(prefix: tuple,
|
|||||||
def convert_image(source: str,
|
def convert_image(source: str,
|
||||||
dest: str,
|
dest: str,
|
||||||
out_format: str,
|
out_format: str,
|
||||||
out_subformat: str = None,
|
out_subformat: Optional[str] = None,
|
||||||
src_format: str = None,
|
src_format: Optional[str] = None,
|
||||||
run_as_root: bool = True,
|
run_as_root: bool = True,
|
||||||
throttle=None,
|
throttle=None,
|
||||||
cipher_spec: dict = None,
|
cipher_spec: Optional[dict] = None,
|
||||||
passphrase_file: str = None,
|
passphrase_file: Optional[str] = None,
|
||||||
compress: bool = False,
|
compress: bool = False,
|
||||||
src_passphrase_file: str = None) -> None:
|
src_passphrase_file: Optional[str] = None) -> None:
|
||||||
if not throttle:
|
if not throttle:
|
||||||
throttle = throttling.Throttle.get_default()
|
throttle = throttling.Throttle.get_default()
|
||||||
with throttle.subcommand(source, dest) as throttle_cmd:
|
with throttle.subcommand(source, dest) as throttle_cmd:
|
||||||
@ -447,7 +449,7 @@ def convert_image(source: str,
|
|||||||
def resize_image(source: str,
|
def resize_image(source: str,
|
||||||
size: int,
|
size: int,
|
||||||
run_as_root: bool = False,
|
run_as_root: bool = False,
|
||||||
file_format: str = None) -> None:
|
file_format: Optional[str] = None) -> None:
|
||||||
"""Changes the virtual size of the image."""
|
"""Changes the virtual size of the image."""
|
||||||
cmd: Tuple[str, ...]
|
cmd: Tuple[str, ...]
|
||||||
if file_format:
|
if file_format:
|
||||||
@ -805,7 +807,7 @@ def upload_volume(context: context.RequestContext,
|
|||||||
volume_format: str = 'raw',
|
volume_format: str = 'raw',
|
||||||
run_as_root: bool = True,
|
run_as_root: bool = True,
|
||||||
compress: bool = True,
|
compress: bool = True,
|
||||||
store_id: str = None,
|
store_id: Optional[str] = None,
|
||||||
base_image_ref: Optional[str] = None) -> None:
|
base_image_ref: Optional[str] = None) -> None:
|
||||||
# NOTE: You probably want to use volume_utils.upload_volume(),
|
# NOTE: You probably want to use volume_utils.upload_volume(),
|
||||||
# not this function.
|
# not this function.
|
||||||
|
@ -29,8 +29,8 @@ LOG = logging.getLogger(__name__)
|
|||||||
|
|
||||||
|
|
||||||
def normalize(weight_list: List[float],
|
def normalize(weight_list: List[float],
|
||||||
minval: float = None,
|
minval: Optional[float] = None,
|
||||||
maxval: float = None) -> Iterable[float]:
|
maxval: Optional[float] = None) -> Iterable[float]:
|
||||||
"""Normalize the values in a list between 0 and 1.0.
|
"""Normalize the values in a list between 0 and 1.0.
|
||||||
|
|
||||||
The normalization is made regarding the lower and upper values present in
|
The normalization is made regarding the lower and upper values present in
|
||||||
|
@ -485,7 +485,8 @@ class FilterScheduler(driver.Scheduler):
|
|||||||
|
|
||||||
def _get_weighted_candidates_by_group_type(
|
def _get_weighted_candidates_by_group_type(
|
||||||
self, context: context.RequestContext, group_spec: dict,
|
self, context: context.RequestContext, group_spec: dict,
|
||||||
group_filter_properties: dict = None) -> List[WeighedHost]:
|
group_filter_properties: Optional[dict] = None) \
|
||||||
|
-> List[WeighedHost]:
|
||||||
"""Finds backends that supports the group type.
|
"""Finds backends that supports the group type.
|
||||||
|
|
||||||
Returns a list of backends that meet the required specs,
|
Returns a list of backends that meet the required specs,
|
||||||
|
@ -72,7 +72,7 @@ LOG = logging.getLogger(__name__)
|
|||||||
|
|
||||||
class ReadOnlyDict(abc.Mapping):
|
class ReadOnlyDict(abc.Mapping):
|
||||||
"""A read-only dict."""
|
"""A read-only dict."""
|
||||||
def __init__(self, source: Union[dict, 'ReadOnlyDict'] = None):
|
def __init__(self, source: Optional[Union[dict, 'ReadOnlyDict']] = None):
|
||||||
self.data: dict
|
self.data: dict
|
||||||
if source is not None:
|
if source is not None:
|
||||||
self.data = dict(source)
|
self.data = dict(source)
|
||||||
|
@ -234,7 +234,7 @@ def check_metadata_properties(
|
|||||||
raise exception.InvalidVolumeMetadataSize(reason=msg)
|
raise exception.InvalidVolumeMetadataSize(reason=msg)
|
||||||
|
|
||||||
|
|
||||||
def last_completed_audit_period(unit: str = None) -> \
|
def last_completed_audit_period(unit: Optional[str] = None) -> \
|
||||||
Tuple[Union[datetime.datetime, datetime.timedelta],
|
Tuple[Union[datetime.datetime, datetime.timedelta],
|
||||||
Union[datetime.datetime, datetime.timedelta]]:
|
Union[datetime.datetime, datetime.timedelta]]:
|
||||||
"""This method gives you the most recently *completed* audit period.
|
"""This method gives you the most recently *completed* audit period.
|
||||||
@ -374,7 +374,9 @@ def monkey_patch() -> None:
|
|||||||
decorator("%s.%s" % (module, key), func))
|
decorator("%s.%s" % (module, key), func))
|
||||||
|
|
||||||
|
|
||||||
def make_dev_path(dev: str, partition: str = None, base: str = '/dev') -> str:
|
def make_dev_path(dev: str,
|
||||||
|
partition: Optional[str] = None,
|
||||||
|
base: str = '/dev') -> str:
|
||||||
"""Return a path to a particular device.
|
"""Return a path to a particular device.
|
||||||
|
|
||||||
>>> make_dev_path('xvdc')
|
>>> make_dev_path('xvdc')
|
||||||
@ -434,7 +436,8 @@ def robust_file_write(directory: str, filename: str, data: str) -> None:
|
|||||||
|
|
||||||
|
|
||||||
@contextlib.contextmanager
|
@contextlib.contextmanager
|
||||||
def temporary_chown(path: str, owner_uid: int = None) -> Iterator[None]:
|
def temporary_chown(path: str,
|
||||||
|
owner_uid: Optional[int] = None) -> Iterator[None]:
|
||||||
"""Temporarily chown a path.
|
"""Temporarily chown a path.
|
||||||
|
|
||||||
:params owner_uid: UID of temporary owner (defaults to current user)
|
:params owner_uid: UID of temporary owner (defaults to current user)
|
||||||
@ -493,7 +496,7 @@ def get_file_size(path: str) -> int:
|
|||||||
|
|
||||||
def _get_disk_of_partition(
|
def _get_disk_of_partition(
|
||||||
devpath: str,
|
devpath: str,
|
||||||
st: os.stat_result = None) -> Tuple[str, os.stat_result]:
|
st: Optional[os.stat_result] = None) -> Tuple[str, os.stat_result]:
|
||||||
"""Gets a disk device path and status from partition path.
|
"""Gets a disk device path and status from partition path.
|
||||||
|
|
||||||
Returns a disk device path from a partition device path, and stat for
|
Returns a disk device path from a partition device path, and stat for
|
||||||
@ -558,7 +561,7 @@ def get_blkdev_major_minor(path: str,
|
|||||||
|
|
||||||
|
|
||||||
def check_string_length(value: str, name: str, min_length: int = 0,
|
def check_string_length(value: str, name: str, min_length: int = 0,
|
||||||
max_length: int = None,
|
max_length: Optional[int] = None,
|
||||||
allow_all_spaces: bool = True) -> None:
|
allow_all_spaces: bool = True) -> None:
|
||||||
"""Check the length of specified string.
|
"""Check the length of specified string.
|
||||||
|
|
||||||
@ -684,7 +687,7 @@ def convert_str(text: Union[str, bytes]) -> str:
|
|||||||
|
|
||||||
|
|
||||||
def build_or_str(elements: Union[None, str, Iterable[str]],
|
def build_or_str(elements: Union[None, str, Iterable[str]],
|
||||||
str_format: str = None) -> str:
|
str_format: Optional[str] = None) -> str:
|
||||||
"""Builds a string of elements joined by 'or'.
|
"""Builds a string of elements joined by 'or'.
|
||||||
|
|
||||||
Will join strings with the 'or' word and if a str_format is provided it
|
Will join strings with the 'or' word and if a str_format is provided it
|
||||||
|
@ -219,10 +219,10 @@ class API(base.Base):
|
|||||||
name: Optional[str],
|
name: Optional[str],
|
||||||
description: Optional[str],
|
description: Optional[str],
|
||||||
snapshot: Optional[objects.Snapshot] = None,
|
snapshot: Optional[objects.Snapshot] = None,
|
||||||
image_id: str = None,
|
image_id: Optional[str] = None,
|
||||||
volume_type: Optional[objects.VolumeType] = None,
|
volume_type: Optional[objects.VolumeType] = None,
|
||||||
metadata: Optional[dict] = None,
|
metadata: Optional[dict] = None,
|
||||||
availability_zone: str = None,
|
availability_zone: Optional[str] = None,
|
||||||
source_volume: Optional[objects.Volume] = None,
|
source_volume: Optional[objects.Volume] = None,
|
||||||
scheduler_hints=None,
|
scheduler_hints=None,
|
||||||
source_replica=None,
|
source_replica=None,
|
||||||
@ -1154,7 +1154,7 @@ class API(base.Base):
|
|||||||
name: str,
|
name: str,
|
||||||
description: str,
|
description: str,
|
||||||
cgsnapshot_id: str,
|
cgsnapshot_id: str,
|
||||||
group_snapshot_id: str = None) -> Dict[str, Any]:
|
group_snapshot_id: Optional[str] = None) -> Dict[str, Any]:
|
||||||
options = {'volume_id': volume['id'],
|
options = {'volume_id': volume['id'],
|
||||||
'cgsnapshot_id': cgsnapshot_id,
|
'cgsnapshot_id': cgsnapshot_id,
|
||||||
'group_snapshot_id': group_snapshot_id,
|
'group_snapshot_id': group_snapshot_id,
|
||||||
@ -1175,7 +1175,7 @@ class API(base.Base):
|
|||||||
volume: objects.Volume,
|
volume: objects.Volume,
|
||||||
name: str,
|
name: str,
|
||||||
description: str,
|
description: str,
|
||||||
metadata: Dict[str, Any] = None,
|
metadata: Optional[Dict[str, Any]] = None,
|
||||||
cgsnapshot_id: Optional[str] = None,
|
cgsnapshot_id: Optional[str] = None,
|
||||||
group_snapshot_id: Optional[str] = None,
|
group_snapshot_id: Optional[str] = None,
|
||||||
allow_in_use: bool = False) -> objects.Snapshot:
|
allow_in_use: bool = False) -> objects.Snapshot:
|
||||||
@ -1192,7 +1192,7 @@ class API(base.Base):
|
|||||||
volume: objects.Volume,
|
volume: objects.Volume,
|
||||||
name: str,
|
name: str,
|
||||||
description: str,
|
description: str,
|
||||||
metadata: Dict[str, Any] = None) -> objects.Snapshot:
|
metadata: Optional[Dict[str, Any]] = None) -> objects.Snapshot:
|
||||||
result = self._create_snapshot(context, volume, name, description,
|
result = self._create_snapshot(context, volume, name, description,
|
||||||
True, metadata)
|
True, metadata)
|
||||||
LOG.info("Snapshot force create request issued successfully.",
|
LOG.info("Snapshot force create request issued successfully.",
|
||||||
|
@ -159,11 +159,11 @@ class RBDVolumeProxy(object):
|
|||||||
def __init__(self,
|
def __init__(self,
|
||||||
driver: 'RBDDriver',
|
driver: 'RBDDriver',
|
||||||
name: str,
|
name: str,
|
||||||
pool: str = None,
|
pool: Optional[str] = None,
|
||||||
snapshot: str = None,
|
snapshot: Optional[str] = None,
|
||||||
read_only: bool = False,
|
read_only: bool = False,
|
||||||
remote: Optional[Dict[str, str]] = None,
|
remote: Optional[Dict[str, str]] = None,
|
||||||
timeout: int = None,
|
timeout: Optional[int] = None,
|
||||||
client: 'rados.Rados' = None,
|
client: 'rados.Rados' = None,
|
||||||
ioctx: 'rados.Ioctx' = None):
|
ioctx: 'rados.Ioctx' = None):
|
||||||
self._close_conn = not (client and ioctx)
|
self._close_conn = not (client and ioctx)
|
||||||
@ -205,7 +205,9 @@ class RBDVolumeProxy(object):
|
|||||||
|
|
||||||
class RADOSClient(object):
|
class RADOSClient(object):
|
||||||
"""Context manager to simplify error handling for connecting to ceph."""
|
"""Context manager to simplify error handling for connecting to ceph."""
|
||||||
def __init__(self, driver: 'RBDDriver', pool: str = None) -> None:
|
def __init__(self,
|
||||||
|
driver: 'RBDDriver',
|
||||||
|
pool: Optional[str] = None) -> None:
|
||||||
self.driver = driver
|
self.driver = driver
|
||||||
self.cluster, self.ioctx = driver._connect_to_rados(pool)
|
self.cluster, self.ioctx = driver._connect_to_rados(pool)
|
||||||
|
|
||||||
@ -246,7 +248,7 @@ class RBDDriver(driver.CloneableImageVD, driver.MigrateVD,
|
|||||||
STORAGE_PROTOCOL = 'ceph'
|
STORAGE_PROTOCOL = 'ceph'
|
||||||
|
|
||||||
def __init__(self,
|
def __init__(self,
|
||||||
active_backend_id: str = None,
|
active_backend_id: Optional[str] = None,
|
||||||
*args,
|
*args,
|
||||||
**kwargs) -> None:
|
**kwargs) -> None:
|
||||||
super(RBDDriver, self).__init__(*args, **kwargs)
|
super(RBDDriver, self).__init__(*args, **kwargs)
|
||||||
@ -1531,9 +1533,9 @@ class RBDDriver(driver.CloneableImageVD, driver.MigrateVD,
|
|||||||
result.append(demoted)
|
result.append(demoted)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def _get_failover_target_config(self,
|
def _get_failover_target_config(
|
||||||
secondary_id: str = None) -> Tuple[str,
|
self,
|
||||||
dict]:
|
secondary_id: Optional[str] = None) -> Tuple[str, dict]:
|
||||||
if not secondary_id:
|
if not secondary_id:
|
||||||
# In auto mode exclude failback and active
|
# In auto mode exclude failback and active
|
||||||
candidates = set(self._target_names).difference(
|
candidates = set(self._target_names).difference(
|
||||||
@ -1587,7 +1589,7 @@ class RBDDriver(driver.CloneableImageVD, driver.MigrateVD,
|
|||||||
def failover_host(self,
|
def failover_host(self,
|
||||||
context: context.RequestContext,
|
context: context.RequestContext,
|
||||||
volumes: List[Volume],
|
volumes: List[Volume],
|
||||||
secondary_id: str = None,
|
secondary_id: Optional[str] = None,
|
||||||
groups: Optional[List] = None) -> Tuple[str,
|
groups: Optional[List] = None) -> Tuple[str,
|
||||||
List[Volume],
|
List[Volume],
|
||||||
List]:
|
List]:
|
||||||
|
@ -257,7 +257,8 @@ class ExtractVolumeRequestTask(flow_utils.CinderTask):
|
|||||||
snapshot,
|
snapshot,
|
||||||
source_volume,
|
source_volume,
|
||||||
group: Optional[dict],
|
group: Optional[dict],
|
||||||
volume_type: Dict[str, Any] = None) -> Tuple[List[str], bool]:
|
volume_type: Optional[Dict[str, Any]] = None) -> Tuple[List[str],
|
||||||
|
bool]:
|
||||||
"""Extracts and returns a validated availability zone list.
|
"""Extracts and returns a validated availability zone list.
|
||||||
|
|
||||||
This function will extract the availability zone (if not provided) from
|
This function will extract the availability zone (if not provided) from
|
||||||
|
@ -146,8 +146,8 @@ class VolumeAPI(rpc.RPCAPI):
|
|||||||
BINARY = constants.VOLUME_BINARY
|
BINARY = constants.VOLUME_BINARY
|
||||||
|
|
||||||
def _get_cctxt(self,
|
def _get_cctxt(self,
|
||||||
host: str = None,
|
host: Optional[str] = None,
|
||||||
version: Union[str, Tuple[str, ...]] = None,
|
version: Optional[Union[str, Tuple[str, ...]]] = None,
|
||||||
**kwargs) -> rpc.RPCAPI:
|
**kwargs) -> rpc.RPCAPI:
|
||||||
if host:
|
if host:
|
||||||
server = volume_utils.extract_host(host)
|
server = volume_utils.extract_host(host)
|
||||||
|
@ -164,8 +164,8 @@ def _usage_from_backup(backup: 'objects.Backup', **kw) -> dict:
|
|||||||
def notify_about_volume_usage(context: context.RequestContext,
|
def notify_about_volume_usage(context: context.RequestContext,
|
||||||
volume: 'objects.Volume',
|
volume: 'objects.Volume',
|
||||||
event_suffix: str,
|
event_suffix: str,
|
||||||
extra_usage_info: dict = None,
|
extra_usage_info: Optional[dict] = None,
|
||||||
host: str = None) -> None:
|
host: Optional[str] = None) -> None:
|
||||||
if not host:
|
if not host:
|
||||||
host = CONF.host
|
host = CONF.host
|
||||||
|
|
||||||
@ -182,8 +182,8 @@ def notify_about_volume_usage(context: context.RequestContext,
|
|||||||
def notify_about_backup_usage(context: context.RequestContext,
|
def notify_about_backup_usage(context: context.RequestContext,
|
||||||
backup: 'objects.Backup',
|
backup: 'objects.Backup',
|
||||||
event_suffix: str,
|
event_suffix: str,
|
||||||
extra_usage_info: dict = None,
|
extra_usage_info: Optional[dict] = None,
|
||||||
host: str = None) -> None:
|
host: Optional[str] = None) -> None:
|
||||||
if not host:
|
if not host:
|
||||||
host = CONF.host
|
host = CONF.host
|
||||||
|
|
||||||
@ -227,8 +227,8 @@ def _usage_from_snapshot(snapshot: 'objects.Snapshot',
|
|||||||
def notify_about_snapshot_usage(context: context.RequestContext,
|
def notify_about_snapshot_usage(context: context.RequestContext,
|
||||||
snapshot: 'objects.Snapshot',
|
snapshot: 'objects.Snapshot',
|
||||||
event_suffix: str,
|
event_suffix: str,
|
||||||
extra_usage_info: dict = None,
|
extra_usage_info: Optional[dict] = None,
|
||||||
host: str = None) -> None:
|
host: Optional[str] = None) -> None:
|
||||||
if not host:
|
if not host:
|
||||||
host = CONF.host
|
host = CONF.host
|
||||||
|
|
||||||
@ -263,8 +263,8 @@ def _usage_from_capacity(capacity: Dict[str, Any],
|
|||||||
def notify_about_capacity_usage(context: context.RequestContext,
|
def notify_about_capacity_usage(context: context.RequestContext,
|
||||||
capacity: dict,
|
capacity: dict,
|
||||||
suffix: str,
|
suffix: str,
|
||||||
extra_usage_info: dict = None,
|
extra_usage_info: Optional[dict] = None,
|
||||||
host: str = None) -> None:
|
host: Optional[str] = None) -> None:
|
||||||
if not host:
|
if not host:
|
||||||
host = CONF.host
|
host = CONF.host
|
||||||
|
|
||||||
@ -292,11 +292,12 @@ def _usage_from_consistencygroup(group_ref: 'objects.Group', **kw) -> dict:
|
|||||||
|
|
||||||
|
|
||||||
@utils.if_notifications_enabled
|
@utils.if_notifications_enabled
|
||||||
def notify_about_consistencygroup_usage(context: context.RequestContext,
|
def notify_about_consistencygroup_usage(
|
||||||
group: 'objects.Group',
|
context: context.RequestContext,
|
||||||
event_suffix: str,
|
group: 'objects.Group',
|
||||||
extra_usage_info: dict = None,
|
event_suffix: str,
|
||||||
host: str = None) -> None:
|
extra_usage_info: Optional[dict] = None,
|
||||||
|
host: Optional[str] = None) -> None:
|
||||||
if not host:
|
if not host:
|
||||||
host = CONF.host
|
host = CONF.host
|
||||||
|
|
||||||
@ -330,8 +331,8 @@ def _usage_from_group(group_ref: 'objects.Group', **kw) -> dict:
|
|||||||
def notify_about_group_usage(context: context.RequestContext,
|
def notify_about_group_usage(context: context.RequestContext,
|
||||||
group: 'objects.Group',
|
group: 'objects.Group',
|
||||||
event_suffix: str,
|
event_suffix: str,
|
||||||
extra_usage_info: dict = None,
|
extra_usage_info: Optional[dict] = None,
|
||||||
host: str = None) -> None:
|
host: Optional[str] = None) -> None:
|
||||||
if not host:
|
if not host:
|
||||||
host = CONF.host
|
host = CONF.host
|
||||||
|
|
||||||
@ -381,8 +382,8 @@ def _usage_from_group_snapshot(group_snapshot: 'objects.GroupSnapshot',
|
|||||||
def notify_about_cgsnapshot_usage(context: context.RequestContext,
|
def notify_about_cgsnapshot_usage(context: context.RequestContext,
|
||||||
cgsnapshot: 'objects.CGSnapshot',
|
cgsnapshot: 'objects.CGSnapshot',
|
||||||
event_suffix: str,
|
event_suffix: str,
|
||||||
extra_usage_info: dict = None,
|
extra_usage_info: Optional[dict] = None,
|
||||||
host: str = None) -> None:
|
host: Optional[str] = None) -> None:
|
||||||
if not host:
|
if not host:
|
||||||
host = CONF.host
|
host = CONF.host
|
||||||
|
|
||||||
@ -403,7 +404,7 @@ def notify_about_group_snapshot_usage(context: context.RequestContext,
|
|||||||
group_snapshot: 'objects.GroupSnapshot',
|
group_snapshot: 'objects.GroupSnapshot',
|
||||||
event_suffix: str,
|
event_suffix: str,
|
||||||
extra_usage_info=None,
|
extra_usage_info=None,
|
||||||
host: str = None) -> None:
|
host: Optional[str] = None) -> None:
|
||||||
if not host:
|
if not host:
|
||||||
host = CONF.host
|
host = CONF.host
|
||||||
|
|
||||||
@ -633,9 +634,9 @@ def copy_volume(src: Union[str, BinaryIO],
|
|||||||
|
|
||||||
def clear_volume(volume_size: int,
|
def clear_volume(volume_size: int,
|
||||||
volume_path: str,
|
volume_path: str,
|
||||||
volume_clear: str = None,
|
volume_clear: Optional[str] = None,
|
||||||
volume_clear_size: int = None,
|
volume_clear_size: Optional[int] = None,
|
||||||
volume_clear_ionice: str = None,
|
volume_clear_ionice: Optional[str] = None,
|
||||||
throttle=None) -> None:
|
throttle=None) -> None:
|
||||||
"""Unprovision old volumes to prevent data leaking between users."""
|
"""Unprovision old volumes to prevent data leaking between users."""
|
||||||
if volume_clear is None:
|
if volume_clear is None:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user