Common and Misc Libraries

Libraries common throughout Nova or just ones that haven’t been categorized very well yet.

The nova.adminclient Module

The nova.context Module

RequestContext: context for requests that persist through all of nova.

class RequestContext(user_id, project_id, is_admin=None, read_deleted='no', roles=None, remote_address=None, timestamp=None, request_id=None, auth_token=None, overwrite=True, quota_class=None, user_name=None, project_name=None, service_catalog=None, instance_lock_checked=False, **kwargs)

Bases: object

Security context and request information.

Represents the user taking a given action within the system.

RequestContext.elevated(read_deleted=None, overwrite=False)

Return a version of this context with admin flag set.

classmethod RequestContext.from_dict(values)
RequestContext.read_deleted
RequestContext.tenant
RequestContext.to_dict()
RequestContext.update_store()
RequestContext.user
authorize_project_context(context, project_id)

Ensures a request has permission to access the given project.

authorize_quota_class_context(context, class_name)

Ensures a request has permission to access the given quota class.

authorize_user_context(context, user_id)

Ensures a request has permission to access the given user.

generate_request_id()
get_admin_context(read_deleted='no')
is_user_context(context)

Indicates if the request context is a normal user.

require_admin_context(ctxt)

Raise exception.AdminRequired() if context is an admin context.

require_context(ctxt)

Raise exception.NotAuthorized() if context is not a user or an admin context.

The nova.exception Module

Nova base exception handling.

Includes decorator for re-raising Nova-type exceptions.

SHOULD include dedicated exception logging.

exception AdminRequired(message=None, **kwargs)

Bases: nova.exception.NotAuthorized

AdminRequired.message = u'User does not have admin privileges'
exception AgentBuildNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

AgentBuildNotFound.message = u'No agent-build associated with id %(id)s.'
exception AggregateError(message=None, **kwargs)

Bases: nova.exception.NovaException

AggregateError.message = u"Aggregate %(aggregate_id)s: action '%(action)s' caused an error: %(reason)s."
exception AggregateHostExists(message=None, **kwargs)

Bases: nova.exception.Duplicate

AggregateHostExists.message = u'Aggregate %(aggregate_id)s already has host %(host)s.'
exception AggregateHostNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

AggregateHostNotFound.message = u'Aggregate %(aggregate_id)s has no host %(host)s.'
exception AggregateMetadataNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

AggregateMetadataNotFound.message = u'Aggregate %(aggregate_id)s has no metadata with key %(metadata_key)s.'
exception AggregateNameExists(message=None, **kwargs)

Bases: nova.exception.Duplicate

AggregateNameExists.message = u'Aggregate %(aggregate_name)s already exists.'
exception AggregateNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

AggregateNotFound.message = u'Aggregate %(aggregate_id)s could not be found.'
exception Base64Exception(message=None, **kwargs)

Bases: nova.exception.NovaException

Base64Exception.message = u'Invalid Base 64 data for file %(path)s'
exception CannotDisassociateAutoAssignedFloatingIP(message=None, **kwargs)

Bases: nova.exception.NovaException

CannotDisassociateAutoAssignedFloatingIP.message = u'Cannot disassociate auto assigined floating ip'
exception CannotResizeToSameFlavor(message=None, **kwargs)

Bases: nova.exception.NovaException

CannotResizeToSameFlavor.message = u'When resizing, instances must change flavor!'
exception CellError(message=None, **kwargs)

Bases: nova.exception.NovaException

CellError.message = u'Exception received during cell processing: %(exc_name)s.'
exception CellMaxHopCountReached(message=None, **kwargs)

Bases: nova.exception.NovaException

CellMaxHopCountReached.message = u'Cell message has reached maximum hop count: %(hop_count)s'
exception CellNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

CellNotFound.message = u"Cell %(cell_name)s doesn't exist."
exception CellRoutingInconsistency(message=None, **kwargs)

Bases: nova.exception.NovaException

CellRoutingInconsistency.message = u'Inconsistency in cell routing: %(reason)s'
exception CellServiceAPIMethodNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

CellServiceAPIMethodNotFound.message = u'Service API method not found: %(detail)s'
exception CellTimeout(message=None, **kwargs)

Bases: nova.exception.NotFound

CellTimeout.message = u'Timeout waiting for response from cell'
exception CertificateNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

CertificateNotFound.message = u'Certificate %(certificate_id)s not found.'
exception CidrConflict(message=None, **kwargs)

Bases: nova.exception.NovaException

CidrConflict.code = 409
CidrConflict.message = u'There was a conflict when trying to complete your request.'
exception ClassNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

ClassNotFound.message = u'Class %(class_name)s could not be found: %(exception)s'
exception ComputeHostNotFound(message=None, **kwargs)

Bases: nova.exception.HostNotFound

ComputeHostNotFound.message = u'Compute host %(host)s could not be found.'
exception ComputeResourcesUnavailable(message=None, **kwargs)

Bases: nova.exception.ServiceUnavailable

ComputeResourcesUnavailable.message = u'Insufficient compute resources.'
exception ComputeServiceUnavailable(message=None, **kwargs)

Bases: nova.exception.ServiceUnavailable

ComputeServiceUnavailable.message = u'Compute service of %(host)s is unavailable at this time.'
exception ConfigDriveMountFailed(message=None, **kwargs)

Bases: nova.exception.NovaException

ConfigDriveMountFailed.message = u'Could not mount vfat config drive. %(operation)s failed. Error: %(error)s'
exception ConfigDriveUnknownFormat(message=None, **kwargs)

Bases: nova.exception.NovaException

ConfigDriveUnknownFormat.message = u'Unknown config drive format %(format)s. Select one of iso9660 or vfat.'
exception ConfigNotFound(message=None, **kwargs)

Bases: nova.exception.NovaException

ConfigNotFound.message = u'Could not find config at %(path)s'
exception ConsoleNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

ConsoleNotFound.message = u'Console %(console_id)s could not be found.'
exception ConsoleNotFoundForInstance(message=None, **kwargs)

Bases: nova.exception.ConsoleNotFound

ConsoleNotFoundForInstance.message = u'Console for instance %(instance_uuid)s could not be found.'
exception ConsoleNotFoundInPoolForInstance(message=None, **kwargs)

Bases: nova.exception.ConsoleNotFound

ConsoleNotFoundInPoolForInstance.message = u'Console for instance %(instance_uuid)s in pool %(pool_id)s could not be found.'
exception ConsolePoolNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

ConsolePoolNotFound.message = u'Console pool %(pool_id)s could not be found.'
exception ConsolePoolNotFoundForHostType(message=None, **kwargs)

Bases: nova.exception.NotFound

ConsolePoolNotFoundForHostType.message = u'Console pool of type %(console_type)s for compute host %(compute_host)s on proxy host %(host)s not found.'
exception ConsoleTypeInvalid(message=None, **kwargs)

Bases: nova.exception.Invalid

ConsoleTypeInvalid.message = u'Invalid console type %(console_type)s'
exception ConstraintNotMet(message=None, **kwargs)

Bases: nova.exception.NovaException

ConstraintNotMet.code = 412
ConstraintNotMet.message = u'Constraint not met.'
exception ConvertedException(code=0, title='', explanation='')

Bases: webob.exc.WSGIHTTPException

exception CouldNotFetchImage(message=None, **kwargs)

Bases: nova.exception.NovaException

CouldNotFetchImage.message = u'Could not fetch image %(image_id)s'
exception CouldNotFetchMetrics(message=None, **kwargs)

Bases: nova.exception.NovaException

CouldNotFetchMetrics.message = u'Could not fetch bandwidth/cpu/disk metrics for this host.'
exception CouldNotUploadImage(message=None, **kwargs)

Bases: nova.exception.NovaException

CouldNotUploadImage.message = u'Could not upload image %(image_id)s'
exception CryptoCAFileNotFound(message=None, **kwargs)

Bases: nova.exception.FileNotFound

CryptoCAFileNotFound.message = u'The CA file for %(project)s could not be found'
exception CryptoCRLFileNotFound(message=None, **kwargs)

Bases: nova.exception.FileNotFound

CryptoCRLFileNotFound.message = u'The CRL file for %(project)s could not be found'
exception DBNotAllowed(message=None, **kwargs)

Bases: nova.exception.NovaException

DBNotAllowed.message = u'%(binary)s attempted direct database access which is not allowed by policy'
exception DatastoreNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

DatastoreNotFound.message = u'Could not find the datastore reference(s) which the VM uses.'
exception DecryptionFailure(message=None, **kwargs)

Bases: nova.exception.NovaException

DecryptionFailure.message = u'Failed to decrypt text: %(reason)s'
exception DestinationDiskExists(message=None, **kwargs)

Bases: nova.exception.Invalid

DestinationDiskExists.message = u'The supplied disk path (%(path)s) already exists, it is expected not to exist.'
exception DestinationHypervisorTooOld(message=None, **kwargs)

Bases: nova.exception.Invalid

DestinationHypervisorTooOld.message = u'The instance requires a newer hypervisor version than has been provided.'
exception DeviceIsBusy(message=None, **kwargs)

Bases: nova.exception.Invalid

DeviceIsBusy.message = u'The supplied device (%(device)s) is busy.'
exception DevicePathInUse(message=None, **kwargs)

Bases: nova.exception.Invalid

DevicePathInUse.code = 409
DevicePathInUse.message = u'The supplied device path (%(path)s) is in use.'
exception DiskNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

DiskNotFound.message = u'No disk at %(location)s'
exception Duplicate(message=None, **kwargs)

Bases: nova.exception.NovaException

exception DuplicateVlan(message=None, **kwargs)

Bases: nova.exception.Duplicate

DuplicateVlan.message = u'Detected existing vlan with id %(vlan)d'
exception EC2APIError(message=None, code=None)

Bases: nova.exception.NovaException

EC2APIError.message = u'Unknown'
exception EncryptionFailure(message=None, **kwargs)

Bases: nova.exception.NovaException

EncryptionFailure.message = u'Failed to encrypt text: %(reason)s'
exception FileNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

FileNotFound.message = u'File %(file_path)s could not be found.'
exception FixedIpAlreadyInUse(message=None, **kwargs)

Bases: nova.exception.NovaException

FixedIpAlreadyInUse.message = u'Fixed IP address %(address)s is already in use on instance %(instance_uuid)s.'
exception FixedIpAssociatedWithMultipleInstances(message=None, **kwargs)

Bases: nova.exception.NovaException

FixedIpAssociatedWithMultipleInstances.message = u"More than one instance is associated with fixed ip address '%(address)s'."
exception FixedIpInvalid(message=None, **kwargs)

Bases: nova.exception.Invalid

FixedIpInvalid.message = u'Fixed IP address %(address)s is invalid.'
exception FixedIpLimitExceeded(message=None, **kwargs)

Bases: nova.exception.QuotaError

FixedIpLimitExceeded.message = u'Maximum number of fixed ips exceeded'
exception FixedIpNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

FixedIpNotFound.message = u'No fixed IP associated with id %(id)s.'
exception FixedIpNotFoundForAddress(message=None, **kwargs)

Bases: nova.exception.FixedIpNotFound

FixedIpNotFoundForAddress.message = u'Fixed ip not found for address %(address)s.'
exception FixedIpNotFoundForInstance(message=None, **kwargs)

Bases: nova.exception.FixedIpNotFound

FixedIpNotFoundForInstance.message = u'Instance %(instance_uuid)s has zero fixed ips.'
exception FixedIpNotFoundForNetwork(message=None, **kwargs)

Bases: nova.exception.FixedIpNotFound

FixedIpNotFoundForNetwork.message = u'Fixed IP address (%(address)s) does not exist in network (%(network_uuid)s).'
exception FixedIpNotFoundForNetworkHost(message=None, **kwargs)

Bases: nova.exception.FixedIpNotFound

FixedIpNotFoundForNetworkHost.message = u'Network host %(host)s has zero fixed ips in network %(network_id)s.'
exception FixedIpNotFoundForSpecificInstance(message=None, **kwargs)

Bases: nova.exception.FixedIpNotFound

FixedIpNotFoundForSpecificInstance.message = u"Instance %(instance_uuid)s doesn't have fixed ip '%(ip)s'."
exception FlavorAccessExists(message=None, **kwargs)

Bases: nova.exception.Duplicate

FlavorAccessExists.message = u'Flavor access alreay exists for flavor %(flavor_id)s and project %(project_id)s combination.'
exception FlavorAccessNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

FlavorAccessNotFound.message = u'Flavor access not found for %(flavor_id)s / %(project_id)s combination.'
exception FlavorNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

FlavorNotFound.message = u'Flavor %(flavor_id)s could not be found.'
exception FloatingIpAssociated(message=None, **kwargs)

Bases: nova.exception.NovaException

FloatingIpAssociated.message = u'Floating ip %(address)s is associated.'
exception FloatingIpDNSExists(message=None, **kwargs)

Bases: nova.exception.Invalid

FloatingIpDNSExists.message = u'The DNS entry %(name)s already exists in domain %(domain)s.'
exception FloatingIpExists(message=None, **kwargs)

Bases: nova.exception.Duplicate

FloatingIpExists.message = u'Floating ip %(address)s already exists.'
exception FloatingIpLimitExceeded(message=None, **kwargs)

Bases: nova.exception.QuotaError

FloatingIpLimitExceeded.message = u'Maximum number of floating ips exceeded'
exception FloatingIpMultipleFoundForAddress(message=None, **kwargs)

Bases: nova.exception.NovaException

FloatingIpMultipleFoundForAddress.message = u'Multiple floating ips are found for address %(address)s.'
exception FloatingIpNotAssociated(message=None, **kwargs)

Bases: nova.exception.NovaException

FloatingIpNotAssociated.message = u'Floating ip %(address)s is not associated.'
exception FloatingIpNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

FloatingIpNotFound.message = u'Floating ip not found for id %(id)s.'
exception FloatingIpNotFoundForAddress(message=None, **kwargs)

Bases: nova.exception.FloatingIpNotFound

FloatingIpNotFoundForAddress.message = u'Floating ip not found for address %(address)s.'
exception FloatingIpNotFoundForHost(message=None, **kwargs)

Bases: nova.exception.FloatingIpNotFound

FloatingIpNotFoundForHost.message = u'Floating ip not found for host %(host)s.'
exception FloatingIpPoolNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

FloatingIpPoolNotFound.message = u'Floating ip pool not found.'
FloatingIpPoolNotFound.safe = True
exception GlanceConnectionFailed(message=None, **kwargs)

Bases: nova.exception.NovaException

GlanceConnectionFailed.message = u'Connection to glance host %(host)s:%(port)s failed: %(reason)s'
exception HostBinaryNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

HostBinaryNotFound.message = u'Could not find binary %(binary)s on host %(host)s.'
exception HostNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

HostNotFound.message = u'Host %(host)s could not be found.'
exception ISCSITargetNotFoundForVolume(message=None, **kwargs)

Bases: nova.exception.NotFound

ISCSITargetNotFoundForVolume.message = u'No target id found for volume %(volume_id)s.'
exception ImageNotActive(message=None, **kwargs)

Bases: nova.exception.NovaException

ImageNotActive.message = u'Image %(image_id)s is not active.'
exception ImageNotAuthorized(message=None, **kwargs)

Bases: nova.exception.NovaException

ImageNotAuthorized.message = u'Not authorized for image %(image_id)s.'
exception ImageNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

ImageNotFound.message = u'Image %(image_id)s could not be found.'
exception ImageNotFoundEC2(message=None, **kwargs)

Bases: nova.exception.ImageNotFound

ImageNotFoundEC2.message = u'Image %(image_id)s could not be found. The nova EC2 API assigns image ids dynamically when they are listed for the first time. Have you listed image ids since adding this image?'
exception ImageRotationNotAllowed(message=None, **kwargs)

Bases: nova.exception.NovaException

ImageRotationNotAllowed.message = u'Rotation is not allowed for snapshots'
exception ImageTooLarge(message=None, **kwargs)

Bases: nova.exception.NovaException

ImageTooLarge.message = u'Image is larger than instance type allows'
exception ImageUnacceptable(message=None, **kwargs)

Bases: nova.exception.Invalid

ImageUnacceptable.message = u'Image %(image_id)s is unacceptable: %(reason)s'
exception InstanceActionEventNotFound(message=None, **kwargs)

Bases: nova.exception.NovaException

InstanceActionEventNotFound.message = u'Event %(event)s not found for action id %(action_id)s'
exception InstanceActionNotFound(message=None, **kwargs)

Bases: nova.exception.NovaException

InstanceActionNotFound.message = u'Action for request_id %(request_id)s on instance %(instance_uuid)s not found'
exception InstanceDeployFailure(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceDeployFailure.message = u'Failed to deploy instance: %(reason)s'
exception InstanceExists(message=None, **kwargs)

Bases: nova.exception.Duplicate

InstanceExists.message = u'Instance %(name)s already exists.'
exception InstanceInfoCacheNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

InstanceInfoCacheNotFound.message = u'Info cache for instance %(instance_uuid)s could not be found.'
exception InstanceInvalidState(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceInvalidState.message = u'Instance %(instance_uuid)s in %(attr)s %(state)s. Cannot %(method)s while the instance is in this state.'
exception InstanceIsLocked(message=None, **kwargs)

Bases: nova.exception.InstanceInvalidState

InstanceIsLocked.message = u'Instance %(instance_uuid)s is locked'
exception InstanceMetadataNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

InstanceMetadataNotFound.message = u'Instance %(instance_uuid)s has no metadata with key %(metadata_key)s.'
exception InstanceNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

InstanceNotFound.message = u'Instance %(instance_id)s could not be found.'
exception InstanceNotInRescueMode(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceNotInRescueMode.message = u'Instance %(instance_id)s is not in rescue mode'
exception InstanceNotReady(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceNotReady.message = u'Instance %(instance_id)s is not ready'
exception InstanceNotRescuable(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceNotRescuable.message = u'Instance %(instance_id)s cannot be rescued: %(reason)s'
exception InstanceNotRunning(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceNotRunning.message = u'Instance %(instance_id)s is not running.'
exception InstancePasswordSetFailed(message=None, **kwargs)

Bases: nova.exception.NovaException

InstancePasswordSetFailed.message = u'Failed to set admin password on %(instance)s because %(reason)s'
InstancePasswordSetFailed.safe = True
exception InstancePowerOffFailure(message=None, **kwargs)

Bases: nova.exception.Invalid

InstancePowerOffFailure.message = u'Failed to power off instance: %(reason)s.'
exception InstancePowerOnFailure(message=None, **kwargs)

Bases: nova.exception.Invalid

InstancePowerOnFailure.message = u'Failed to power on instance: %(reason)s.'
exception InstanceRebootFailure(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceRebootFailure.message = u'Failed to reboot instance: %(reason)s'
exception InstanceRecreateNotSupported(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceRecreateNotSupported.message = u'Instance recreate is not implemented by this virt driver.'
exception InstanceResumeFailure(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceResumeFailure.message = u'Failed to resume instance: %(reason)s.'
exception InstanceSuspendFailure(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceSuspendFailure.message = u'Failed to suspend instance: %(reason)s'
exception InstanceSystemMetadataNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

InstanceSystemMetadataNotFound.message = u'Instance %(instance_uuid)s has no system metadata with key %(metadata_key)s.'
exception InstanceTerminationFailure(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceTerminationFailure.message = u'Failed to terminate instance: %(reason)s'
exception InstanceTypeCreateFailed(message=None, **kwargs)

Bases: nova.exception.NovaException

InstanceTypeCreateFailed.message = u'Unable to create instance type'
exception InstanceTypeDiskTooSmall(message=None, **kwargs)

Bases: nova.exception.NovaException

InstanceTypeDiskTooSmall.message = u"Instance type's disk is too small for requested image."
exception InstanceTypeExists(message=None, **kwargs)

Bases: nova.exception.Duplicate

InstanceTypeExists.message = u'Instance Type with name %(name)s already exists.'
exception InstanceTypeExtraSpecsNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

InstanceTypeExtraSpecsNotFound.message = u'Instance Type %(instance_type_id)s has no extra specs with key %(extra_specs_key)s.'
exception InstanceTypeIdExists(message=None, **kwargs)

Bases: nova.exception.Duplicate

InstanceTypeIdExists.message = u'Instance Type with ID %(flavor_id)s already exists.'
exception InstanceTypeMemoryTooSmall(message=None, **kwargs)

Bases: nova.exception.NovaException

InstanceTypeMemoryTooSmall.message = u"Instance type's memory is too small for requested image."
exception InstanceTypeNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

InstanceTypeNotFound.message = u'Instance type %(instance_type_id)s could not be found.'
exception InstanceTypeNotFoundByName(message=None, **kwargs)

Bases: nova.exception.InstanceTypeNotFound

InstanceTypeNotFoundByName.message = u'Instance type with name %(instance_type_name)s could not be found.'
exception InstanceUnacceptable(message=None, **kwargs)

Bases: nova.exception.Invalid

InstanceUnacceptable.message = u'Instance %(instance_id)s is unacceptable: %(reason)s'
exception InstanceUnknownCell(message=None, **kwargs)

Bases: nova.exception.NotFound

InstanceUnknownCell.message = u'Cell is not known for instance %(instance_uuid)s'
exception InstanceUserDataMalformed(message=None, **kwargs)

Bases: nova.exception.NovaException

InstanceUserDataMalformed.message = u'User data needs to be valid base 64.'
exception InstanceUserDataTooLarge(message=None, **kwargs)

Bases: nova.exception.NovaException

InstanceUserDataTooLarge.message = u'User data too large. User data must be no larger than %(maxsize)s bytes once base64 encoded. Your data is %(length)d bytes'
exception InsufficientFreeMemory(message=None, **kwargs)

Bases: nova.exception.NovaException

InsufficientFreeMemory.message = u'Insufficient free memory on compute node to start %(uuid)s.'
exception InterfaceAttachFailed(message=None, **kwargs)

Bases: nova.exception.Invalid

InterfaceAttachFailed.message = u'Failed to attach network adapter device to %(instance)s'
exception InterfaceDetachFailed(message=None, **kwargs)

Bases: nova.exception.Invalid

InterfaceDetachFailed.message = u'Failed to detach network adapter device from %(instance)s'
exception Invalid(message=None, **kwargs)

Bases: nova.exception.NovaException

Invalid.code = 400
Invalid.message = u'Unacceptable parameters.'
exception InvalidAggregateAction(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidAggregateAction.message = u"Cannot perform action '%(action)s' on aggregate %(aggregate_id)s. Reason: %(reason)s."
exception InvalidBDM(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidBDM.message = u'Block Device Mapping is Invalid.'
exception InvalidBDMSnapshot(message=None, **kwargs)

Bases: nova.exception.InvalidBDM

InvalidBDMSnapshot.message = u'Block Device Mapping is Invalid: failed to get snapshot %(id)s.'
exception InvalidBDMVolume(message=None, **kwargs)

Bases: nova.exception.InvalidBDM

InvalidBDMVolume.message = u'Block Device Mapping is Invalid: failed to get volume %(id)s.'
exception InvalidCPUInfo(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidCPUInfo.message = u'Unacceptable CPU info: %(reason)s'
exception InvalidCidr(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidCidr.message = u'Invalid cidr %(cidr)s.'
exception InvalidContentType(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidContentType.message = u'Invalid content type %(content_type)s.'
exception InvalidDevicePath(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidDevicePath.message = u'The supplied device path (%(path)s) is invalid.'
exception InvalidDiskFormat(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidDiskFormat.message = u'Disk format %(disk_format)s is not acceptable'
exception InvalidEc2Id(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidEc2Id.message = u'Ec2 id %(ec2_id)s is unacceptable.'
exception InvalidGroup(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidGroup.message = u'Group not valid. Reason: %(reason)s'
exception InvalidHypervisorType(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidHypervisorType.message = u'The supplied hypervisor type of is invalid.'
exception InvalidID(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidID.message = u'Invalid ID received %(id)s.'
exception InvalidImageRef(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidImageRef.message = u'Invalid image href %(image_href)s.'
exception InvalidInput(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidInput.message = u'Invalid input received: %(reason)s'
exception InvalidInstanceIDMalformed(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidInstanceIDMalformed.message = u'Invalid id: %(val)s (expecting "i-...").'
exception InvalidIpAddressError(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidIpAddressError.message = u'%(address)s is not a valid IP v4/6 address.'
exception InvalidIpProtocol(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidIpProtocol.message = u'Invalid IP protocol %(protocol)s.'
exception InvalidKeypair(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidKeypair.message = u'Keypair data is invalid'
exception InvalidLocalStorage(message=None, **kwargs)

Bases: nova.exception.NovaException

InvalidLocalStorage.message = u'%(path)s is not on local storage: %(reason)s'
exception InvalidMetadata(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidMetadata.message = u'Invalid metadata: %(reason)s'
exception InvalidMetadataSize(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidMetadataSize.message = u'Invalid metadata size: %(reason)s'
exception InvalidParameterValue(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidParameterValue.message = u'%(err)s'
exception InvalidPeriodicTaskArg(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidPeriodicTaskArg.message = u'Unexpected argument for periodic task creation: %(arg)s.'
exception InvalidPortRange(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidPortRange.message = u'Invalid port range %(from_port)s:%(to_port)s. %(msg)s'
exception InvalidQuotaValue(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidQuotaValue.message = u'Change would make usage less than 0 for the following resources: %(unders)s'
exception InvalidRequest(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidRequest.message = u'The request is invalid.'
exception InvalidReservationExpiration(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidReservationExpiration.message = u'Invalid reservation expiration %(expire)s.'
exception InvalidSharedStorage(message=None, **kwargs)

Bases: nova.exception.NovaException

InvalidSharedStorage.message = u'%(path)s is not on shared storage: %(reason)s'
exception InvalidSortKey(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidSortKey.message = u'Sort key supplied was not valid.'
exception InvalidUUID(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidUUID.message = u'Expected a uuid but received %(uuid)s.'
exception InvalidUnicodeParameter(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidUnicodeParameter.message = u'Invalid Parameter: Unicode is not supported by the current database.'
exception InvalidVLANPortGroup(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidVLANPortGroup.message = u'vSwitch which contains the port group %(bridge)s is not associated with the desired physical adapter. Expected vSwitch is %(expected)s, but the one associated is %(actual)s.'
exception InvalidVLANTag(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidVLANTag.message = u'VLAN tag is not appropriate for the port group %(bridge)s. Expected VLAN tag is %(tag)s, but the one associated with the port group is %(pgroup)s.'
exception InvalidVolume(message=None, **kwargs)

Bases: nova.exception.Invalid

InvalidVolume.message = u'Invalid volume: %(reason)s'
exception KeyPairExists(message=None, **kwargs)

Bases: nova.exception.Duplicate

KeyPairExists.message = u'Key pair %(key_name)s already exists.'
exception KeypairLimitExceeded(message=None, **kwargs)

Bases: nova.exception.QuotaError

KeypairLimitExceeded.message = u'Maximum number of key pairs exceeded'
exception KeypairNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

KeypairNotFound.message = u'Keypair %(name)s not found for user %(user_id)s'
exception MalformedRequestBody(message=None, **kwargs)

Bases: nova.exception.NovaException

MalformedRequestBody.message = u'Malformed message body: %(reason)s'
exception MarkerNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

MarkerNotFound.message = u'Marker %(marker)s could not be found.'
exception MetadataLimitExceeded(message=None, **kwargs)

Bases: nova.exception.QuotaError

MetadataLimitExceeded.message = u'Maximum number of metadata items exceeds %(allowed)d'
exception MigrationError(message=None, **kwargs)

Bases: nova.exception.NovaException

MigrationError.message = u'Migration error: %(reason)s'
exception MigrationNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

MigrationNotFound.message = u'Migration %(migration_id)s could not be found.'
exception MigrationNotFoundByStatus(message=None, **kwargs)

Bases: nova.exception.MigrationNotFound

MigrationNotFoundByStatus.message = u'Migration not found for instance %(instance_id)s with status %(status)s.'
exception MigrationPreCheckError(message=None, **kwargs)

Bases: nova.exception.MigrationError

MigrationPreCheckError.message = u'Migration pre-check error: %(reason)s'
exception NetworkAdapterNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

NetworkAdapterNotFound.message = u'Network adapter %(adapter)s could not be found.'
exception NetworkDuplicated(message=None, **kwargs)

Bases: nova.exception.NovaException

NetworkDuplicated.message = u'Network %(network_id)s is duplicated.'
exception NetworkInUse(message=None, **kwargs)

Bases: nova.exception.NovaException

NetworkInUse.message = u'Network %(network_id)s is still in use.'
exception NetworkNotCreated(message=None, **kwargs)

Bases: nova.exception.NovaException

NetworkNotCreated.message = u'%(req)s is required to create a network.'
exception NetworkNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

NetworkNotFound.message = u'Network %(network_id)s could not be found.'
exception NetworkNotFoundForBridge(message=None, **kwargs)

Bases: nova.exception.NetworkNotFound

NetworkNotFoundForBridge.message = u'Network could not be found for bridge %(bridge)s'
exception NetworkNotFoundForCidr(message=None, **kwargs)

Bases: nova.exception.NetworkNotFound

NetworkNotFoundForCidr.message = u'Network could not be found with cidr %(cidr)s.'
exception NetworkNotFoundForInstance(message=None, **kwargs)

Bases: nova.exception.NetworkNotFound

NetworkNotFoundForInstance.message = u'Network could not be found for instance %(instance_id)s.'
exception NetworkNotFoundForProject(message=None, **kwargs)

Bases: nova.exception.NotFound

NetworkNotFoundForProject.message = u'Either Network uuid %(network_uuid)s is not present or is not assigned to the project %(project_id)s.'
exception NetworkNotFoundForUUID(message=None, **kwargs)

Bases: nova.exception.NetworkNotFound

NetworkNotFoundForUUID.message = u'Network could not be found for uuid %(uuid)s'
exception NoCellsAvailable(message=None, **kwargs)

Bases: nova.exception.NovaException

NoCellsAvailable.message = u'No cells available matching scheduling criteria.'
exception NoFilesFound(message=None, **kwargs)

Bases: nova.exception.NotFound

NoFilesFound.message = u'Zero files could be found.'
exception NoFixedIpsDefined(message=None, **kwargs)

Bases: nova.exception.NotFound

NoFixedIpsDefined.message = u'Zero fixed ips could be found.'
exception NoFloatingIpInterface(message=None, **kwargs)

Bases: nova.exception.NotFound

NoFloatingIpInterface.message = u'Interface %(interface)s not found.'
exception NoFloatingIpsDefined(message=None, **kwargs)

Bases: nova.exception.NotFound

NoFloatingIpsDefined.message = u'Zero floating ips exist.'
exception NoMoreFixedIps(message=None, **kwargs)

Bases: nova.exception.NovaException

NoMoreFixedIps.message = u'Zero fixed ips available.'
exception NoMoreFloatingIps(message=None, **kwargs)

Bases: nova.exception.FloatingIpNotFound

NoMoreFloatingIps.message = u'Zero floating ips available.'
NoMoreFloatingIps.safe = True
exception NoNetworksFound(message=None, **kwargs)

Bases: nova.exception.NotFound

NoNetworksFound.message = u'No networks defined.'
exception NoUniqueMatch(message=None, **kwargs)

Bases: nova.exception.NovaException

NoUniqueMatch.code = 409
NoUniqueMatch.message = u'No Unique Match Found.'
exception NoValidHost(message=None, **kwargs)

Bases: nova.exception.NovaException

NoValidHost.message = u'No valid host was found. %(reason)s'
exception NodeNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

NodeNotFound.message = u'Node %(node_id)s could not be found.'
exception NodeNotFoundByUUID(message=None, **kwargs)

Bases: nova.exception.NotFound

NodeNotFoundByUUID.message = u'Node with UUID %(node_uuid)s could not be found.'
exception NotAllowed(message=None, **kwargs)

Bases: nova.exception.NovaException

NotAllowed.message = u'Action not allowed.'
exception NotAuthorized(message=None, **kwargs)

Bases: nova.exception.NovaException

NotAuthorized.code = 403
NotAuthorized.message = u'Not authorized.'
exception NotFound(message=None, **kwargs)

Bases: nova.exception.NovaException

NotFound.code = 404
NotFound.message = u'Resource could not be found.'
exception NovaException(message=None, **kwargs)

Bases: exceptions.Exception

Base Nova Exception

To correctly use this class, inherit from it and define a ‘message’ property. That message will get printf’d with the keyword arguments provided to the constructor.

NovaException.code = 500
NovaException.format_message()
NovaException.headers = {}
NovaException.message = u'An unknown exception occurred.'
NovaException.safe = False
exception OnsetFileContentLimitExceeded(message=None, **kwargs)

Bases: nova.exception.QuotaError

OnsetFileContentLimitExceeded.message = u'Personality file content too long'
exception OnsetFileLimitExceeded(message=None, **kwargs)

Bases: nova.exception.QuotaError

OnsetFileLimitExceeded.message = u'Personality file limit exceeded'
exception OnsetFilePathLimitExceeded(message=None, **kwargs)

Bases: nova.exception.QuotaError

OnsetFilePathLimitExceeded.message = u'Personality file path too long'
exception OverQuota(message=None, **kwargs)

Bases: nova.exception.NovaException

OverQuota.message = u'Quota exceeded for resources: %(overs)s'
exception PasteAppNotFound(message=None, **kwargs)

Bases: nova.exception.NovaException

PasteAppNotFound.message = u"Could not load paste app '%(name)s' from %(path)s"
exception PolicyNotAuthorized(message=None, **kwargs)

Bases: nova.exception.NotAuthorized

PolicyNotAuthorized.message = u"Policy doesn't allow %(action)s to be performed."
exception PortInUse(message=None, **kwargs)

Bases: nova.exception.NovaException

PortInUse.message = u'Port %(port_id)s is still in use.'
exception PortNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

PortNotFound.message = u'Port id %(port_id)s could not be found.'
exception PortNotFree(message=None, **kwargs)

Bases: nova.exception.NovaException

PortNotFree.message = u'No free port available for instance %(instance)s.'
exception PortNotUsable(message=None, **kwargs)

Bases: nova.exception.NovaException

PortNotUsable.message = u'Port %(port_id)s not usable for instance %(instance)s.'
exception ProcessExecutionError(stdout=None, stderr=None, exit_code=None, cmd=None, description=None)

Bases: exceptions.IOError

exception ProjectNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

ProjectNotFound.message = u'Project %(project_id)s could not be found.'
exception ProjectQuotaNotFound(message=None, **kwargs)

Bases: nova.exception.QuotaNotFound

ProjectQuotaNotFound.message = u'Quota for project %(project_id)s could not be found.'
exception QuotaClassNotFound(message=None, **kwargs)

Bases: nova.exception.QuotaNotFound

QuotaClassNotFound.message = u'Quota class %(class_name)s could not be found.'
exception QuotaError(message=None, **kwargs)

Bases: nova.exception.NovaException

QuotaError.code = 413
QuotaError.headers = {'Retry-After': 0}
QuotaError.message = u'Quota exceeded: code=%(code)s'
QuotaError.safe = True
exception QuotaNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

QuotaNotFound.message = u'Quota could not be found'
exception QuotaResourceUnknown(message=None, **kwargs)

Bases: nova.exception.QuotaNotFound

QuotaResourceUnknown.message = u'Unknown quota resources %(unknown)s.'
exception QuotaUsageNotFound(message=None, **kwargs)

Bases: nova.exception.QuotaNotFound

QuotaUsageNotFound.message = u'Quota usage for project %(project_id)s could not be found.'
exception ReservationNotFound(message=None, **kwargs)

Bases: nova.exception.QuotaNotFound

ReservationNotFound.message = u'Quota reservation %(uuid)s could not be found.'
exception ResizeError(message=None, **kwargs)

Bases: nova.exception.NovaException

ResizeError.message = u'Resize error: %(reason)s'
exception RotationRequiredForBackup(message=None, **kwargs)

Bases: nova.exception.NovaException

RotationRequiredForBackup.message = u'Rotation param is required for backup image_type'
exception SchedulerCostFunctionNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

SchedulerCostFunctionNotFound.message = u'Scheduler cost function %(cost_fn_str)s could not be found.'
exception SchedulerHostFilterNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

SchedulerHostFilterNotFound.message = u'Scheduler Host Filter %(filter_name)s could not be found.'
exception SchedulerWeightFlagNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

SchedulerWeightFlagNotFound.message = u'Scheduler weight flag not found: %(flag_name)s'
exception SecurityGroupCannotBeApplied(message=None, **kwargs)

Bases: nova.exception.Invalid

SecurityGroupCannotBeApplied.message = u'Network requires port_security_enabled and subnet associated in order to apply security groups.'
exception SecurityGroupDefaultRuleNotFound(message=None, **kwargs)

Bases: nova.exception.Invalid

SecurityGroupDefaultRuleNotFound.message = u'Security group default rule (%rule_id)s not found.'
exception SecurityGroupExistsForInstance(message=None, **kwargs)

Bases: nova.exception.Invalid

SecurityGroupExistsForInstance.message = u'Security group %(security_group_id)s is already associated with the instance %(instance_id)s'
exception SecurityGroupLimitExceeded(message=None, **kwargs)

Bases: nova.exception.QuotaError

SecurityGroupLimitExceeded.message = u'Maximum number of security groups or rules exceeded'
exception SecurityGroupNotExistsForInstance(message=None, **kwargs)

Bases: nova.exception.Invalid

SecurityGroupNotExistsForInstance.message = u'Security group %(security_group_id)s is not associated with the instance %(instance_id)s'
exception SecurityGroupNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

SecurityGroupNotFound.message = u'Security group %(security_group_id)s not found.'
exception SecurityGroupNotFoundForProject(message=None, **kwargs)

Bases: nova.exception.SecurityGroupNotFound

SecurityGroupNotFoundForProject.message = u'Security group %(security_group_id)s not found for project %(project_id)s.'
exception SecurityGroupNotFoundForRule(message=None, **kwargs)

Bases: nova.exception.SecurityGroupNotFound

SecurityGroupNotFoundForRule.message = u'Security group with rule %(rule_id)s not found.'
exception ServiceGroupUnavailable(message=None, **kwargs)

Bases: nova.exception.NovaException

ServiceGroupUnavailable.message = u'The service from servicegroup driver %(driver) is temporarily unavailable.'
exception ServiceNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

ServiceNotFound.message = u'Service %(service_id)s could not be found.'
exception ServiceUnavailable(message=None, **kwargs)

Bases: nova.exception.Invalid

ServiceUnavailable.message = u'Service is unavailable at this time.'
exception SnapshotNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

SnapshotNotFound.message = u'Snapshot %(snapshot_id)s could not be found.'
exception StorageRepositoryNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

StorageRepositoryNotFound.message = u'Cannot find SR to read/write VDI.'
exception SwitchNotFoundForNetworkAdapter(message=None, **kwargs)

Bases: nova.exception.NotFound

SwitchNotFoundForNetworkAdapter.message = u'Virtual switch associated with the network adapter %(adapter)s not found.'
exception TaskAlreadyRunning(message=None, **kwargs)

Bases: nova.exception.NovaException

TaskAlreadyRunning.message = u'Task %(task_name)s is already running on host %(host)s'
exception TaskNotRunning(message=None, **kwargs)

Bases: nova.exception.NovaException

TaskNotRunning.message = u'Task %(task_name)s is not running on host %(host)s'
exception TooManyInstances(message=None, **kwargs)

Bases: nova.exception.QuotaError

TooManyInstances.message = u'Quota exceeded for %(overs)s: Requested %(req)s, but already used %(used)d of %(allowed)d %(resource)s'
exception UnableToMigrateToSelf(message=None, **kwargs)

Bases: nova.exception.Invalid

UnableToMigrateToSelf.message = u'Unable to migrate instance (%(instance_id)s) to current host (%(host)s).'
exception UnexpectedTaskStateError(message=None, **kwargs)

Bases: nova.exception.NovaException

UnexpectedTaskStateError.message = u'unexpected task state: expecting %(expected)s but the actual state is %(actual)s'
exception UnsupportedHardware(message=None, **kwargs)

Bases: nova.exception.Invalid

UnsupportedHardware.message = u"Requested hardware '%(model)s' is not supported by the '%(virt)s' virt driver"
exception UnsupportedVirtType(message=None, **kwargs)

Bases: nova.exception.Invalid

UnsupportedVirtType.message = u"Virtualization type '%(virt)s' is not supported by this compute driver"
exception VirtualInterfaceCreateException(message=None, **kwargs)

Bases: nova.exception.NovaException

VirtualInterfaceCreateException.message = u'Virtual Interface creation failed'
exception VirtualInterfaceMacAddressException(message=None, **kwargs)

Bases: nova.exception.NovaException

VirtualInterfaceMacAddressException.message = u'5 attempts to create virtual interfacewith unique mac address failed'
exception VolumeDriverNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

VolumeDriverNotFound.message = u'Could not find a handler for %(driver_type)s volume.'
exception VolumeNotFound(message=None, **kwargs)

Bases: nova.exception.NotFound

VolumeNotFound.message = u'Volume %(volume_id)s could not be found.'
exception VolumeUnattached(message=None, **kwargs)

Bases: nova.exception.Invalid

VolumeUnattached.message = u'Volume %(volume_id)s is not attached to anything'
wrap_exception(notifier=None, publisher_id=None, event_type=None, level=None)

This decorator wraps a method to catch any exceptions that may get thrown. It logs the exception as well as optionally sending it to the notification system.

The nova.flags Module

The nova.process Module

The nova.rpc Module

The nova.server Module

The nova.test Module

Base classes for our unit tests.

Allows overriding of flags for use of fakes, and some black magic for inline callbacks.

class APICoverage

Bases: object

APICoverage.cover_api = None
APICoverage.test_api_methods()
class Database(db_session, db_migrate, sql_connection, sqlite_db, sqlite_clean_db)

Bases: fixtures.fixture.Fixture

Database.post_migrations()

Any addition steps that are needed outside of the migrations.

Database.setUp()
class MoxStubout

Bases: fixtures.fixture.Fixture

Deal with code around mox and stubout as a fixture.

MoxStubout.setUp()
class ReplaceModule(name, new_value)

Bases: fixtures.fixture.Fixture

Replace a module with a fake module.

ReplaceModule.setUp()
class ServiceFixture(name, host=None, **kwargs)

Bases: fixtures.fixture.Fixture

Run a service as a test fixture.

ServiceFixture.setUp()
class TestCase(*args, **kwargs)

Bases: testtools.testcase.TestCase

Test case base class for all unit tests.

TestCase.flags(**kw)

Override flag variables for a test.

TestCase.setUp()

Run before each test method to initialize test environment.

TestCase.start_service(name, host=None, **kwargs)
exception TestingException

Bases: exceptions.Exception

class TimeOverride

Bases: fixtures.fixture.Fixture

Fixture to start and remove time override.

TimeOverride.setUp()

The nova.utils Module

Utilities and helper functions.

class DynamicLoopingCall(f=None, *args, **kw)

Bases: nova.utils.LoopingCallBase

A looping call which happens sleeps until the next known event.

The function called should return how long to sleep for before being called again.

DynamicLoopingCall.start(initial_delay=None, periodic_interval_max=None)
class ExceptionHelper(target)

Bases: object

Class to wrap another and translate the ClientExceptions raised by its function calls to the actual ones

class FixedIntervalLoopingCall(f=None, *args, **kw)

Bases: nova.utils.LoopingCallBase

A looping call which happens at a fixed interval.

FixedIntervalLoopingCall.start(interval, initial_delay=None)
class LazyPluggable(pivot, config_group=None, **backends)

Bases: object

A pluggable backend loaded lazily based on some value.

class LoopingCallBase(f=None, *args, **kw)

Bases: object

LoopingCallBase.stop()
LoopingCallBase.wait()
exception LoopingCallDone(retvalue=True)

Bases: exceptions.Exception

Exception to break out and stop a LoopingCall.

The poll-function passed to LoopingCall can raise this exception to break out of the loop normally. This is somewhat analogous to StopIteration.

An optional return-value can be included as the argument to the exception; this return-value will be returned by LoopingCall.wait()

class UndoManager

Bases: object

Provides a mechanism to facilitate rolling back a series of actions when an exception is raised.

UndoManager.rollback_and_reraise(msg=None, **kwargs)

Rollback a series of actions then re-raise the exception.

Note

(sirp) This should only be called within an exception handler.

UndoManager.undo_with(undo_func)
bool_from_str(val)

Convert a string representation of a bool into a bool value.

check_isinstance(obj, cls)

Checks that obj is of type cls, and lets PyLint infer types.

check_string_length(value, name, min_length=0, max_length=None)

Check the length of specified string :param value: the value of the string :param name: the name of the string :param min_length: the min_length of the string :param max_length: the max_length of the string

convert_to_list_dict(lst, label)

Convert a value or list into a list of dicts.

debug(arg)
delete_if_exists(pathname)

delete a file, but ignore file not found error.

dict_to_metadata(metadata)
diff_dict(orig, new)

Return a dict describing how to change orig to new. The keys correspond to values that have changed; the value will be a list of one or two elements. The first element of the list will be either ‘+’ or ‘-‘, indicating whether the key was updated or deleted; if the key was updated, the list will contain a second element, giving the updated value.

execute(*cmd, **kwargs)

Helper method to execute command with optional retry.

If you add a run_as_root=True command, don’t forget to add the corresponding filter to etc/nova/rootwrap.d !

Parameters:
  • cmd – Passed to subprocess.Popen.
  • process_input – Send to opened process.
  • check_exit_code – Single bool, int, or list of allowed exit codes. Defaults to [0]. Raise exception.ProcessExecutionError unless program exits with one of these code.
  • delay_on_retry – True | False. Defaults to True. If set to True, wait a short amount of time before retrying.
  • attempts – How many times to retry cmd.
  • run_as_root – True | False. Defaults to False. If set to True, the command is run with rootwrap.
Raises:
  • exception.NovaException – on receiving unknown arguments
  • exception.ProcessExecutionError
Returns:

a tuple, (stdout, stderr) from the spawned process, or None if the command fails.

file_open(*args, **kwargs)

Open file

see built-in file() documentation for more details

Note: The reason this is kept in a separate module is to easily
be able to provide a stub module that doesn’t alter system state at all (for unit tests)
flatten_dict(dict_, flattened=None)

Recursively flatten a nested dictionary.

generate_mac_address()

Generate an Ethernet MAC address.

generate_password(length=None, symbolgroups=('23456789', 'ABCDEFGHJKLMNPQRSTUVWXYZ', 'abcdefghijkmnopqrstuvwxyz'))

Generate a random password from the supplied symbol groups.

At least one symbol from each group will be included. Unpredictable results if length is less than the number of symbol groups.

Believed to be reasonably secure (with a reasonable password length!)

generate_uid(topic, size=8)
get_from_path(items, path)

Returns a list of items matching the specified path.

Takes an XPath-like expression e.g. prop1/prop2/prop3, and for each item in items, looks up items[prop1][prop2][prop3]. Like XPath, if any of the intermediate results are lists it will treat each list item individually. A ‘None’ in items or any child expressions will be ignored, this function will not throw because of None (anywhere) in items. The returned list will contain no None values.

get_ip_version(network)

Returns the IP version of a network (IPv4 or IPv6). Raises AddrFormatError if invalid network.

get_my_linklocal(interface)
get_shortened_ipv6(address)
get_shortened_ipv6_cidr(address)
get_wrapped_function(function)

Get the method at the bottom of a stack of decorators.

hash_file(file_like_object)

Generate a hash for the contents of a file.

is_int_like(val)

Check if a value looks like an int.

is_valid_boolstr(val)

Check if the provided string is a valid bool string or not.

is_valid_cidr(address)

Check if the provided ipv4 or ipv6 address is a valid CIDR address or not

is_valid_ipv4(address)

Verify that address represents a valid IPv4 address.

is_valid_ipv6(address)
is_valid_ipv6_cidr(address)
last_bytes(file_like_object, num)

Return num bytes from the end of the file, and remaining byte count.

Parameters:
  • file_like_object – The file to read
  • num – The number of bytes to return

:returns (data, remaining)

last_completed_audit_period(unit=None, before=None)

This method gives you the most recently completed audit period.

arguments:
units: string, one of ‘hour’, ‘day’, ‘month’, ‘year’
Periods normally begin at the beginning (UTC) of the period unit (So a ‘day’ period begins at midnight UTC, a ‘month’ unit on the 1st, a ‘year’ on Jan, 1) unit string may be appended with an optional offset like so: 'day@18‘ This will begin the period at 18:00 UTC. 'month@15‘ starts a monthly period on the 15th, and year@3 begins a yearly one on March 1st.
before: Give the audit period most recently completed before
<timestamp>. Defaults to now.
returns: 2 tuple of datetimes (begin, end)
The begin timestamp of this audit period is the same as the end of the previous.
last_octet(address)
make_dev_path(dev, partition=None, base='/dev')

Return a path to a particular device.

>>> make_dev_path('xvdc')
/dev/xvdc
>>> make_dev_path('xvdc', 1)
/dev/xvdc1
map_dict_keys(dict_, key_map)

Return a dict in which the dictionaries keys are mapped to new keys.

metadata_to_dict(metadata)
mkfs(fs, path, label=None)

Format a file or block device

Parameters:
  • fs – Filesystem type (examples include ‘swap’, ‘ext3’, ‘ext4’ ‘btrfs’, etc.)
  • path – Path to file or block device to format
  • label – Volume label to use
monkey_patch()

If the Flags.monkey_patch set as True, this function patches a decorator for all functions in specified modules. You can set decorators for each modules using CONF.monkey_patch_modules. The format is “Module path:Decorator function”. Example:

‘nova.api.ec2.cloud:nova.openstack.common.notifier.api.notify_decorator’

Parameters of the decorator is as follows. (See nova.openstack.common.notifier.api.notify_decorator)

name - name of the function function - object of the function

novadir()
parse_mailmap(mailmap='.mailmap')
parse_server_string(server_str)

Parses the given server_string and returns a list of host and port. If it’s not a combination of host part and port, the port element is a null string. If the input is invalid expression, return a null list.

partition_dict(dict_, keys)

Return two dicts, one with keys the other with everything else.

read_cached_file(filename, cache_info, reload_func=None)

Read from a file if it has been modified.

Parameters:
  • cache_info – dictionary to hold opaque cache.
  • reload_func – optional function to be called with data when file is reloaded due to a modification.
Returns:

data from file

read_file_as_root(file_path)

Secure helper to read file as root.

remove_path_on_error(*args, **kwds)

Protect code that wants to operate on PATH atomically. Any exception will cause PATH to be removed.

sanitize_hostname(hostname)

Return a hostname which conforms to RFC-952 and RFC-1123 specs.

ssh_execute(ssh, cmd, process_input=None, addl_env=None, check_exit_code=True)
str_dict_replace(s, mapping)
subset_dict(dict_, keys)

Return a dict that only contains a subset of keys.

tempdir(*args, **kwds)
temporary_chown(*args, **kwds)

Temporarily chown a path.

Params owner_uid:
 UID of temporary owner (defaults to current user)
temporary_mutation(*args, **kwds)

Temporarily set the attr on a particular object to a given value then revert when finished.

One use of this is to temporarily set the read_deleted flag on a context object:

with temporary_mutation(context, read_deleted=”yes”):
do_something_that_needed_deleted_objects()
timefunc(func)

Decorator that logs how long a particular function took to execute.

to_bytes(text, default=0)

Try to turn a string into a number of bytes. Looks at the last characters of the text to determine what conversion is needed to turn the input text into a byte number.

Supports: B/b, K/k, M/m, G/g, T/t (or the same with b/B on the end)

total_seconds(td)

Local total_seconds implementation for compatibility with python 2.6.

trycmd(*args, **kwargs)

A wrapper around execute() to more easily handle warnings and errors.

Returns an (out, err) tuple of strings containing the output of the command’s stdout and stderr. If ‘err’ is not empty then the command can be considered to have failed.

:discard_warnings True | False. Defaults to False. If set to True,
then for succeeding commands, stderr is cleared
utf8(value)

Try to turn a string into utf-8 if possible.

Code is directly from the utf8 function in http://github.com/facebook/tornado/blob/master/tornado/escape.py

vpn_ping(address, port, timeout=0.05, session_id=None)

Sends a vpn negotiation packet and returns the server session.

Returns False on a failure. Basic packet structure is below.

Client packet (14 bytes):

 0 1      8 9  13
+-+--------+-----+
|x| cli_id |?????|
+-+--------+-----+
x = packet identifier 0x38
cli_id = 64 bit identifier
? = unknown, probably flags/padding

Server packet (26 bytes):

 0 1      8 9  13 14    21 2225
+-+--------+-----+--------+----+
|x| srv_id |?????| cli_id |????|
+-+--------+-----+--------+----+
x = packet identifier 0x40
cli_id = 64 bit identifier
? = unknown, probably flags/padding
bit 9 was 1 and the rest were 0 in testing
walk_class_hierarchy(clazz, encountered=None)

Walk class hierarchy, yielding most derived classes first.

xhtml_escape(value)

Escapes a string so it is valid within XML or XHTML.

The nova.validate Module

The nova.wsgi Module

Utility methods for working with WSGI servers.

class Application

Bases: object

Base WSGI application wrapper. Subclasses need to implement __call__.

classmethod Application.factory(global_config, **local_config)

Used for paste app factories in paste.deploy config files.

Any local configuration (that is, values under the [app:APPNAME] section of the paste config) will be passed into the __init__ method as kwargs.

A hypothetical configuration would look like:

[app:wadl] latest_version = 1.3 paste.app_factory = nova.api.fancy_api:Wadl.factory

which would result in a call to the Wadl class as

import nova.api.fancy_api fancy_api.Wadl(latest_version=‘1.3’)

You could of course re-implement the factory method in subclasses, but using the kwarg passing it shouldn’t be necessary.

class Debug(application)

Bases: nova.wsgi.Middleware

Helper class for debugging a WSGI application.

Can be inserted into any WSGI application chain to get information about the request and response.

static Debug.print_generator(app_iter)

Iterator that prints the contents of a wrapper string.

class Loader(config_path=None)

Bases: object

Used to load WSGI applications from paste configurations.

Loader.load_app(name)

Return the paste URLMap wrapped WSGI application.

Parameters:name – Name of the application to load.
Returns:Paste URLMap object wrapping the requested application.
Raises :nova.exception.PasteAppNotFound
class Middleware(application)

Bases: nova.wsgi.Application

Base WSGI middleware.

These classes require an application to be initialized that will be called next. By default the middleware will simply call its wrapped app, or you can override __call__ to customize its behavior.

classmethod Middleware.factory(global_config, **local_config)

Used for paste app factories in paste.deploy config files.

Any local configuration (that is, values under the [filter:APPNAME] section of the paste config) will be passed into the __init__ method as kwargs.

A hypothetical configuration would look like:

[filter:analytics] redis_host = 127.0.0.1 paste.filter_factory = nova.api.analytics:Analytics.factory

which would result in a call to the Analytics class as

import nova.api.analytics analytics.Analytics(app_from_paste, redis_host=‘127.0.0.1’)

You could of course re-implement the factory method in subclasses, but using the kwarg passing it shouldn’t be necessary.

Middleware.process_request(req)

Called on each request.

If this returns None, the next application down the stack will be executed. If it returns a response then that response will be returned and execution will stop here.

Middleware.process_response(response)

Do whatever you’d like to the response.

class Request(environ, charset=None, unicode_errors=None, decode_param_names=None, **kw)

Bases: webob.request.Request

class Router(mapper)

Bases: object

WSGI middleware that maps incoming requests to WSGI apps.

class Server(name, app, host='0.0.0.0', port=0, pool_size=None, protocol=<class eventlet.wsgi.HttpProtocol at 0xb12ba7c>, backlog=128, use_ssl=False, max_url_len=None)

Bases: object

Server class to manage a WSGI server, serving a WSGI application.

Server.default_pool_size = 1000
Server.start()

Start serving a WSGI application.

Returns:None
Server.stop()

Stop this server.

This is not a very nice action, as currently the method by which a server is stopped is by killing its eventlet.

Returns:None
Server.wait()

Block, until the server has stopped.

Waits on the server’s eventlet to finish, then returns.

Returns:None

Tests

The declare_flags Module

The fake_flags Module

The flags_unittest Module

The process_unittest Module

The real_flags Module

The rpc_unittest Module

The runtime_flags Module

The validator_unittest Module