Peter Hamilton b4c3980da0 Update the Query payloads to rename Protection Storage Masks
This change makes a simple renaming update to the Query response
payload, correcting how Protection Storage Masks are used and
referenced. All related unit tests have been updated to reflect
this change.
2019-05-03 12:03:16 -04:00

1179 lines
45 KiB
Python

# Copyright (c) 2015 The Johns Hopkins University/Applied Physics Laboratory
# All Rights Reserved.
#
# 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.
import six
from kmip.core import enums
from kmip.core import exceptions
from kmip.core import misc
from kmip.core import objects
from kmip.core import primitives
from kmip.core import utils
class QueryRequestPayload(primitives.Struct):
"""
A request payload for the Query operation.
The payload contains a list of query functions that the KMIP server should
respond to. See Section 4.25 of the KMIP 1.1 specification for more
information.
Attributes:
query_functions: A list of QueryFunction enumerations.
"""
def __init__(self, query_functions=None):
"""
Construct a QueryRequestPayload object.
Args:
query_functions (list): A list of QueryFunction enumerations.
"""
super(QueryRequestPayload, self).__init__(enums.Tags.REQUEST_PAYLOAD)
self._query_functions = None
self.query_functions = query_functions
@property
def query_functions(self):
if self._query_functions:
return [x.value for x in self._query_functions]
return None
@query_functions.setter
def query_functions(self, value):
if value is None:
self._query_functions = None
elif isinstance(value, list):
query_functions = []
for v in value:
if isinstance(v, enums.QueryFunction):
query_functions.append(
primitives.Enumeration(
enums.QueryFunction,
value=v,
tag=enums.Tags.QUERY_FUNCTION
)
)
else:
raise TypeError(
"The query functions must be a list of QueryFunction "
"enumerations."
)
self._query_functions = query_functions
else:
raise TypeError(
"The query functions must be a list of QueryFunction "
"enumerations."
)
def read(self, input_buffer, kmip_version=enums.KMIPVersion.KMIP_1_0):
"""
Read the data encoding the QueryRequestPayload object and decode it
into its constituent parts.
Args:
input_buffer (Stream): A data stream containing encoded object
data, supporting a read method; usually a BytearrayStream
object.
kmip_version (KMIPVersion): An enumeration defining the KMIP
version with which the object will be decoded. Optional,
defaults to KMIP 1.0.
Raises:
InvalidKmipEncoding: Raised if the query functions are missing
from the encoded payload.
"""
super(QueryRequestPayload, self).read(
input_buffer,
kmip_version=kmip_version
)
local_buffer = utils.BytearrayStream(input_buffer.read(self.length))
query_functions = []
while(self.is_tag_next(enums.Tags.QUERY_FUNCTION, local_buffer)):
query_function = primitives.Enumeration(
enums.QueryFunction,
tag=enums.Tags.QUERY_FUNCTION
)
query_function.read(local_buffer, kmip_version=kmip_version)
query_functions.append(query_function)
if query_functions:
self._query_functions = query_functions
else:
raise exceptions.InvalidKmipEncoding(
"The Query request payload encoding is missing the query "
"functions."
)
self.is_oversized(local_buffer)
def write(self, output_buffer, kmip_version=enums.KMIPVersion.KMIP_1_0):
"""
Write the data encoding the QueryRequestPayload object to a stream.
Args:
output_buffer (Stream): A data stream in which to encode object
data, supporting a write method; usually a BytearrayStream
object.
kmip_version (KMIPVersion): An enumeration defining the KMIP
version with which the object will be encoded. Optional,
defaults to KMIP 1.0.
Raises:
InvalidField: Raised if the query functions are not defined.
"""
local_buffer = utils.BytearrayStream()
if self._query_functions:
for query_function in self._query_functions:
query_function.write(local_buffer, kmip_version=kmip_version)
else:
raise exceptions.InvalidField(
"The Query request payload is missing the query functions "
"field."
)
self.length = local_buffer.length()
super(QueryRequestPayload, self).write(
output_buffer,
kmip_version=kmip_version
)
output_buffer.write(local_buffer.buffer)
def __repr__(self):
d = "query_functions={}".format(
"[{}]".format(
", ".join(["{}".format(x) for x in self.query_functions])
) if self.query_functions else None
)
return "QueryRequestPayload({})".format(d)
def __str__(self):
d = '"query_functions": {}'.format(
"[{}]".format(
", ".join(["{}".format(x) for x in self.query_functions])
) if self.query_functions else None
)
return "{" + d + "}"
def __eq__(self, other):
if isinstance(other, QueryRequestPayload):
if self.query_functions == other.query_functions:
return True
else:
return False
else:
return NotImplemented
def __ne__(self, other):
if isinstance(other, QueryRequestPayload):
return not (self == other)
else:
return NotImplemented
class QueryResponsePayload(primitives.Struct):
"""
A response payload for the Query operation.
The payload contains different sets of responses that the KMIP server
provides in response to the initial Query request.
Attributes:
operations: A list of Operations supported by the server.
object_types: A list of ObjectTypes supported by the server.
vendor_identification: A string identifying the server vendor.
server_information: A structure containing vendor-specific fields and
substructures.
application_namespaces: A list of application namespaces supported by
the server.
extension_information: A list of ExtensionInformation objects
detailing Objects supported by the server with ItemTag values in
the Extensions range. Added in KMIP 1.1.
attestation_types: A list of AttestationType enumerations detailing
the attestation methods supported by the server. Added in KMIP 1.2.
rng_parameters: A list of RNGParameters structures detailing the types
of random number generators supported by the server. Added in
KMIP 1.3.
profile_information: A list of ProfileInformation structures detailing
the different profiles supported by the server. Added in KMIP 1.3.
validation_information: A list of ValidationInformation structures
detailing the types of formal validation supported by the server.
Added in KMIP 1.3.
capability_information: A list of CapabilityInformation structures
detailing the different capabilities supported by the server.
Added in KMIP 1.3.
client_registration_methods: A list of ClientRegistrationMethod
enumerations detailing the different client registration methods
supported by the server. Added in KMIP 1.3.
defaults_information: A DefaultsInformation structure detailing the
default attribute values used by the server for new managed
objects. Added in KMIP 2.0.
protection__storage_mask: A list of integers representing combined sets
of ProtectionStorageMask enumerations detailing the storage
protections supported by the server. Added in KMIP 2.0.
"""
def __init__(self,
operations=None,
object_types=None,
vendor_identification=None,
server_information=None,
application_namespaces=None,
extension_information=None,
attestation_types=None,
rng_parameters=None,
profile_information=None,
validation_information=None,
capability_information=None,
client_registration_methods=None,
defaults_information=None,
protection_storage_masks=None):
"""
Construct a QueryResponsePayload object.
Args:
operations (list): A list of Operations supported by the server.
Optional, defaults to None.
object_types (list): A list of ObjectTypes supported by the
server. Optional, defaults to None.
vendor_identification (string): A string identifying the server
vendor. Optional, defaults to None.
server_information (structure): A ServerInformation structure
containing vendor-specific fields and substructures. Optional,
defaults to None.
application_namespaces (list): A list of application namespaces
supported by the server. Optional, defaults to None.
extension_information (list): A list of ExtensionInformation
objects detailing Objects supported by the server with ItemTag
values in the Extensions range. Optional, defaults to None.
Added in KMIP 1.1.
attestation_types (list): A list of AttestationType enumerations
detailing the attestation methods supported by the server.
Optional, defaults to None. Added in KMIP 1.2.
rng_parameters (list): A list of RNGParameters structures detailing
the types of random number generators supported by the server.
Optional, defaults to None. Added in KMIP 1.3.
profile_information (list): A list of ProfileInformation structures
detailing the different profiles supported by the server.
Optional, defaults to None. Added in KMIP 1.3.
validation_information (list): A list of ValidationInformation
structures detailing the types of formal validation supported
by the server. Optional, defaults to None. Added in KMIP 1.3.
capability_information (list): A list of CapabilityInformation
structures detailing the different capabilities supported by
the server. Optional, defaults to None. Added in KMIP 1.3.
client_registration_methods (list): A list of
ClientRegistrationMethod enumerations detailing the different
client registration methods supported by the server. Optional,
defaults to None. Added in KMIP 1.3.
defaults_information (structure): A DefaultsInformation structure
detailing the default attribute values used by the server for
new managed objects. Optional, defaults to None. Added in
KMIP 2.0.
protection__storage_masks (list): A list of integers representing
combined sets of ProtectionStorageMask enumerations detailing
the storage protections supported by the server. Optional,
defaults to None. Added in KMIP 2.0.
"""
super(QueryResponsePayload, self).__init__(
enums.Tags.RESPONSE_PAYLOAD
)
self._operations = None
self._object_types = None
self._vendor_identification = None
self._server_information = None
self._application_namespaces = None
self._extension_information = None
self._attestation_types = None
self._rng_parameters = None
self._profile_information = None
self._validation_information = None
self._capability_information = None
self._client_registration_methods = None
self._defaults_information = None
self._storage_protection_masks = None
self.operations = operations
self.object_types = object_types
self.vendor_identification = vendor_identification
self.server_information = server_information
self.application_namespaces = application_namespaces
self.extension_information = extension_information
self.attestation_types = attestation_types
self.rng_parameters = rng_parameters
self.profile_information = profile_information
self.validation_information = validation_information
self.capability_information = capability_information
self.client_registration_methods = client_registration_methods
self.defaults_information = defaults_information
self.protection_storage_masks = protection_storage_masks
@property
def operations(self):
if self._operations:
return [x.value for x in self._operations]
return None
@operations.setter
def operations(self, value):
if value is None:
self._operations = None
elif isinstance(value, list):
operations = []
for i in value:
if isinstance(i, enums.Operation):
operations.append(
primitives.Enumeration(
enums.Operation,
value=i,
tag=enums.Tags.OPERATION
)
)
else:
raise TypeError(
"The operations must be a list of Operation "
"enumerations."
)
self._operations = operations
else:
raise TypeError(
"The operations must be a list of Operation enumerations."
)
@property
def object_types(self):
if self._object_types:
return [x.value for x in self._object_types]
return None
@object_types.setter
def object_types(self, value):
if value is None:
self._object_types = None
elif isinstance(value, list):
object_types = []
for i in value:
if isinstance(i, enums.ObjectType):
object_types.append(
primitives.Enumeration(
enums.ObjectType,
value=i,
tag=enums.Tags.OBJECT_TYPE
)
)
else:
raise TypeError(
"The object types must be a list of ObjectType "
"enumerations."
)
self._object_types = object_types
else:
raise TypeError(
"The object types must be a list of ObjectType enumerations."
)
@property
def vendor_identification(self):
if self._vendor_identification:
return self._vendor_identification.value
return None
@vendor_identification.setter
def vendor_identification(self, value):
if value is None:
self._vendor_identification = None
elif isinstance(value, six.string_types):
self._vendor_identification = primitives.TextString(
value=value,
tag=enums.Tags.VENDOR_IDENTIFICATION
)
else:
raise TypeError("The vendor identification must be a string.")
@property
def server_information(self):
return self._server_information
@server_information.setter
def server_information(self, value):
if value is None:
self._server_information = None
elif isinstance(value, misc.ServerInformation):
self._server_information = value
else:
raise TypeError(
"The server information must be a ServerInformation structure."
)
@property
def application_namespaces(self):
if self._application_namespaces:
return [x.value for x in self._application_namespaces]
return None
@application_namespaces.setter
def application_namespaces(self, value):
if value is None:
self._application_namespaces = None
elif isinstance(value, list):
application_namespaces = []
for i in value:
if isinstance(i, six.string_types):
application_namespaces.append(
primitives.TextString(
value=i,
tag=enums.Tags.APPLICATION_NAMESPACE
)
)
else:
raise TypeError(
"The application namespaces must be a list of strings."
)
self._application_namespaces = application_namespaces
else:
raise TypeError(
"The application namespaces must be a list of strings."
)
@property
def extension_information(self):
if self._extension_information:
return [x for x in self._extension_information]
return None
@extension_information.setter
def extension_information(self, value):
if value is None:
self._extension_information = None
elif isinstance(value, list):
extension_information = []
for i in value:
if isinstance(i, objects.ExtensionInformation):
extension_information.append(i)
else:
raise TypeError(
"The extension information must be a list of "
"ExtensionInformation structures."
)
self._extension_information = extension_information
else:
raise TypeError(
"The extension information must be a list of "
"ExtensionInformation structures."
)
@property
def attestation_types(self):
if self._attestation_types:
return [x.value for x in self._attestation_types]
return None
@attestation_types.setter
def attestation_types(self, value):
if value is None:
self._attestation_types = None
elif isinstance(value, list):
attestation_types = []
for i in value:
if isinstance(i, enums.AttestationType):
attestation_types.append(
primitives.Enumeration(
enums.AttestationType,
value=i,
tag=enums.Tags.ATTESTATION_TYPE
)
)
else:
raise TypeError(
"The attestation types must be a list of "
"AttestationType enumerations."
)
self._attestation_types = attestation_types
else:
raise TypeError(
"The attestation types must be a list of AttestationType "
"enumerations."
)
@property
def rng_parameters(self):
return self._rng_parameters
@rng_parameters.setter
def rng_parameters(self, value):
if value is None:
self._rng_parameters = None
elif isinstance(value, list):
rng_parameters = []
for i in value:
if isinstance(i, objects.RNGParameters):
rng_parameters.append(i)
else:
raise TypeError(
"The RNG parameters must be a list of RNGParameters "
"structures."
)
self._rng_parameters = rng_parameters
else:
raise TypeError(
"The RNG parameters must be a list of RNGParameters "
"structures."
)
@property
def profile_information(self):
return self._profile_information
@profile_information.setter
def profile_information(self, value):
if value is None:
self._profile_information = None
elif isinstance(value, list):
profile_information = []
for i in value:
if isinstance(i, objects.ProfileInformation):
profile_information.append(i)
else:
raise TypeError(
"The profile information must be a list of "
"ProfileInformation structures."
)
self._profile_information = profile_information
else:
raise TypeError(
"The profile information must be a list of "
"ProfileInformation structures."
)
@property
def validation_information(self):
return self._validation_information
@validation_information.setter
def validation_information(self, value):
if value is None:
self._validation_information = None
elif isinstance(value, list):
validation_information = []
for i in value:
if isinstance(i, objects.ValidationInformation):
validation_information.append(i)
else:
raise TypeError(
"The validation information must be a list of "
"ValidationInformation structures."
)
self._validation_information = validation_information
else:
raise TypeError(
"The validation information must be a list of "
"ValidationInformation structures."
)
@property
def capability_information(self):
return self._capability_information
@capability_information.setter
def capability_information(self, value):
if value is None:
self._capability_information = None
elif isinstance(value, list):
capability_information = []
for i in value:
if isinstance(i, objects.CapabilityInformation):
capability_information.append(i)
else:
raise TypeError(
"The capability information must be a list of "
"CapabilityInformation structures."
)
self._capability_information = capability_information
else:
raise TypeError(
"The capability information must be a list of "
"CapabilityInformation structures."
)
@property
def client_registration_methods(self):
if self._client_registration_methods:
return [x.value for x in self._client_registration_methods]
return None
@client_registration_methods.setter
def client_registration_methods(self, value):
if value is None:
self._client_registration_methods = None
elif isinstance(value, list):
client_registration_methods = []
for i in value:
if isinstance(i, enums.ClientRegistrationMethod):
client_registration_methods.append(
primitives.Enumeration(
enums.ClientRegistrationMethod,
value=i,
tag=enums.Tags.CLIENT_REGISTRATION_METHOD
)
)
else:
raise TypeError(
"The client registration methods must be a list of "
"ClientRegistrationMethod enumerations."
)
self._client_registration_methods = client_registration_methods
else:
raise TypeError(
"The client registration methods must be a list of "
"ClientRegistrationMethod enumerations."
)
@property
def defaults_information(self):
return self._defaults_information
@defaults_information.setter
def defaults_information(self, value):
if value is None:
self._defaults_information = None
elif isinstance(value, objects.DefaultsInformation):
self._defaults_information = value
else:
raise TypeError(
"The defaults information must be a DefaultsInformation "
"structure."
)
@property
def protection_storage_masks(self):
if self._protection_storage_masks:
return [x.value for x in self._protection_storage_masks]
return None
@protection_storage_masks.setter
def protection_storage_masks(self, value):
if value is None:
self._protection_storage_masks = None
elif isinstance(value, list):
protection_storage_masks = []
for i in value:
if isinstance(i, six.integer_types):
protection_storage_masks.append(
primitives.Integer(
value=i,
tag=enums.Tags.PROTECTION_STORAGE_MASK
)
)
else:
raise TypeError(
"The protection storage masks must be a list of "
"integers."
)
self._protection_storage_masks = protection_storage_masks
else:
raise TypeError(
"The protection storage masks must be a list of integers."
)
def read(self, input_buffer, kmip_version=enums.KMIPVersion.KMIP_1_0):
"""
Read the data encoding the QueryResponsePayload object and decode it
into its constituent parts.
Args:
input_buffer (Stream): A data stream containing encoded object
data, supporting a read method; usually a BytearrayStream
object.
kmip_version (KMIPVersion): An enumeration defining the KMIP
version with which the object will be decoded. Optional,
defaults to KMIP 1.0.
"""
super(QueryResponsePayload, self).read(
input_buffer,
kmip_version=kmip_version
)
local_buffer = utils.BytearrayStream(input_buffer.read(self.length))
operations = []
while(self.is_tag_next(enums.Tags.OPERATION, local_buffer)):
operation = primitives.Enumeration(
enums.Operation,
tag=enums.Tags.OPERATION
)
operation.read(local_buffer, kmip_version=kmip_version)
operations.append(operation)
self._operations = operations
object_types = []
while(self.is_tag_next(enums.Tags.OBJECT_TYPE, local_buffer)):
object_type = primitives.Enumeration(
enums.ObjectType,
tag=enums.Tags.OBJECT_TYPE
)
object_type.read(local_buffer, kmip_version=kmip_version)
object_types.append(object_type)
self._object_types = object_types
if self.is_tag_next(enums.Tags.VENDOR_IDENTIFICATION, local_buffer):
vendor_identification = primitives.TextString(
tag=enums.Tags.VENDOR_IDENTIFICATION
)
vendor_identification.read(
local_buffer,
kmip_version=kmip_version
)
self._vendor_identification = vendor_identification
if self.is_tag_next(enums.Tags.SERVER_INFORMATION, local_buffer):
server_information = misc.ServerInformation()
server_information.read(
local_buffer,
kmip_version=kmip_version
)
self._server_information = server_information
application_namespaces = []
while(self.is_tag_next(
enums.Tags.APPLICATION_NAMESPACE,
local_buffer
)
):
application_namespace = primitives.TextString(
tag=enums.Tags.APPLICATION_NAMESPACE
)
application_namespace.read(local_buffer, kmip_version=kmip_version)
application_namespaces.append(application_namespace)
self._application_namespaces = application_namespaces
if kmip_version >= enums.KMIPVersion.KMIP_1_1:
extensions_information = []
while(self.is_tag_next(
enums.Tags.EXTENSION_INFORMATION,
local_buffer
)
):
extension_information = objects.ExtensionInformation()
extension_information.read(
local_buffer,
kmip_version=kmip_version
)
extensions_information.append(extension_information)
self._extension_information = extensions_information
if kmip_version >= enums.KMIPVersion.KMIP_1_2:
attestation_types = []
while(self.is_tag_next(enums.Tags.ATTESTATION_TYPE, local_buffer)):
attestation_type = primitives.Enumeration(
enums.AttestationType,
tag=enums.Tags.ATTESTATION_TYPE
)
attestation_type.read(local_buffer, kmip_version=kmip_version)
attestation_types.append(attestation_type)
self._attestation_types = attestation_types
if kmip_version >= enums.KMIPVersion.KMIP_1_3:
rngs_parameters = []
while(self.is_tag_next(enums.Tags.RNG_PARAMETERS, local_buffer)):
rng_parameters = objects.RNGParameters()
rng_parameters.read(local_buffer, kmip_version=kmip_version)
rngs_parameters.append(rng_parameters)
self._rng_parameters = rngs_parameters
profiles_information = []
while(self.is_tag_next(
enums.Tags.PROFILE_INFORMATION,
local_buffer
)
):
profile_information = objects.ProfileInformation()
profile_information.read(
local_buffer,
kmip_version=kmip_version
)
profiles_information.append(profile_information)
self._profile_information = profiles_information
validations_information = []
while(self.is_tag_next(
enums.Tags.VALIDATION_INFORMATION,
local_buffer
)
):
validation_information = objects.ValidationInformation()
validation_information.read(
local_buffer,
kmip_version=kmip_version
)
validations_information.append(validation_information)
self._validation_information = validations_information
capabilities_information = []
while(self.is_tag_next(
enums.Tags.CAPABILITY_INFORMATION,
local_buffer
)
):
capability_information = objects.CapabilityInformation()
capability_information.read(
local_buffer,
kmip_version=kmip_version
)
capabilities_information.append(capability_information)
self._capability_information = capabilities_information
client_registration_methods = []
while(self.is_tag_next(
enums.Tags.CLIENT_REGISTRATION_METHOD,
local_buffer
)
):
client_registration_method = primitives.Enumeration(
enums.ClientRegistrationMethod,
tag=enums.Tags.CLIENT_REGISTRATION_METHOD
)
client_registration_method.read(
local_buffer,
kmip_version=kmip_version
)
client_registration_methods.append(client_registration_method)
self._client_registration_methods = client_registration_methods
if kmip_version >= enums.KMIPVersion.KMIP_2_0:
if self.is_tag_next(enums.Tags.DEFAULTS_INFORMATION, local_buffer):
defaults_information = objects.DefaultsInformation()
defaults_information.read(
local_buffer,
kmip_version=kmip_version
)
self._defaults_information = defaults_information
protection_storage_masks = []
while(self.is_tag_next(
enums.Tags.PROTECTION_STORAGE_MASK,
local_buffer
)
):
protection_storage_mask = primitives.Integer(
tag=enums.Tags.PROTECTION_STORAGE_MASK
)
protection_storage_mask.read(
local_buffer,
kmip_version=kmip_version
)
protection_storage_masks.append(protection_storage_mask)
self._protection_storage_masks = protection_storage_masks
self.is_oversized(local_buffer)
def write(self, output_buffer, kmip_version=enums.KMIPVersion.KMIP_1_0):
"""
Write the data encoding the QueryResponsePayload object to a stream.
Args:
output_buffer (Stream): A data stream in which to encode object
data, supporting a write method; usually a BytearrayStream
object.
kmip_version (KMIPVersion): An enumeration defining the KMIP
version with which the object will be encoded. Optional,
defaults to KMIP 1.0.
"""
local_buffer = utils.BytearrayStream()
if self._operations:
for operation in self._operations:
operation.write(local_buffer, kmip_version=kmip_version)
if self._object_types:
for object_type in self._object_types:
object_type.write(local_buffer, kmip_version=kmip_version)
if self._vendor_identification:
self._vendor_identification.write(
local_buffer,
kmip_version=kmip_version
)
if self._server_information:
self._server_information.write(
local_buffer,
kmip_version=kmip_version
)
if self._application_namespaces:
for application_namespace in self._application_namespaces:
application_namespace.write(
local_buffer,
kmip_version=kmip_version
)
if kmip_version >= enums.KMIPVersion.KMIP_1_1:
if self._extension_information:
for extension_information in self._extension_information:
extension_information.write(
local_buffer,
kmip_version=kmip_version
)
if kmip_version >= enums.KMIPVersion.KMIP_1_2:
if self._attestation_types:
for attestation_type in self._attestation_types:
attestation_type.write(
local_buffer,
kmip_version=kmip_version
)
if kmip_version >= enums.KMIPVersion.KMIP_1_3:
if self._rng_parameters:
for rng_parameters in self._rng_parameters:
rng_parameters.write(
local_buffer,
kmip_version=kmip_version
)
if self._profile_information:
for profile_information in self._profile_information:
profile_information.write(
local_buffer,
kmip_version=kmip_version
)
if self._validation_information:
for validation_information in self._validation_information:
validation_information.write(
local_buffer,
kmip_version=kmip_version
)
if self._capability_information:
for capability_information in self._capability_information:
capability_information.write(
local_buffer,
kmip_version=kmip_version
)
if self._client_registration_methods:
for client_reg_method in self._client_registration_methods:
client_reg_method.write(
local_buffer,
kmip_version=kmip_version
)
if kmip_version >= enums.KMIPVersion.KMIP_2_0:
if self._defaults_information:
self._defaults_information.write(
local_buffer,
kmip_version=kmip_version
)
if self._protection_storage_masks:
for protection_storage_mask in self._protection_storage_masks:
protection_storage_mask.write(
local_buffer,
kmip_version=kmip_version
)
self.length = local_buffer.length()
super(QueryResponsePayload, self).write(
output_buffer,
kmip_version=kmip_version
)
output_buffer.write(local_buffer.buffer)
def __repr__(self):
o = "operations={}".format(
"[{}]".format(
", ".join([str(x) for x in self.operations])
) if self.operations else None
)
ot = "object_types={}".format(
"[{}]".format(
", ".join([str(x) for x in self.object_types])
) if self.object_types else None
)
vi = 'vendor_identification="{}"'.format(self.vendor_identification)
si = "server_information={}".format(repr(self.server_information))
an = "application_namespaces={}".format(
"[{}]".format(
", ".join(
['"{}"'.format(x) for x in self.application_namespaces]
)
) if self.application_namespaces else None
)
ei = "extension_information={}".format(
"[{}]".format(
", ".join([repr(x) for x in self.extension_information])
) if self.extension_information else None
)
at = "attestation_types={}".format(
"[{}]".format(
", ".join([str(x) for x in self.attestation_types])
) if self.attestation_types else None
)
rp = "rng_parameters={}".format(
"[{}]".format(
", ".join([repr(x) for x in self.rng_parameters])
) if self.rng_parameters else None
)
pi = "profile_information={}".format(
"[{}]".format(
", ".join([repr(x) for x in self.profile_information])
) if self.profile_information else None
)
vai = "validation_information={}".format(
"[{}]".format(
", ".join([repr(x) for x in self.validation_information])
) if self.validation_information else None
)
ci = "capability_information={}".format(
"[{}]".format(
", ".join([repr(x) for x in self.capability_information])
) if self.capability_information else None
)
crm = "client_registration_methods={}".format(
"[{}]".format(
", ".join([str(x) for x in self.client_registration_methods])
) if self.client_registration_methods else None
)
di = "defaults_information={}".format(
"{}".format(
repr(self._defaults_information)
) if self._defaults_information else None
)
spm = "protection_storage_masks={}".format(
"[{}]".format(
", ".join([str(x) for x in self.protection_storage_masks])
) if self._protection_storage_masks else None
)
v = ", ".join(
[o, ot, vi, si, an, ei, at, rp, pi, vai, ci, crm, di, spm]
)
return "QueryResponsePayload({})".format(v)
def __str__(self):
o = '"operations": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.operations])
) if self.operations else None
)
ot = '"object_types": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.object_types])
) if self.object_types else None
)
vi = '"vendor_identification": "{}"'.format(self.vendor_identification)
si = '"server_information": {}'.format(repr(self.server_information))
an = '"application_namespaces": {}'.format(
"[{}]".format(
", ".join(
['"{}"'.format(x) for x in self.application_namespaces]
)
) if self.application_namespaces else None
)
ei = '"extension_information": {}'.format(
"[{}]".format(
", ".join([repr(x) for x in self.extension_information])
) if self.extension_information else None
)
at = '"attestation_types": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.attestation_types])
) if self.attestation_types else None
)
rp = '"rng_parameters": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.rng_parameters])
) if self.rng_parameters else None
)
pi = '"profile_information": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.profile_information])
) if self.profile_information else None
)
vai = '"validation_information": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.validation_information])
) if self.validation_information else None
)
ci = '"capability_information": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.capability_information])
) if self.capability_information else None
)
crm = '"client_registration_methods": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.client_registration_methods])
) if self.client_registration_methods else None
)
di = '"defaults_information": {}'.format(
"{}".format(
str(self.defaults_information)
) if self._defaults_information else None
)
spm = '"protection_storage_masks": {}'.format(
"[{}]".format(
", ".join([str(x) for x in self.protection_storage_masks])
) if self._protection_storage_masks else None
)
v = ", ".join(
[o, ot, vi, si, an, ei, at, rp, pi, vai, ci, crm, di, spm]
)
return '{' + v + '}'
def __eq__(self, other):
if isinstance(other, QueryResponsePayload):
if self.operations != other.operations:
return False
elif self.object_types != other.object_types:
return False
elif self.vendor_identification != other.vendor_identification:
return False
elif self.server_information != other.server_information:
return False
elif self.application_namespaces != other.application_namespaces:
return False
elif self.extension_information != other.extension_information:
return False
elif self.attestation_types != other.attestation_types:
return False
elif self.rng_parameters != other.rng_parameters:
return False
elif self.profile_information != other.profile_information:
return False
elif self.validation_information != other.validation_information:
return False
elif self.capability_information != other.capability_information:
return False
elif self.client_registration_methods != \
other.client_registration_methods:
return False
elif self.defaults_information != other.defaults_information:
return False
elif self.protection_storage_masks != \
other.protection_storage_masks:
return False
else:
return True
else:
return NotImplemented
def __ne__(self, other):
if isinstance(other, QueryResponsePayload):
return not (self == other)
else:
return NotImplemented