Source code for stream_manager.data

from reprlib import repr as limitedRepr


import enum
from typing import List


[docs]class VersionInfo(enum.Enum): """ (Internal Only) Version information. """ PROTOCOL_VERSION = "1.1.0"
[docs] @staticmethod def from_dict(d): return VersionInfo(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum VersionInfo. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class ConnectRequest: """ (Internal Only) Request object to connect to the service. """ __slots__ = [ "__request_id", "__protocol_version", "__other_supported_protocol_versions", "__sdk_version", "__auth_token", ] _types_map = { "request_id": {"type": str, "subtype": None}, "protocol_version": {"type": str, "subtype": None}, "other_supported_protocol_versions": {"type": list, "subtype": str}, "sdk_version": {"type": str, "subtype": None}, "auth_token": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "protocol_version": { "required": True, }, "other_supported_protocol_versions": { "required": False, }, "sdk_version": { "required": False, }, "auth_token": { "required": False, }, } def __init__( self, request_id: str = None, protocol_version: str = None, other_supported_protocol_versions: List[str] = None, sdk_version: str = None, auth_token: str = None, ): pass self.__request_id = request_id self.__protocol_version = protocol_version self.__other_supported_protocol_versions = other_supported_protocol_versions self.__sdk_version = sdk_version self.__auth_token = auth_token def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_protocol_version(self): return self.__protocol_version def _set_protocol_version(self, value): if not isinstance(value, str): raise TypeError("protocol_version must be str") self.__protocol_version = value protocol_version = property(_get_protocol_version, _set_protocol_version) def _get_other_supported_protocol_versions(self): return self.__other_supported_protocol_versions def _set_other_supported_protocol_versions(self, value): if value is not None and not isinstance(value, list): raise TypeError("other_supported_protocol_versions must be list") if value is not None and not all(isinstance(i, str) for i in value): raise TypeError("other_supported_protocol_versions list values must be str") self.__other_supported_protocol_versions = value other_supported_protocol_versions = property( _get_other_supported_protocol_versions, _set_other_supported_protocol_versions ) def _get_sdk_version(self): return self.__sdk_version def _set_sdk_version(self, value): if value is not None and not isinstance(value, str): raise TypeError("sdk_version must be str") self.__sdk_version = value sdk_version = property(_get_sdk_version, _set_sdk_version) def _get_auth_token(self): return self.__auth_token def _set_auth_token(self, value): if value is not None and not isinstance(value, str): raise TypeError("auth_token must be str") self.__auth_token = value auth_token = property(_get_auth_token, _set_auth_token)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "protocolVersion" in d: v["protocol_version"] = ( str.from_dict(d["protocolVersion"]) if hasattr(str, "from_dict") else d["protocolVersion"] ) if "otherSupportedProtocolVersions" in d: v["other_supported_protocol_versions"] = [ str.from_dict(p) if hasattr(str, "from_dict") else p for p in d["otherSupportedProtocolVersions"] ] if "sdkVersion" in d: v["sdk_version"] = ( str.from_dict(d["sdkVersion"]) if hasattr(str, "from_dict") else d["sdkVersion"] ) if "authToken" in d: v["auth_token"] = ( str.from_dict(d["authToken"]) if hasattr(str, "from_dict") else d["authToken"] ) return ConnectRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__protocol_version is not None: d["protocolVersion"] = ( self.__protocol_version.as_dict() if hasattr(self.__protocol_version, "as_dict") else self.__protocol_version ) if self.__other_supported_protocol_versions is not None: d["otherSupportedProtocolVersions"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__other_supported_protocol_versions ] if self.__sdk_version is not None: d["sdkVersion"] = ( self.__sdk_version.as_dict() if hasattr(self.__sdk_version, "as_dict") else self.__sdk_version ) if self.__auth_token is not None: d["authToken"] = ( self.__auth_token.as_dict() if hasattr(self.__auth_token, "as_dict") else self.__auth_token ) return d
def __repr__(self): return "<Class ConnectRequest. request_id: {}, protocol_version: {}, other_supported_protocol_versions: {}, sdk_version: {}, auth_token: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__protocol_version[:20] if isinstance(self.__protocol_version, bytes) else self.__protocol_version ), limitedRepr( self.__other_supported_protocol_versions[:20] if isinstance(self.__other_supported_protocol_versions, bytes) else self.__other_supported_protocol_versions ), limitedRepr( self.__sdk_version[:20] if isinstance(self.__sdk_version, bytes) else self.__sdk_version ), limitedRepr( self.__auth_token[:20] if isinstance(self.__auth_token, bytes) else self.__auth_token ), )
[docs]class ResponseStatusCode(enum.Enum): """ (Internal Only) Enum defining possible response status codes from StreamManager server. Success: Request succeeded. UnknownFailure: Encountered unknown StreamManager server failure. Unauthorized: Client is not authorized to perform this request. InvalidRequest: Client request is invalid. RequestPayloadTooLarge: Request payload is too large. ResourceNotFound: The requested resource does not exist. ServerTimeout: Server took too long and timed out. ResponsePayloadTooLarge: Server response exceeded the max allowed response payload size by the protocol. UnsupportedConnectVersion: Server does not support the Connect version presented by the Client. UnexpectedOperation: Operation presented was not expected by the Server. UnsupportedProtocolVersion: Protocol version presented by the Client is not compatible with the Server. InvalidProtocolVersion: Protocol version presented by the Client is not valid. FailedToConnect: Client failed to connect to the Server. NotEnoughMessages: There is not enough messages to return. MessageStoreReadError: Read messages encountered an error. OutOfMemoryError: Server ran out of memory. UpdateFailed: Update operation failed. UpdateNotAllowed: One or more fields are not allowed to be updated. UnknownOperation: Client request is not recognized by the server. """ Success = 0 UnknownFailure = 1 Unauthorized = 2 InvalidRequest = 3 RequestPayloadTooLarge = 4 ResourceNotFound = 5 ServerTimeout = 6 ResponsePayloadTooLarge = 7 UnsupportedConnectVersion = 8 UnexpectedOperation = 9 UnsupportedProtocolVersion = 10 InvalidProtocolVersion = 11 FailedToConnect = 12 NotEnoughMessages = 13 MessageStoreReadError = 14 OutOfMemoryError = 15 UpdateFailed = 16 UpdateNotAllowed = 17 UnknownOperation = 18
[docs] @staticmethod def from_dict(d): return ResponseStatusCode(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum ResponseStatusCode. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class ConnectResponse: """ Internal Only. """ __slots__ = [ "__request_id", "__status", "__error_message", "__protocol_version", "__supported_protocol_versions", "__server_version", "__client_identifier", ] _types_map = { "request_id": {"type": str, "subtype": None}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, "protocol_version": {"type": str, "subtype": None}, "supported_protocol_versions": {"type": list, "subtype": str}, "server_version": {"type": str, "subtype": None}, "client_identifier": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": False, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "status": { "required": True, }, "error_message": { "required": False, }, "protocol_version": { "required": False, }, "supported_protocol_versions": { "required": False, }, "server_version": { "required": False, }, "client_identifier": { "required": False, }, } def __init__( self, request_id: str = None, status: ResponseStatusCode = None, error_message: str = None, protocol_version: str = None, supported_protocol_versions: List[str] = None, server_version: str = None, client_identifier: str = None, ): pass self.__request_id = request_id self.__status = status self.__error_message = error_message self.__protocol_version = protocol_version self.__supported_protocol_versions = supported_protocol_versions self.__server_version = server_version self.__client_identifier = client_identifier def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if value is not None and not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message) def _get_protocol_version(self): return self.__protocol_version def _set_protocol_version(self, value): if value is not None and not isinstance(value, str): raise TypeError("protocol_version must be str") self.__protocol_version = value protocol_version = property(_get_protocol_version, _set_protocol_version) def _get_supported_protocol_versions(self): return self.__supported_protocol_versions def _set_supported_protocol_versions(self, value): if value is not None and not isinstance(value, list): raise TypeError("supported_protocol_versions must be list") if value is not None and not all(isinstance(i, str) for i in value): raise TypeError("supported_protocol_versions list values must be str") self.__supported_protocol_versions = value supported_protocol_versions = property( _get_supported_protocol_versions, _set_supported_protocol_versions ) def _get_server_version(self): return self.__server_version def _set_server_version(self, value): if value is not None and not isinstance(value, str): raise TypeError("server_version must be str") self.__server_version = value server_version = property(_get_server_version, _set_server_version) def _get_client_identifier(self): return self.__client_identifier def _set_client_identifier(self, value): if value is not None and not isinstance(value, str): raise TypeError("client_identifier must be str") self.__client_identifier = value client_identifier = property(_get_client_identifier, _set_client_identifier)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) if "protocolVersion" in d: v["protocol_version"] = ( str.from_dict(d["protocolVersion"]) if hasattr(str, "from_dict") else d["protocolVersion"] ) if "supportedProtocolVersions" in d: v["supported_protocol_versions"] = [ str.from_dict(p) if hasattr(str, "from_dict") else p for p in d["supportedProtocolVersions"] ] if "serverVersion" in d: v["server_version"] = ( str.from_dict(d["serverVersion"]) if hasattr(str, "from_dict") else d["serverVersion"] ) if "clientIdentifier" in d: v["client_identifier"] = ( str.from_dict(d["clientIdentifier"]) if hasattr(str, "from_dict") else d["clientIdentifier"] ) return ConnectResponse(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) if self.__protocol_version is not None: d["protocolVersion"] = ( self.__protocol_version.as_dict() if hasattr(self.__protocol_version, "as_dict") else self.__protocol_version ) if self.__supported_protocol_versions is not None: d["supportedProtocolVersions"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__supported_protocol_versions ] if self.__server_version is not None: d["serverVersion"] = ( self.__server_version.as_dict() if hasattr(self.__server_version, "as_dict") else self.__server_version ) if self.__client_identifier is not None: d["clientIdentifier"] = ( self.__client_identifier.as_dict() if hasattr(self.__client_identifier, "as_dict") else self.__client_identifier ) return d
def __repr__(self): return "<Class ConnectResponse. request_id: {}, status: {}, error_message: {}, protocol_version: {}, supported_protocol_versions: {}, server_version: {}, client_identifier: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), limitedRepr( self.__protocol_version[:20] if isinstance(self.__protocol_version, bytes) else self.__protocol_version ), limitedRepr( self.__supported_protocol_versions[:20] if isinstance(self.__supported_protocol_versions, bytes) else self.__supported_protocol_versions ), limitedRepr( self.__server_version[:20] if isinstance(self.__server_version, bytes) else self.__server_version ), limitedRepr( self.__client_identifier[:20] if isinstance(self.__client_identifier, bytes) else self.__client_identifier ), )
[docs]class Operation(enum.Enum): """ Internal Only. """ Unknown = 0 Connect = 1 CreateMessageStream = 2 DeleteMessageStream = 3 AppendMessage = 4 ReadMessages = 5 ConnectResponse = 6 CreateMessageStreamResponse = 7 DeleteMessageStreamResponse = 8 AppendMessageResponse = 9 ReadMessagesResponse = 10 ListStreams = 11 ListStreamsResponse = 12 DescribeMessageStream = 13 DescribeMessageStreamResponse = 14 UpdateMessageStream = 15 UpdateMessageStreamResponse = 16 UnknownOperationError = 17
[docs] @staticmethod def from_dict(d): return Operation(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum Operation. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class MessageFrame: """ Internal Only. """ __slots__ = [ "__operation", "__payload", ] _types_map = { "operation": {"type": Operation, "subtype": None}, "payload": {"type": bytes, "subtype": None}, } _formats_map = {} _validations_map = { "operation": { "required": True, }, "payload": { "required": True, }, } def __init__(self, operation: Operation = None, payload: bytes = None): pass self.__operation = operation self.__payload = payload def _get_operation(self): return self.__operation def _set_operation(self, value): if not isinstance(value, Operation): raise TypeError("operation must be Operation") self.__operation = value operation = property(_get_operation, _set_operation) def _get_payload(self): return self.__payload def _set_payload(self, value): if not isinstance(value, bytes): raise TypeError("payload must be bytes") self.__payload = value payload = property(_get_payload, _set_payload)
[docs] @staticmethod def from_dict(d): v = {} if "operation" in d: v["operation"] = ( Operation.from_dict(d["operation"]) if hasattr(Operation, "from_dict") else d["operation"] ) if "payload" in d: v["payload"] = ( bytes.from_dict(d["payload"]) if hasattr(bytes, "from_dict") else d["payload"] ) return MessageFrame(**v)
[docs] def as_dict(self): d = {} if self.__operation is not None: d["operation"] = ( self.__operation.as_dict() if hasattr(self.__operation, "as_dict") else self.__operation ) if self.__payload is not None: d["payload"] = ( self.__payload.as_dict() if hasattr(self.__payload, "as_dict") else self.__payload ) return d
def __repr__(self): return "<Class MessageFrame. operation: {}, payload: {}>".format( limitedRepr( self.__operation[:20] if isinstance(self.__operation, bytes) else self.__operation ), limitedRepr( self.__payload[:20] if isinstance(self.__payload, bytes) else self.__payload ), )
[docs]class S3ExportTaskDefinition: """ S3 Task definition containing all the information necessary to export the data to S3. This will contain the S3 bucket and key as well as the file's URL where the data is stored. """ __slots__ = [ "__input_url", "__bucket", "__key", "__user_metadata", ] _types_map = { "input_url": {"type": str, "subtype": None}, "bucket": {"type": str, "subtype": None}, "key": {"type": str, "subtype": None}, "user_metadata": {"type": dict, "subtype": None}, } _formats_map = {} _validations_map = { "input_url": { "required": True, }, "bucket": { "required": True, "minLength": 3, "maxLength": 63, "pattern": "(?=^.{3,63}$)(?!^(\d+\.)+\d+$)(^(([a-z0-9]|[a-z0-9][a-z0-9\-]*[a-z0-9])\.)*([a-z0-9]|[a-z0-9][a-z0-9\-]*[a-z0-9])$)", }, "key": { "required": True, "minLength": 1, "maxLength": 1024, "pattern": "^([^\\\{ \}%\`\[\]\"'\>\<\~\#\^\?\|]|!\{[a-zA-Z]+:[a-zA-Z\/]+\})*$", }, "user_metadata": { "required": False, }, } def __init__( self, input_url: str = None, bucket: str = None, key: str = None, user_metadata: dict = None, ): """ :param input_url: The URL of the file that contains the data to upload. The file should be local on the disk. :param bucket: The name of the S3 bucket that this file should be uploaded to. :param key: The key for the S3 object that this file should be uploaded to. The string can have placeholder expressions which are resolved at upload time. Valid expressions are strings that are valid Java DateTimeFormatter strings. See https://docs.oracle.com/javase/8/docs/api/java/time/format/DateTimeFormatter.html Example: myKeyNamePrefix/!{timestamp:yyyy/MM/dd}/myKeyNameSuffix. :param user_metadata: User metadata. For key of a user metadata, callers should not include the internal "x-amz-meta-" prefix. Keys are case insensitive and will appear as lowercase strings on S3, even if they were originally specified with uppercase strings. Reserved key names start with "$aws-gg-" prefix. """ pass self.__input_url = input_url self.__bucket = bucket self.__key = key self.__user_metadata = user_metadata def _get_input_url(self): return self.__input_url def _set_input_url(self, value): if not isinstance(value, str): raise TypeError("input_url must be str") self.__input_url = value input_url = property(_get_input_url, _set_input_url) """ The URL of the file that contains the data to upload. The file should be local on the disk. """ def _get_bucket(self): return self.__bucket def _set_bucket(self, value): if not isinstance(value, str): raise TypeError("bucket must be str") self.__bucket = value bucket = property(_get_bucket, _set_bucket) """ The name of the S3 bucket that this file should be uploaded to. """ def _get_key(self): return self.__key def _set_key(self, value): if not isinstance(value, str): raise TypeError("key must be str") self.__key = value key = property(_get_key, _set_key) """ The key for the S3 object that this file should be uploaded to. The string can have placeholder expressions which are resolved at upload time. Valid expressions are strings that are valid Java DateTimeFormatter strings. See https://docs.oracle.com/javase/8/docs/api/java/time/format/DateTimeFormatter.html Example: myKeyNamePrefix/!{timestamp:yyyy/MM/dd}/myKeyNameSuffix. """ def _get_user_metadata(self): return self.__user_metadata def _set_user_metadata(self, value): if value is not None and not isinstance(value, dict): raise TypeError("user_metadata must be dict") self.__user_metadata = value user_metadata = property(_get_user_metadata, _set_user_metadata) """ User metadata. For key of a user metadata, callers should not include the internal "x-amz-meta-" prefix. Keys are case insensitive and will appear as lowercase strings on S3, even if they were originally specified with uppercase strings. Reserved key names start with "$aws-gg-" prefix. """
[docs] @staticmethod def from_dict(d): v = {} if "inputUrl" in d: v["input_url"] = ( str.from_dict(d["inputUrl"]) if hasattr(str, "from_dict") else d["inputUrl"] ) if "bucket" in d: v["bucket"] = ( str.from_dict(d["bucket"]) if hasattr(str, "from_dict") else d["bucket"] ) if "key" in d: v["key"] = ( str.from_dict(d["key"]) if hasattr(str, "from_dict") else d["key"] ) if "userMetadata" in d: v["user_metadata"] = ( dict.from_dict(d["userMetadata"]) if hasattr(dict, "from_dict") else d["userMetadata"] ) return S3ExportTaskDefinition(**v)
[docs] def as_dict(self): d = {} if self.__input_url is not None: d["inputUrl"] = ( self.__input_url.as_dict() if hasattr(self.__input_url, "as_dict") else self.__input_url ) if self.__bucket is not None: d["bucket"] = ( self.__bucket.as_dict() if hasattr(self.__bucket, "as_dict") else self.__bucket ) if self.__key is not None: d["key"] = ( self.__key.as_dict() if hasattr(self.__key, "as_dict") else self.__key ) if self.__user_metadata is not None: d["userMetadata"] = ( self.__user_metadata.as_dict() if hasattr(self.__user_metadata, "as_dict") else self.__user_metadata ) return d
def __repr__(self): return "<Class S3ExportTaskDefinition. input_url: {}, bucket: {}, key: {}, user_metadata: {}>".format( limitedRepr( self.__input_url[:20] if isinstance(self.__input_url, bytes) else self.__input_url ), limitedRepr( self.__bucket[:20] if isinstance(self.__bucket, bytes) else self.__bucket ), limitedRepr( self.__key[:20] if isinstance(self.__key, bytes) else self.__key ), limitedRepr( self.__user_metadata[:20] if isinstance(self.__user_metadata, bytes) else self.__user_metadata ), )
[docs]class StatusContext: """ Context associated with a status message. Describes which stream, export config, message, the status is associated with. """ __slots__ = [ "__s3_export_task_definition", "__export_identifier", "__stream_name", "__sequence_number", ] _types_map = { "s3_export_task_definition": {"type": S3ExportTaskDefinition, "subtype": None}, "export_identifier": {"type": str, "subtype": None}, "stream_name": {"type": str, "subtype": None}, "sequence_number": {"type": int, "subtype": None}, } _formats_map = {} _validations_map = { "s3_export_task_definition": { "required": False, }, "export_identifier": { "required": False, }, "stream_name": { "required": False, }, "sequence_number": { "required": False, }, } def __init__( self, s3_export_task_definition: S3ExportTaskDefinition = None, export_identifier: str = None, stream_name: str = None, sequence_number: int = None, ): """ :param s3_export_task_definition: The task definition of an S3 upload task if the status is associated with it, ie, if the eventType = S3Task. :param export_identifier: The export identifier the status is associated with. :param stream_name: The name of the stream the status is associated with. :param sequence_number: The sequence number of the message the status is associated with. """ pass self.__s3_export_task_definition = s3_export_task_definition self.__export_identifier = export_identifier self.__stream_name = stream_name self.__sequence_number = sequence_number def _get_s3_export_task_definition(self): return self.__s3_export_task_definition def _set_s3_export_task_definition(self, value): if value is not None and not isinstance(value, S3ExportTaskDefinition): raise TypeError("s3_export_task_definition must be S3ExportTaskDefinition") self.__s3_export_task_definition = value s3_export_task_definition = property( _get_s3_export_task_definition, _set_s3_export_task_definition ) """ The task definition of an S3 upload task if the status is associated with it, ie, if the eventType = S3Task. """ def _get_export_identifier(self): return self.__export_identifier def _set_export_identifier(self, value): if value is not None and not isinstance(value, str): raise TypeError("export_identifier must be str") self.__export_identifier = value export_identifier = property(_get_export_identifier, _set_export_identifier) """ The export identifier the status is associated with. """ def _get_stream_name(self): return self.__stream_name def _set_stream_name(self, value): if value is not None and not isinstance(value, str): raise TypeError("stream_name must be str") self.__stream_name = value stream_name = property(_get_stream_name, _set_stream_name) """ The name of the stream the status is associated with. """ def _get_sequence_number(self): return self.__sequence_number def _set_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("sequence_number must be int") self.__sequence_number = value sequence_number = property(_get_sequence_number, _set_sequence_number) """ The sequence number of the message the status is associated with. """
[docs] @staticmethod def from_dict(d): v = {} if "s3ExportTaskDefinition" in d: v["s3_export_task_definition"] = ( S3ExportTaskDefinition.from_dict(d["s3ExportTaskDefinition"]) if hasattr(S3ExportTaskDefinition, "from_dict") else d["s3ExportTaskDefinition"] ) if "exportIdentifier" in d: v["export_identifier"] = ( str.from_dict(d["exportIdentifier"]) if hasattr(str, "from_dict") else d["exportIdentifier"] ) if "streamName" in d: v["stream_name"] = ( str.from_dict(d["streamName"]) if hasattr(str, "from_dict") else d["streamName"] ) if "sequenceNumber" in d: v["sequence_number"] = ( int.from_dict(d["sequenceNumber"]) if hasattr(int, "from_dict") else d["sequenceNumber"] ) return StatusContext(**v)
[docs] def as_dict(self): d = {} if self.__s3_export_task_definition is not None: d["s3ExportTaskDefinition"] = ( self.__s3_export_task_definition.as_dict() if hasattr(self.__s3_export_task_definition, "as_dict") else self.__s3_export_task_definition ) if self.__export_identifier is not None: d["exportIdentifier"] = ( self.__export_identifier.as_dict() if hasattr(self.__export_identifier, "as_dict") else self.__export_identifier ) if self.__stream_name is not None: d["streamName"] = ( self.__stream_name.as_dict() if hasattr(self.__stream_name, "as_dict") else self.__stream_name ) if self.__sequence_number is not None: d["sequenceNumber"] = ( self.__sequence_number.as_dict() if hasattr(self.__sequence_number, "as_dict") else self.__sequence_number ) return d
def __repr__(self): return "<Class StatusContext. s3_export_task_definition: {}, export_identifier: {}, stream_name: {}, sequence_number: {}>".format( limitedRepr( self.__s3_export_task_definition[:20] if isinstance(self.__s3_export_task_definition, bytes) else self.__s3_export_task_definition ), limitedRepr( self.__export_identifier[:20] if isinstance(self.__export_identifier, bytes) else self.__export_identifier ), limitedRepr( self.__stream_name[:20] if isinstance(self.__stream_name, bytes) else self.__stream_name ), limitedRepr( self.__sequence_number[:20] if isinstance(self.__sequence_number, bytes) else self.__sequence_number ), )
[docs]class Status(enum.Enum): """ The status of the event. """ Success = 0 Failure = 1 InProgress = 2 Warning = 3 Canceled = 4
[docs] @staticmethod def from_dict(d): return Status(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum Status. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class EventType(enum.Enum): """ The type of event, which determines how to interpret the status payload. """ S3Task = 0
[docs] @staticmethod def from_dict(d): return EventType(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum EventType. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class StatusLevel(enum.Enum): """ Defines the verbosity of status messages in a status-stream. """ ERROR = 0 WARN = 1 INFO = 2 DEBUG = 3 TRACE = 4
[docs] @staticmethod def from_dict(d): return StatusLevel(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum StatusLevel. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class StatusMessage: """ Status object appended to a status-stream. """ __slots__ = [ "__event_type", "__status_level", "__status", "__status_context", "__message", "__timestamp_epoch_ms", ] _types_map = { "event_type": {"type": EventType, "subtype": None}, "status_level": {"type": StatusLevel, "subtype": None}, "status": {"type": Status, "subtype": None}, "status_context": {"type": StatusContext, "subtype": None}, "message": {"type": str, "subtype": None}, "timestamp_epoch_ms": {"type": int, "subtype": None}, } _formats_map = {} _validations_map = { "event_type": { "required": True, }, "status_level": { "required": False, }, "status": { "required": True, }, "status_context": { "required": False, }, "message": { "required": False, }, "timestamp_epoch_ms": { "required": False, }, } def __init__( self, event_type: EventType = None, status_level: StatusLevel = None, status: Status = None, status_context: StatusContext = None, message: str = None, timestamp_epoch_ms: int = None, ): """ :param message: String describing the status message. :param timestamp_epoch_ms: The time this status was added to the status-stream (in milliseconds since epoch). """ pass self.__event_type = event_type self.__status_level = status_level self.__status = status self.__status_context = status_context self.__message = message self.__timestamp_epoch_ms = timestamp_epoch_ms def _get_event_type(self): return self.__event_type def _set_event_type(self, value): if not isinstance(value, EventType): raise TypeError("event_type must be EventType") self.__event_type = value event_type = property(_get_event_type, _set_event_type) def _get_status_level(self): return self.__status_level def _set_status_level(self, value): if value is not None and not isinstance(value, StatusLevel): raise TypeError("status_level must be StatusLevel") self.__status_level = value status_level = property(_get_status_level, _set_status_level) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, Status): raise TypeError("status must be Status") self.__status = value status = property(_get_status, _set_status) def _get_status_context(self): return self.__status_context def _set_status_context(self, value): if value is not None and not isinstance(value, StatusContext): raise TypeError("status_context must be StatusContext") self.__status_context = value status_context = property(_get_status_context, _set_status_context) def _get_message(self): return self.__message def _set_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("message must be str") self.__message = value message = property(_get_message, _set_message) """ String describing the status message. """ def _get_timestamp_epoch_ms(self): return self.__timestamp_epoch_ms def _set_timestamp_epoch_ms(self, value): if value is not None and not isinstance(value, int): raise TypeError("timestamp_epoch_ms must be int") self.__timestamp_epoch_ms = value timestamp_epoch_ms = property(_get_timestamp_epoch_ms, _set_timestamp_epoch_ms) """ The time this status was added to the status-stream (in milliseconds since epoch). """
[docs] @staticmethod def from_dict(d): v = {} if "eventType" in d: v["event_type"] = ( EventType.from_dict(d["eventType"]) if hasattr(EventType, "from_dict") else d["eventType"] ) if "statusLevel" in d: v["status_level"] = ( StatusLevel.from_dict(d["statusLevel"]) if hasattr(StatusLevel, "from_dict") else d["statusLevel"] ) if "status" in d: v["status"] = ( Status.from_dict(d["status"]) if hasattr(Status, "from_dict") else d["status"] ) if "statusContext" in d: v["status_context"] = ( StatusContext.from_dict(d["statusContext"]) if hasattr(StatusContext, "from_dict") else d["statusContext"] ) if "message" in d: v["message"] = ( str.from_dict(d["message"]) if hasattr(str, "from_dict") else d["message"] ) if "timestampEpochMs" in d: v["timestamp_epoch_ms"] = ( int.from_dict(d["timestampEpochMs"]) if hasattr(int, "from_dict") else d["timestampEpochMs"] ) return StatusMessage(**v)
[docs] def as_dict(self): d = {} if self.__event_type is not None: d["eventType"] = ( self.__event_type.as_dict() if hasattr(self.__event_type, "as_dict") else self.__event_type ) if self.__status_level is not None: d["statusLevel"] = ( self.__status_level.as_dict() if hasattr(self.__status_level, "as_dict") else self.__status_level ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__status_context is not None: d["statusContext"] = ( self.__status_context.as_dict() if hasattr(self.__status_context, "as_dict") else self.__status_context ) if self.__message is not None: d["message"] = ( self.__message.as_dict() if hasattr(self.__message, "as_dict") else self.__message ) if self.__timestamp_epoch_ms is not None: d["timestampEpochMs"] = ( self.__timestamp_epoch_ms.as_dict() if hasattr(self.__timestamp_epoch_ms, "as_dict") else self.__timestamp_epoch_ms ) return d
def __repr__(self): return "<Class StatusMessage. event_type: {}, status_level: {}, status: {}, status_context: {}, message: {}, timestamp_epoch_ms: {}>".format( limitedRepr( self.__event_type[:20] if isinstance(self.__event_type, bytes) else self.__event_type ), limitedRepr( self.__status_level[:20] if isinstance(self.__status_level, bytes) else self.__status_level ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__status_context[:20] if isinstance(self.__status_context, bytes) else self.__status_context ), limitedRepr( self.__message[:20] if isinstance(self.__message, bytes) else self.__message ), limitedRepr( self.__timestamp_epoch_ms[:20] if isinstance(self.__timestamp_epoch_ms, bytes) else self.__timestamp_epoch_ms ), )
[docs]class TraceableRequest: """ (Internal Only) TraceableRequest that contains only requestId. """ __slots__ = [ "__request_id", ] _types_map = { "request_id": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, } def __init__(self, request_id: str = None): pass self.__request_id = request_id def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) return TraceableRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) return d
def __repr__(self): return "<Class TraceableRequest. request_id: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ) )
[docs]class UnknownOperationError: """ (Internal Only) Response for UnknownOperationError. """ __slots__ = [ "__request_id", "__status", "__error_message", ] _types_map = { "request_id": {"type": str, "subtype": None}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "status": { "required": True, }, "error_message": { "required": False, }, } def __init__( self, request_id: str = None, status: ResponseStatusCode = None, error_message: str = None, ): pass self.__request_id = request_id self.__status = status self.__error_message = error_message def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) return UnknownOperationError(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) return d
def __repr__(self): return "<Class UnknownOperationError. request_id: {}, status: {}, error_message: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), )
[docs]class Persistence(enum.Enum): """ Stream persistence. If set to File, the file system will be used to persist messages long-term and is resilient to restarts. Memory should be used when performance matters more than durability as it only stores the stream in memory and never writes to the disk. """ File = 0 Memory = 1
[docs] @staticmethod def from_dict(d): return Persistence(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum Persistence. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class StatusConfig: """ Configuration for status in a status-stream. """ __slots__ = [ "__status_level", "__status_stream_name", ] _types_map = { "status_level": {"type": StatusLevel, "subtype": None}, "status_stream_name": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "status_level": { "required": False, }, "status_stream_name": { "required": False, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, } def __init__( self, status_level: StatusLevel = None, status_stream_name: str = None ): """ :param status_level: Defines the verbosity of status messages in a status-stream. :param status_stream_name: The name of the stream to which status messages are appended. The status-stream should be created before associating it with another stream. """ pass self.__status_level = status_level self.__status_stream_name = status_stream_name def _get_status_level(self): return self.__status_level def _set_status_level(self, value): if value is not None and not isinstance(value, StatusLevel): raise TypeError("status_level must be StatusLevel") self.__status_level = value status_level = property(_get_status_level, _set_status_level) """ Defines the verbosity of status messages in a status-stream. """ def _get_status_stream_name(self): return self.__status_stream_name def _set_status_stream_name(self, value): if value is not None and not isinstance(value, str): raise TypeError("status_stream_name must be str") self.__status_stream_name = value status_stream_name = property(_get_status_stream_name, _set_status_stream_name) """ The name of the stream to which status messages are appended. The status-stream should be created before associating it with another stream. """
[docs] @staticmethod def from_dict(d): v = {} if "statusLevel" in d: v["status_level"] = ( StatusLevel.from_dict(d["statusLevel"]) if hasattr(StatusLevel, "from_dict") else d["statusLevel"] ) if "statusStreamName" in d: v["status_stream_name"] = ( str.from_dict(d["statusStreamName"]) if hasattr(str, "from_dict") else d["statusStreamName"] ) return StatusConfig(**v)
[docs] def as_dict(self): d = {} if self.__status_level is not None: d["statusLevel"] = ( self.__status_level.as_dict() if hasattr(self.__status_level, "as_dict") else self.__status_level ) if self.__status_stream_name is not None: d["statusStreamName"] = ( self.__status_stream_name.as_dict() if hasattr(self.__status_stream_name, "as_dict") else self.__status_stream_name ) return d
def __repr__(self): return "<Class StatusConfig. status_level: {}, status_stream_name: {}>".format( limitedRepr( self.__status_level[:20] if isinstance(self.__status_level, bytes) else self.__status_level ), limitedRepr( self.__status_stream_name[:20] if isinstance(self.__status_stream_name, bytes) else self.__status_stream_name ), )
[docs]class S3ExportTaskExecutorConfig: """ Configuration object for S3 export tasks executor. Minimum version requirements: StreamManager server version 1.1 (or AWS IoT Greengrass Core 1.11.0) """ __slots__ = [ "__identifier", "__size_threshold_for_multipart_upload_bytes", "__priority", "__disabled", "__status_config", ] _types_map = { "identifier": {"type": str, "subtype": None}, "size_threshold_for_multipart_upload_bytes": {"type": int, "subtype": None}, "priority": {"type": int, "subtype": None}, "disabled": {"type": bool, "subtype": None}, "status_config": {"type": StatusConfig, "subtype": None}, } _formats_map = {} _validations_map = { "identifier": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, "size_threshold_for_multipart_upload_bytes": { "required": False, "minimum": 5242880, }, "priority": { "required": False, "maximum": 10, "minimum": 1, }, "disabled": { "required": False, }, "status_config": { "required": False, }, } def __init__( self, identifier: str = None, size_threshold_for_multipart_upload_bytes: int = None, priority: int = None, disabled: bool = None, status_config: StatusConfig = None, ): """ :param identifier: A unique identifier to identify this individual upload task. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. :param size_threshold_for_multipart_upload_bytes: The size threshold in bytes for when to use multipart uploads. Uploads over this size will automatically use a multipart upload strategy, while uploads equal or smaller than this threshold will use a single connection to upload the whole object. :param priority: Priority for this upload task. Lower values are higher priority. If not specified it will have the lowest priority. :param disabled: Enable or disable this export. Default is false. :param status_config: Event status configuration that specifies the target status stream and verbosity. """ pass self.__identifier = identifier self.__size_threshold_for_multipart_upload_bytes = ( size_threshold_for_multipart_upload_bytes ) self.__priority = priority self.__disabled = disabled self.__status_config = status_config def _get_identifier(self): return self.__identifier def _set_identifier(self, value): if not isinstance(value, str): raise TypeError("identifier must be str") self.__identifier = value identifier = property(_get_identifier, _set_identifier) """ A unique identifier to identify this individual upload task. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. """ def _get_size_threshold_for_multipart_upload_bytes(self): return self.__size_threshold_for_multipart_upload_bytes def _set_size_threshold_for_multipart_upload_bytes(self, value): if value is not None and not isinstance(value, int): raise TypeError("size_threshold_for_multipart_upload_bytes must be int") self.__size_threshold_for_multipart_upload_bytes = value size_threshold_for_multipart_upload_bytes = property( _get_size_threshold_for_multipart_upload_bytes, _set_size_threshold_for_multipart_upload_bytes, ) """ The size threshold in bytes for when to use multipart uploads. Uploads over this size will automatically use a multipart upload strategy, while uploads equal or smaller than this threshold will use a single connection to upload the whole object. """ def _get_priority(self): return self.__priority def _set_priority(self, value): if value is not None and not isinstance(value, int): raise TypeError("priority must be int") self.__priority = value priority = property(_get_priority, _set_priority) """ Priority for this upload task. Lower values are higher priority. If not specified it will have the lowest priority. """ def _get_disabled(self): return self.__disabled def _set_disabled(self, value): if value is not None and not isinstance(value, bool): raise TypeError("disabled must be bool") self.__disabled = value disabled = property(_get_disabled, _set_disabled) """ Enable or disable this export. Default is false. """ def _get_status_config(self): return self.__status_config def _set_status_config(self, value): if value is not None and not isinstance(value, StatusConfig): raise TypeError("status_config must be StatusConfig") self.__status_config = value status_config = property(_get_status_config, _set_status_config) """ Event status configuration that specifies the target status stream and verbosity. """
[docs] @staticmethod def from_dict(d): v = {} if "identifier" in d: v["identifier"] = ( str.from_dict(d["identifier"]) if hasattr(str, "from_dict") else d["identifier"] ) if "sizeThresholdForMultipartUploadBytes" in d: v["size_threshold_for_multipart_upload_bytes"] = ( int.from_dict(d["sizeThresholdForMultipartUploadBytes"]) if hasattr(int, "from_dict") else d["sizeThresholdForMultipartUploadBytes"] ) if "priority" in d: v["priority"] = ( int.from_dict(d["priority"]) if hasattr(int, "from_dict") else d["priority"] ) if "disabled" in d: v["disabled"] = ( bool.from_dict(d["disabled"]) if hasattr(bool, "from_dict") else d["disabled"] ) if "statusConfig" in d: v["status_config"] = ( StatusConfig.from_dict(d["statusConfig"]) if hasattr(StatusConfig, "from_dict") else d["statusConfig"] ) return S3ExportTaskExecutorConfig(**v)
[docs] def as_dict(self): d = {} if self.__identifier is not None: d["identifier"] = ( self.__identifier.as_dict() if hasattr(self.__identifier, "as_dict") else self.__identifier ) if self.__size_threshold_for_multipart_upload_bytes is not None: d["sizeThresholdForMultipartUploadBytes"] = ( self.__size_threshold_for_multipart_upload_bytes.as_dict() if hasattr(self.__size_threshold_for_multipart_upload_bytes, "as_dict") else self.__size_threshold_for_multipart_upload_bytes ) if self.__priority is not None: d["priority"] = ( self.__priority.as_dict() if hasattr(self.__priority, "as_dict") else self.__priority ) if self.__disabled is not None: d["disabled"] = ( self.__disabled.as_dict() if hasattr(self.__disabled, "as_dict") else self.__disabled ) if self.__status_config is not None: d["statusConfig"] = ( self.__status_config.as_dict() if hasattr(self.__status_config, "as_dict") else self.__status_config ) return d
def __repr__(self): return "<Class S3ExportTaskExecutorConfig. identifier: {}, size_threshold_for_multipart_upload_bytes: {}, priority: {}, disabled: {}, status_config: {}>".format( limitedRepr( self.__identifier[:20] if isinstance(self.__identifier, bytes) else self.__identifier ), limitedRepr( self.__size_threshold_for_multipart_upload_bytes[:20] if isinstance(self.__size_threshold_for_multipart_upload_bytes, bytes) else self.__size_threshold_for_multipart_upload_bytes ), limitedRepr( self.__priority[:20] if isinstance(self.__priority, bytes) else self.__priority ), limitedRepr( self.__disabled[:20] if isinstance(self.__disabled, bytes) else self.__disabled ), limitedRepr( self.__status_config[:20] if isinstance(self.__status_config, bytes) else self.__status_config ), )
[docs]class ExportFormat(enum.Enum): """ ExportFormat is used to define how messages are batched and formatted in the export payload. RAW_NOT_BATCHED: Each message in a batch will be sent as an individual HTTP POST with the payload as the body (even if batchSize is set). JSON_BATCHED: Each batch of messages will be sent as a JSON list of Message objects as the body. """ RAW_NOT_BATCHED = 0 JSON_BATCHED = 1
[docs] @staticmethod def from_dict(d): return ExportFormat(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum ExportFormat. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class HTTPConfig: """ This export destination is not supported! The interface may change at any time without notice and should not be relied on for any production use. There are no guarantees around its correctness. This configures an HTTP endpoint which sends a POST request to the provided URI. Each request contains a single message in the body of the request. """ __slots__ = [ "__identifier", "__uri", "__batch_size", "__batch_interval_millis", "__priority", "__start_sequence_number", "__disabled", "__export_format", ] _types_map = { "identifier": {"type": str, "subtype": None}, "uri": {"type": str, "subtype": None}, "batch_size": {"type": int, "subtype": None}, "batch_interval_millis": {"type": int, "subtype": None}, "priority": {"type": int, "subtype": None}, "start_sequence_number": {"type": int, "subtype": None}, "disabled": {"type": bool, "subtype": None}, "export_format": {"type": ExportFormat, "subtype": None}, } _formats_map = {} _validations_map = { "identifier": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, "uri": { "required": True, "minLength": 1, }, "batch_size": { "required": False, "maximum": 500, "minimum": 1, }, "batch_interval_millis": { "required": False, "maximum": 9223372036854, "minimum": 60000, }, "priority": { "required": False, "maximum": 10, "minimum": 1, }, "start_sequence_number": { "required": False, "maximum": 9223372036854775807, "minimum": 0, }, "disabled": { "required": False, }, "export_format": { "required": False, }, } def __init__( self, identifier: str = None, uri: str = None, batch_size: int = None, batch_interval_millis: int = None, priority: int = None, start_sequence_number: int = None, disabled: bool = None, export_format: ExportFormat = None, ): """ :param identifier: A unique identifier to identify this individual upload stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. :param uri: URL for HTTP endpoint which should receive the POST requests for export. :param batch_size: The maximum size of a batch to send to the destination. Messages will be queued until the batch size is reached, after which they will then be uploaded. If unspecified the default will be 500. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum batch size is 1 and the maximum is 500. :param batch_interval_millis: The time in milliseconds between the earliest un-uploaded message and the current time. If this time is exceeded, messages will be uploaded in the next batch. If unspecified messages will be eligible for upload immediately. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. :param priority: Priority for this upload stream. Lower values are higher priority. If not specified it will have the lowest priority. :param start_sequence_number: The sequence number of the message to use as the starting message in the export. Default is 0. The sequence number provided should be less than the newest sequence number in the stream, i.e., sequence number of the last messaged appended. To find the newest sequence number, describe the stream and then check the storage status of the returned MessageStreamInfo object. :param disabled: Enable or disable this export. Default is false. :param export_format: Defines how messages are batched and formatted in the export payload. """ pass self.__identifier = identifier self.__uri = uri self.__batch_size = batch_size self.__batch_interval_millis = batch_interval_millis self.__priority = priority self.__start_sequence_number = start_sequence_number self.__disabled = disabled self.__export_format = export_format def _get_identifier(self): return self.__identifier def _set_identifier(self, value): if not isinstance(value, str): raise TypeError("identifier must be str") self.__identifier = value identifier = property(_get_identifier, _set_identifier) """ A unique identifier to identify this individual upload stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. """ def _get_uri(self): return self.__uri def _set_uri(self, value): if not isinstance(value, str): raise TypeError("uri must be str") self.__uri = value uri = property(_get_uri, _set_uri) """ URL for HTTP endpoint which should receive the POST requests for export. """ def _get_batch_size(self): return self.__batch_size def _set_batch_size(self, value): if value is not None and not isinstance(value, int): raise TypeError("batch_size must be int") self.__batch_size = value batch_size = property(_get_batch_size, _set_batch_size) """ The maximum size of a batch to send to the destination. Messages will be queued until the batch size is reached, after which they will then be uploaded. If unspecified the default will be 500. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum batch size is 1 and the maximum is 500. """ def _get_batch_interval_millis(self): return self.__batch_interval_millis def _set_batch_interval_millis(self, value): if value is not None and not isinstance(value, int): raise TypeError("batch_interval_millis must be int") self.__batch_interval_millis = value batch_interval_millis = property( _get_batch_interval_millis, _set_batch_interval_millis ) """ The time in milliseconds between the earliest un-uploaded message and the current time. If this time is exceeded, messages will be uploaded in the next batch. If unspecified messages will be eligible for upload immediately. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. """ def _get_priority(self): return self.__priority def _set_priority(self, value): if value is not None and not isinstance(value, int): raise TypeError("priority must be int") self.__priority = value priority = property(_get_priority, _set_priority) """ Priority for this upload stream. Lower values are higher priority. If not specified it will have the lowest priority. """ def _get_start_sequence_number(self): return self.__start_sequence_number def _set_start_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("start_sequence_number must be int") self.__start_sequence_number = value start_sequence_number = property( _get_start_sequence_number, _set_start_sequence_number ) """ The sequence number of the message to use as the starting message in the export. Default is 0. The sequence number provided should be less than the newest sequence number in the stream, i.e., sequence number of the last messaged appended. To find the newest sequence number, describe the stream and then check the storage status of the returned MessageStreamInfo object. """ def _get_disabled(self): return self.__disabled def _set_disabled(self, value): if value is not None and not isinstance(value, bool): raise TypeError("disabled must be bool") self.__disabled = value disabled = property(_get_disabled, _set_disabled) """ Enable or disable this export. Default is false. """ def _get_export_format(self): return self.__export_format def _set_export_format(self, value): if value is not None and not isinstance(value, ExportFormat): raise TypeError("export_format must be ExportFormat") self.__export_format = value export_format = property(_get_export_format, _set_export_format) """ Defines how messages are batched and formatted in the export payload. """
[docs] @staticmethod def from_dict(d): v = {} if "identifier" in d: v["identifier"] = ( str.from_dict(d["identifier"]) if hasattr(str, "from_dict") else d["identifier"] ) if "uri" in d: v["uri"] = ( str.from_dict(d["uri"]) if hasattr(str, "from_dict") else d["uri"] ) if "batchSize" in d: v["batch_size"] = ( int.from_dict(d["batchSize"]) if hasattr(int, "from_dict") else d["batchSize"] ) if "batchIntervalMillis" in d: v["batch_interval_millis"] = ( int.from_dict(d["batchIntervalMillis"]) if hasattr(int, "from_dict") else d["batchIntervalMillis"] ) if "priority" in d: v["priority"] = ( int.from_dict(d["priority"]) if hasattr(int, "from_dict") else d["priority"] ) if "startSequenceNumber" in d: v["start_sequence_number"] = ( int.from_dict(d["startSequenceNumber"]) if hasattr(int, "from_dict") else d["startSequenceNumber"] ) if "disabled" in d: v["disabled"] = ( bool.from_dict(d["disabled"]) if hasattr(bool, "from_dict") else d["disabled"] ) if "exportFormat" in d: v["export_format"] = ( ExportFormat.from_dict(d["exportFormat"]) if hasattr(ExportFormat, "from_dict") else d["exportFormat"] ) return HTTPConfig(**v)
[docs] def as_dict(self): d = {} if self.__identifier is not None: d["identifier"] = ( self.__identifier.as_dict() if hasattr(self.__identifier, "as_dict") else self.__identifier ) if self.__uri is not None: d["uri"] = ( self.__uri.as_dict() if hasattr(self.__uri, "as_dict") else self.__uri ) if self.__batch_size is not None: d["batchSize"] = ( self.__batch_size.as_dict() if hasattr(self.__batch_size, "as_dict") else self.__batch_size ) if self.__batch_interval_millis is not None: d["batchIntervalMillis"] = ( self.__batch_interval_millis.as_dict() if hasattr(self.__batch_interval_millis, "as_dict") else self.__batch_interval_millis ) if self.__priority is not None: d["priority"] = ( self.__priority.as_dict() if hasattr(self.__priority, "as_dict") else self.__priority ) if self.__start_sequence_number is not None: d["startSequenceNumber"] = ( self.__start_sequence_number.as_dict() if hasattr(self.__start_sequence_number, "as_dict") else self.__start_sequence_number ) if self.__disabled is not None: d["disabled"] = ( self.__disabled.as_dict() if hasattr(self.__disabled, "as_dict") else self.__disabled ) if self.__export_format is not None: d["exportFormat"] = ( self.__export_format.as_dict() if hasattr(self.__export_format, "as_dict") else self.__export_format ) return d
def __repr__(self): return "<Class HTTPConfig. identifier: {}, uri: {}, batch_size: {}, batch_interval_millis: {}, priority: {}, start_sequence_number: {}, disabled: {}, export_format: {}>".format( limitedRepr( self.__identifier[:20] if isinstance(self.__identifier, bytes) else self.__identifier ), limitedRepr( self.__uri[:20] if isinstance(self.__uri, bytes) else self.__uri ), limitedRepr( self.__batch_size[:20] if isinstance(self.__batch_size, bytes) else self.__batch_size ), limitedRepr( self.__batch_interval_millis[:20] if isinstance(self.__batch_interval_millis, bytes) else self.__batch_interval_millis ), limitedRepr( self.__priority[:20] if isinstance(self.__priority, bytes) else self.__priority ), limitedRepr( self.__start_sequence_number[:20] if isinstance(self.__start_sequence_number, bytes) else self.__start_sequence_number ), limitedRepr( self.__disabled[:20] if isinstance(self.__disabled, bytes) else self.__disabled ), limitedRepr( self.__export_format[:20] if isinstance(self.__export_format, bytes) else self.__export_format ), )
[docs]class IoTAnalyticsConfig: """ Configuration object for IoT Analytics export destination. """ __slots__ = [ "__identifier", "__iot_channel", "__iot_msg_id_prefix", "__batch_size", "__batch_interval_millis", "__priority", "__start_sequence_number", "__disabled", ] _types_map = { "identifier": {"type": str, "subtype": None}, "iot_channel": {"type": str, "subtype": None}, "iot_msg_id_prefix": {"type": str, "subtype": None}, "batch_size": {"type": int, "subtype": None}, "batch_interval_millis": {"type": int, "subtype": None}, "priority": {"type": int, "subtype": None}, "start_sequence_number": {"type": int, "subtype": None}, "disabled": {"type": bool, "subtype": None}, } _formats_map = {} _validations_map = { "identifier": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, "iot_channel": { "required": True, "minLength": 1, }, "iot_msg_id_prefix": { "required": False, "maxLength": 32, }, "batch_size": { "required": False, "maximum": 100, "minimum": 1, }, "batch_interval_millis": { "required": False, "maximum": 9223372036854, "minimum": 60000, }, "priority": { "required": False, "maximum": 10, "minimum": 1, }, "start_sequence_number": { "required": False, "maximum": 9223372036854775807, "minimum": 0, }, "disabled": { "required": False, }, } def __init__( self, identifier: str = None, iot_channel: str = None, iot_msg_id_prefix: str = None, batch_size: int = None, batch_interval_millis: int = None, priority: int = None, start_sequence_number: int = None, disabled: bool = None, ): """ :param identifier: A unique identifier to identify this individual upload stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. :param iot_channel: The name of the IoT Analytics Channel that this exporter should upload to. :param iot_msg_id_prefix: A string prefixed to each unique message id. After this prefix, StreamManager may append more data to make the message ID unique. This prefix must be less than 32 characters. :param batch_size: The maximum size of a batch to send to IoT Analytics. Messages will be queued until the batch size is reached, after which they will then be uploaded. If unspecified the default will be 100. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The batch size must be between 1 and 100. :param batch_interval_millis: The time in milliseconds between the earliest un-uploaded message and the current time. If this time is exceeded, messages will be uploaded in the next batch. If unspecified messages will be eligible for upload immediately. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. :param priority: Priority for this upload stream. Lower values are higher priority. If not specified it will have the lowest priority. :param start_sequence_number: The sequence number of the message to use as the starting message in the export. Default is 0. The sequence number provided should be less than the newest sequence number in the stream, i.e., sequence number of the last messaged appended. To find the newest sequence number, describe the stream and then check the storage status of the returned MessageStreamInfo object. :param disabled: Enable or disable this export. Default is false. """ pass self.__identifier = identifier self.__iot_channel = iot_channel self.__iot_msg_id_prefix = iot_msg_id_prefix self.__batch_size = batch_size self.__batch_interval_millis = batch_interval_millis self.__priority = priority self.__start_sequence_number = start_sequence_number self.__disabled = disabled def _get_identifier(self): return self.__identifier def _set_identifier(self, value): if not isinstance(value, str): raise TypeError("identifier must be str") self.__identifier = value identifier = property(_get_identifier, _set_identifier) """ A unique identifier to identify this individual upload stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. """ def _get_iot_channel(self): return self.__iot_channel def _set_iot_channel(self, value): if not isinstance(value, str): raise TypeError("iot_channel must be str") self.__iot_channel = value iot_channel = property(_get_iot_channel, _set_iot_channel) """ The name of the IoT Analytics Channel that this exporter should upload to. """ def _get_iot_msg_id_prefix(self): return self.__iot_msg_id_prefix def _set_iot_msg_id_prefix(self, value): if value is not None and not isinstance(value, str): raise TypeError("iot_msg_id_prefix must be str") self.__iot_msg_id_prefix = value iot_msg_id_prefix = property(_get_iot_msg_id_prefix, _set_iot_msg_id_prefix) """ A string prefixed to each unique message id. After this prefix, StreamManager may append more data to make the message ID unique. This prefix must be less than 32 characters. """ def _get_batch_size(self): return self.__batch_size def _set_batch_size(self, value): if value is not None and not isinstance(value, int): raise TypeError("batch_size must be int") self.__batch_size = value batch_size = property(_get_batch_size, _set_batch_size) """ The maximum size of a batch to send to IoT Analytics. Messages will be queued until the batch size is reached, after which they will then be uploaded. If unspecified the default will be 100. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The batch size must be between 1 and 100. """ def _get_batch_interval_millis(self): return self.__batch_interval_millis def _set_batch_interval_millis(self, value): if value is not None and not isinstance(value, int): raise TypeError("batch_interval_millis must be int") self.__batch_interval_millis = value batch_interval_millis = property( _get_batch_interval_millis, _set_batch_interval_millis ) """ The time in milliseconds between the earliest un-uploaded message and the current time. If this time is exceeded, messages will be uploaded in the next batch. If unspecified messages will be eligible for upload immediately. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. """ def _get_priority(self): return self.__priority def _set_priority(self, value): if value is not None and not isinstance(value, int): raise TypeError("priority must be int") self.__priority = value priority = property(_get_priority, _set_priority) """ Priority for this upload stream. Lower values are higher priority. If not specified it will have the lowest priority. """ def _get_start_sequence_number(self): return self.__start_sequence_number def _set_start_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("start_sequence_number must be int") self.__start_sequence_number = value start_sequence_number = property( _get_start_sequence_number, _set_start_sequence_number ) """ The sequence number of the message to use as the starting message in the export. Default is 0. The sequence number provided should be less than the newest sequence number in the stream, i.e., sequence number of the last messaged appended. To find the newest sequence number, describe the stream and then check the storage status of the returned MessageStreamInfo object. """ def _get_disabled(self): return self.__disabled def _set_disabled(self, value): if value is not None and not isinstance(value, bool): raise TypeError("disabled must be bool") self.__disabled = value disabled = property(_get_disabled, _set_disabled) """ Enable or disable this export. Default is false. """
[docs] @staticmethod def from_dict(d): v = {} if "identifier" in d: v["identifier"] = ( str.from_dict(d["identifier"]) if hasattr(str, "from_dict") else d["identifier"] ) if "iotChannel" in d: v["iot_channel"] = ( str.from_dict(d["iotChannel"]) if hasattr(str, "from_dict") else d["iotChannel"] ) if "iotMsgIdPrefix" in d: v["iot_msg_id_prefix"] = ( str.from_dict(d["iotMsgIdPrefix"]) if hasattr(str, "from_dict") else d["iotMsgIdPrefix"] ) if "batchSize" in d: v["batch_size"] = ( int.from_dict(d["batchSize"]) if hasattr(int, "from_dict") else d["batchSize"] ) if "batchIntervalMillis" in d: v["batch_interval_millis"] = ( int.from_dict(d["batchIntervalMillis"]) if hasattr(int, "from_dict") else d["batchIntervalMillis"] ) if "priority" in d: v["priority"] = ( int.from_dict(d["priority"]) if hasattr(int, "from_dict") else d["priority"] ) if "startSequenceNumber" in d: v["start_sequence_number"] = ( int.from_dict(d["startSequenceNumber"]) if hasattr(int, "from_dict") else d["startSequenceNumber"] ) if "disabled" in d: v["disabled"] = ( bool.from_dict(d["disabled"]) if hasattr(bool, "from_dict") else d["disabled"] ) return IoTAnalyticsConfig(**v)
[docs] def as_dict(self): d = {} if self.__identifier is not None: d["identifier"] = ( self.__identifier.as_dict() if hasattr(self.__identifier, "as_dict") else self.__identifier ) if self.__iot_channel is not None: d["iotChannel"] = ( self.__iot_channel.as_dict() if hasattr(self.__iot_channel, "as_dict") else self.__iot_channel ) if self.__iot_msg_id_prefix is not None: d["iotMsgIdPrefix"] = ( self.__iot_msg_id_prefix.as_dict() if hasattr(self.__iot_msg_id_prefix, "as_dict") else self.__iot_msg_id_prefix ) if self.__batch_size is not None: d["batchSize"] = ( self.__batch_size.as_dict() if hasattr(self.__batch_size, "as_dict") else self.__batch_size ) if self.__batch_interval_millis is not None: d["batchIntervalMillis"] = ( self.__batch_interval_millis.as_dict() if hasattr(self.__batch_interval_millis, "as_dict") else self.__batch_interval_millis ) if self.__priority is not None: d["priority"] = ( self.__priority.as_dict() if hasattr(self.__priority, "as_dict") else self.__priority ) if self.__start_sequence_number is not None: d["startSequenceNumber"] = ( self.__start_sequence_number.as_dict() if hasattr(self.__start_sequence_number, "as_dict") else self.__start_sequence_number ) if self.__disabled is not None: d["disabled"] = ( self.__disabled.as_dict() if hasattr(self.__disabled, "as_dict") else self.__disabled ) return d
def __repr__(self): return "<Class IoTAnalyticsConfig. identifier: {}, iot_channel: {}, iot_msg_id_prefix: {}, batch_size: {}, batch_interval_millis: {}, priority: {}, start_sequence_number: {}, disabled: {}>".format( limitedRepr( self.__identifier[:20] if isinstance(self.__identifier, bytes) else self.__identifier ), limitedRepr( self.__iot_channel[:20] if isinstance(self.__iot_channel, bytes) else self.__iot_channel ), limitedRepr( self.__iot_msg_id_prefix[:20] if isinstance(self.__iot_msg_id_prefix, bytes) else self.__iot_msg_id_prefix ), limitedRepr( self.__batch_size[:20] if isinstance(self.__batch_size, bytes) else self.__batch_size ), limitedRepr( self.__batch_interval_millis[:20] if isinstance(self.__batch_interval_millis, bytes) else self.__batch_interval_millis ), limitedRepr( self.__priority[:20] if isinstance(self.__priority, bytes) else self.__priority ), limitedRepr( self.__start_sequence_number[:20] if isinstance(self.__start_sequence_number, bytes) else self.__start_sequence_number ), limitedRepr( self.__disabled[:20] if isinstance(self.__disabled, bytes) else self.__disabled ), )
[docs]class IoTSiteWiseConfig: """ Configuration object for IotSiteWise data streams export destination. Minimum version requirements: StreamManager server version 1.1 (or AWS IoT Greengrass Core 1.11.0) """ __slots__ = [ "__identifier", "__batch_size", "__batch_interval_millis", "__priority", "__start_sequence_number", "__disabled", ] _types_map = { "identifier": {"type": str, "subtype": None}, "batch_size": {"type": int, "subtype": None}, "batch_interval_millis": {"type": int, "subtype": None}, "priority": {"type": int, "subtype": None}, "start_sequence_number": {"type": int, "subtype": None}, "disabled": {"type": bool, "subtype": None}, } _formats_map = {} _validations_map = { "identifier": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, "batch_size": { "required": False, "maximum": 10, "minimum": 1, }, "batch_interval_millis": { "required": False, "maximum": 9223372036854, "minimum": 60000, }, "priority": { "required": False, "maximum": 10, "minimum": 1, }, "start_sequence_number": { "required": False, "maximum": 9223372036854775807, "minimum": 0, }, "disabled": { "required": False, }, } def __init__( self, identifier: str = None, batch_size: int = None, batch_interval_millis: int = None, priority: int = None, start_sequence_number: int = None, disabled: bool = None, ): """ :param identifier: A unique identifier to identify this individual upload stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. :param batch_size: The maximum size of a batch to send to the destination. Messages will be queued until the batch size is reached, after which they will then be uploaded. If unspecified the default will be 10. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum batch size is 1 and the maximum is 10. :param batch_interval_millis: The time in milliseconds between the earliest un-uploaded message and the current time. If this time is exceeded, messages will be uploaded in the next batch. If unspecified messages will be eligible for upload immediately. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. :param priority: Priority for this upload stream. Lower values are higher priority. If not specified it will have the lowest priority. :param start_sequence_number: The sequence number of the message to use as the starting message in the export. Default is 0. The sequence number provided should be less than the newest sequence number in the stream, i.e., sequence number of the last messaged appended. To find the newest sequence number, describe the stream and then check the storage status of the returned MessageStreamInfo object. :param disabled: Enable or disable this export. Default is false. """ pass self.__identifier = identifier self.__batch_size = batch_size self.__batch_interval_millis = batch_interval_millis self.__priority = priority self.__start_sequence_number = start_sequence_number self.__disabled = disabled def _get_identifier(self): return self.__identifier def _set_identifier(self, value): if not isinstance(value, str): raise TypeError("identifier must be str") self.__identifier = value identifier = property(_get_identifier, _set_identifier) """ A unique identifier to identify this individual upload stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. """ def _get_batch_size(self): return self.__batch_size def _set_batch_size(self, value): if value is not None and not isinstance(value, int): raise TypeError("batch_size must be int") self.__batch_size = value batch_size = property(_get_batch_size, _set_batch_size) """ The maximum size of a batch to send to the destination. Messages will be queued until the batch size is reached, after which they will then be uploaded. If unspecified the default will be 10. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum batch size is 1 and the maximum is 10. """ def _get_batch_interval_millis(self): return self.__batch_interval_millis def _set_batch_interval_millis(self, value): if value is not None and not isinstance(value, int): raise TypeError("batch_interval_millis must be int") self.__batch_interval_millis = value batch_interval_millis = property( _get_batch_interval_millis, _set_batch_interval_millis ) """ The time in milliseconds between the earliest un-uploaded message and the current time. If this time is exceeded, messages will be uploaded in the next batch. If unspecified messages will be eligible for upload immediately. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. """ def _get_priority(self): return self.__priority def _set_priority(self, value): if value is not None and not isinstance(value, int): raise TypeError("priority must be int") self.__priority = value priority = property(_get_priority, _set_priority) """ Priority for this upload stream. Lower values are higher priority. If not specified it will have the lowest priority. """ def _get_start_sequence_number(self): return self.__start_sequence_number def _set_start_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("start_sequence_number must be int") self.__start_sequence_number = value start_sequence_number = property( _get_start_sequence_number, _set_start_sequence_number ) """ The sequence number of the message to use as the starting message in the export. Default is 0. The sequence number provided should be less than the newest sequence number in the stream, i.e., sequence number of the last messaged appended. To find the newest sequence number, describe the stream and then check the storage status of the returned MessageStreamInfo object. """ def _get_disabled(self): return self.__disabled def _set_disabled(self, value): if value is not None and not isinstance(value, bool): raise TypeError("disabled must be bool") self.__disabled = value disabled = property(_get_disabled, _set_disabled) """ Enable or disable this export. Default is false. """
[docs] @staticmethod def from_dict(d): v = {} if "identifier" in d: v["identifier"] = ( str.from_dict(d["identifier"]) if hasattr(str, "from_dict") else d["identifier"] ) if "batchSize" in d: v["batch_size"] = ( int.from_dict(d["batchSize"]) if hasattr(int, "from_dict") else d["batchSize"] ) if "batchIntervalMillis" in d: v["batch_interval_millis"] = ( int.from_dict(d["batchIntervalMillis"]) if hasattr(int, "from_dict") else d["batchIntervalMillis"] ) if "priority" in d: v["priority"] = ( int.from_dict(d["priority"]) if hasattr(int, "from_dict") else d["priority"] ) if "startSequenceNumber" in d: v["start_sequence_number"] = ( int.from_dict(d["startSequenceNumber"]) if hasattr(int, "from_dict") else d["startSequenceNumber"] ) if "disabled" in d: v["disabled"] = ( bool.from_dict(d["disabled"]) if hasattr(bool, "from_dict") else d["disabled"] ) return IoTSiteWiseConfig(**v)
[docs] def as_dict(self): d = {} if self.__identifier is not None: d["identifier"] = ( self.__identifier.as_dict() if hasattr(self.__identifier, "as_dict") else self.__identifier ) if self.__batch_size is not None: d["batchSize"] = ( self.__batch_size.as_dict() if hasattr(self.__batch_size, "as_dict") else self.__batch_size ) if self.__batch_interval_millis is not None: d["batchIntervalMillis"] = ( self.__batch_interval_millis.as_dict() if hasattr(self.__batch_interval_millis, "as_dict") else self.__batch_interval_millis ) if self.__priority is not None: d["priority"] = ( self.__priority.as_dict() if hasattr(self.__priority, "as_dict") else self.__priority ) if self.__start_sequence_number is not None: d["startSequenceNumber"] = ( self.__start_sequence_number.as_dict() if hasattr(self.__start_sequence_number, "as_dict") else self.__start_sequence_number ) if self.__disabled is not None: d["disabled"] = ( self.__disabled.as_dict() if hasattr(self.__disabled, "as_dict") else self.__disabled ) return d
def __repr__(self): return "<Class IoTSiteWiseConfig. identifier: {}, batch_size: {}, batch_interval_millis: {}, priority: {}, start_sequence_number: {}, disabled: {}>".format( limitedRepr( self.__identifier[:20] if isinstance(self.__identifier, bytes) else self.__identifier ), limitedRepr( self.__batch_size[:20] if isinstance(self.__batch_size, bytes) else self.__batch_size ), limitedRepr( self.__batch_interval_millis[:20] if isinstance(self.__batch_interval_millis, bytes) else self.__batch_interval_millis ), limitedRepr( self.__priority[:20] if isinstance(self.__priority, bytes) else self.__priority ), limitedRepr( self.__start_sequence_number[:20] if isinstance(self.__start_sequence_number, bytes) else self.__start_sequence_number ), limitedRepr( self.__disabled[:20] if isinstance(self.__disabled, bytes) else self.__disabled ), )
[docs]class KinesisConfig: """ Configuration object for Kinesis data streams export destination. """ __slots__ = [ "__identifier", "__kinesis_stream_name", "__batch_size", "__batch_interval_millis", "__priority", "__start_sequence_number", "__disabled", ] _types_map = { "identifier": {"type": str, "subtype": None}, "kinesis_stream_name": {"type": str, "subtype": None}, "batch_size": {"type": int, "subtype": None}, "batch_interval_millis": {"type": int, "subtype": None}, "priority": {"type": int, "subtype": None}, "start_sequence_number": {"type": int, "subtype": None}, "disabled": {"type": bool, "subtype": None}, } _formats_map = {} _validations_map = { "identifier": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, "kinesis_stream_name": { "required": True, "minLength": 1, }, "batch_size": { "required": False, "maximum": 500, "minimum": 1, }, "batch_interval_millis": { "required": False, "maximum": 9223372036854, "minimum": 60000, }, "priority": { "required": False, "maximum": 10, "minimum": 1, }, "start_sequence_number": { "required": False, "maximum": 9223372036854775807, "minimum": 0, }, "disabled": { "required": False, }, } def __init__( self, identifier: str = None, kinesis_stream_name: str = None, batch_size: int = None, batch_interval_millis: int = None, priority: int = None, start_sequence_number: int = None, disabled: bool = None, ): """ :param identifier: A unique identifier to identify this individual upload stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. :param kinesis_stream_name: The name of the Kinesis data stream that this exporter should upload to. :param batch_size: The maximum size of a batch to send to Kinesis. Messages will be queued until the batch size is reached, after which they will then be uploaded. If unspecified the default will be 500. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The batch size must be between 1 and 500. :param batch_interval_millis: The time in milliseconds between the earliest un-uploaded message and the current time. If this time is exceeded, messages will be uploaded in the next batch. If unspecified messages will be eligible for upload immediately. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. :param priority: Priority for this upload stream. Lower values are higher priority. If not specified it will have the lowest priority. :param start_sequence_number: The sequence number of the message to use as the starting message in the export. Default is 0. The sequence number provided should be less than the newest sequence number in the stream, i.e., sequence number of the last messaged appended. To find the newest sequence number, describe the stream and then check the storage status of the returned MessageStreamInfo object. :param disabled: Enable or disable this export. Default is false. """ pass self.__identifier = identifier self.__kinesis_stream_name = kinesis_stream_name self.__batch_size = batch_size self.__batch_interval_millis = batch_interval_millis self.__priority = priority self.__start_sequence_number = start_sequence_number self.__disabled = disabled def _get_identifier(self): return self.__identifier def _set_identifier(self, value): if not isinstance(value, str): raise TypeError("identifier must be str") self.__identifier = value identifier = property(_get_identifier, _set_identifier) """ A unique identifier to identify this individual upload stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. """ def _get_kinesis_stream_name(self): return self.__kinesis_stream_name def _set_kinesis_stream_name(self, value): if not isinstance(value, str): raise TypeError("kinesis_stream_name must be str") self.__kinesis_stream_name = value kinesis_stream_name = property(_get_kinesis_stream_name, _set_kinesis_stream_name) """ The name of the Kinesis data stream that this exporter should upload to. """ def _get_batch_size(self): return self.__batch_size def _set_batch_size(self, value): if value is not None and not isinstance(value, int): raise TypeError("batch_size must be int") self.__batch_size = value batch_size = property(_get_batch_size, _set_batch_size) """ The maximum size of a batch to send to Kinesis. Messages will be queued until the batch size is reached, after which they will then be uploaded. If unspecified the default will be 500. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The batch size must be between 1 and 500. """ def _get_batch_interval_millis(self): return self.__batch_interval_millis def _set_batch_interval_millis(self, value): if value is not None and not isinstance(value, int): raise TypeError("batch_interval_millis must be int") self.__batch_interval_millis = value batch_interval_millis = property( _get_batch_interval_millis, _set_batch_interval_millis ) """ The time in milliseconds between the earliest un-uploaded message and the current time. If this time is exceeded, messages will be uploaded in the next batch. If unspecified messages will be eligible for upload immediately. If both batchSize and batchIntervalMillis are specified, then messages will be eligible for upload when either condition is met. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. """ def _get_priority(self): return self.__priority def _set_priority(self, value): if value is not None and not isinstance(value, int): raise TypeError("priority must be int") self.__priority = value priority = property(_get_priority, _set_priority) """ Priority for this upload stream. Lower values are higher priority. If not specified it will have the lowest priority. """ def _get_start_sequence_number(self): return self.__start_sequence_number def _set_start_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("start_sequence_number must be int") self.__start_sequence_number = value start_sequence_number = property( _get_start_sequence_number, _set_start_sequence_number ) """ The sequence number of the message to use as the starting message in the export. Default is 0. The sequence number provided should be less than the newest sequence number in the stream, i.e., sequence number of the last messaged appended. To find the newest sequence number, describe the stream and then check the storage status of the returned MessageStreamInfo object. """ def _get_disabled(self): return self.__disabled def _set_disabled(self, value): if value is not None and not isinstance(value, bool): raise TypeError("disabled must be bool") self.__disabled = value disabled = property(_get_disabled, _set_disabled) """ Enable or disable this export. Default is false. """
[docs] @staticmethod def from_dict(d): v = {} if "identifier" in d: v["identifier"] = ( str.from_dict(d["identifier"]) if hasattr(str, "from_dict") else d["identifier"] ) if "kinesisStreamName" in d: v["kinesis_stream_name"] = ( str.from_dict(d["kinesisStreamName"]) if hasattr(str, "from_dict") else d["kinesisStreamName"] ) if "batchSize" in d: v["batch_size"] = ( int.from_dict(d["batchSize"]) if hasattr(int, "from_dict") else d["batchSize"] ) if "batchIntervalMillis" in d: v["batch_interval_millis"] = ( int.from_dict(d["batchIntervalMillis"]) if hasattr(int, "from_dict") else d["batchIntervalMillis"] ) if "priority" in d: v["priority"] = ( int.from_dict(d["priority"]) if hasattr(int, "from_dict") else d["priority"] ) if "startSequenceNumber" in d: v["start_sequence_number"] = ( int.from_dict(d["startSequenceNumber"]) if hasattr(int, "from_dict") else d["startSequenceNumber"] ) if "disabled" in d: v["disabled"] = ( bool.from_dict(d["disabled"]) if hasattr(bool, "from_dict") else d["disabled"] ) return KinesisConfig(**v)
[docs] def as_dict(self): d = {} if self.__identifier is not None: d["identifier"] = ( self.__identifier.as_dict() if hasattr(self.__identifier, "as_dict") else self.__identifier ) if self.__kinesis_stream_name is not None: d["kinesisStreamName"] = ( self.__kinesis_stream_name.as_dict() if hasattr(self.__kinesis_stream_name, "as_dict") else self.__kinesis_stream_name ) if self.__batch_size is not None: d["batchSize"] = ( self.__batch_size.as_dict() if hasattr(self.__batch_size, "as_dict") else self.__batch_size ) if self.__batch_interval_millis is not None: d["batchIntervalMillis"] = ( self.__batch_interval_millis.as_dict() if hasattr(self.__batch_interval_millis, "as_dict") else self.__batch_interval_millis ) if self.__priority is not None: d["priority"] = ( self.__priority.as_dict() if hasattr(self.__priority, "as_dict") else self.__priority ) if self.__start_sequence_number is not None: d["startSequenceNumber"] = ( self.__start_sequence_number.as_dict() if hasattr(self.__start_sequence_number, "as_dict") else self.__start_sequence_number ) if self.__disabled is not None: d["disabled"] = ( self.__disabled.as_dict() if hasattr(self.__disabled, "as_dict") else self.__disabled ) return d
def __repr__(self): return "<Class KinesisConfig. identifier: {}, kinesis_stream_name: {}, batch_size: {}, batch_interval_millis: {}, priority: {}, start_sequence_number: {}, disabled: {}>".format( limitedRepr( self.__identifier[:20] if isinstance(self.__identifier, bytes) else self.__identifier ), limitedRepr( self.__kinesis_stream_name[:20] if isinstance(self.__kinesis_stream_name, bytes) else self.__kinesis_stream_name ), limitedRepr( self.__batch_size[:20] if isinstance(self.__batch_size, bytes) else self.__batch_size ), limitedRepr( self.__batch_interval_millis[:20] if isinstance(self.__batch_interval_millis, bytes) else self.__batch_interval_millis ), limitedRepr( self.__priority[:20] if isinstance(self.__priority, bytes) else self.__priority ), limitedRepr( self.__start_sequence_number[:20] if isinstance(self.__start_sequence_number, bytes) else self.__start_sequence_number ), limitedRepr( self.__disabled[:20] if isinstance(self.__disabled, bytes) else self.__disabled ), )
[docs]class ExportDefinition: """ Defines how and where the stream is uploaded. """ __slots__ = [ "__http", "__iot_analytics", "__kinesis", "__iot_sitewise", "__s3_task_executor", ] _types_map = { "http": {"type": list, "subtype": HTTPConfig}, "iot_analytics": {"type": list, "subtype": IoTAnalyticsConfig}, "kinesis": {"type": list, "subtype": KinesisConfig}, "iot_sitewise": {"type": list, "subtype": IoTSiteWiseConfig}, "s3_task_executor": {"type": list, "subtype": S3ExportTaskExecutorConfig}, } _formats_map = {} _validations_map = { "http": { "required": False, }, "iot_analytics": { "required": False, }, "kinesis": { "required": False, }, "iot_sitewise": { "required": False, }, "s3_task_executor": { "required": False, }, } def __init__( self, http: List[HTTPConfig] = None, iot_analytics: List[IoTAnalyticsConfig] = None, kinesis: List[KinesisConfig] = None, iot_sitewise: List[IoTSiteWiseConfig] = None, s3_task_executor: List[S3ExportTaskExecutorConfig] = None, ): """ :param http: Defines how the stream is uploaded to an HTTP endpoint. :param iot_analytics: Defines how the stream is uploaded to IoT Analytics. :param kinesis: Defines how the stream is uploaded to Kinesis. :param iot_sitewise: Defines how the stream is uploaded to IoT SiteWise. :param s3_task_executor: Defines the list of configs for S3 task executors. """ pass self.__http = http self.__iot_analytics = iot_analytics self.__kinesis = kinesis self.__iot_sitewise = iot_sitewise self.__s3_task_executor = s3_task_executor def _get_http(self): return self.__http def _set_http(self, value): if value is not None and not isinstance(value, list): raise TypeError("http must be list") if value is not None and not all(isinstance(i, HTTPConfig) for i in value): raise TypeError("http list values must be HTTPConfig") self.__http = value http = property(_get_http, _set_http) """ Defines how the stream is uploaded to an HTTP endpoint. """ def _get_iot_analytics(self): return self.__iot_analytics def _set_iot_analytics(self, value): if value is not None and not isinstance(value, list): raise TypeError("iot_analytics must be list") if value is not None and not all( isinstance(i, IoTAnalyticsConfig) for i in value ): raise TypeError("iot_analytics list values must be IoTAnalyticsConfig") self.__iot_analytics = value iot_analytics = property(_get_iot_analytics, _set_iot_analytics) """ Defines how the stream is uploaded to IoT Analytics. """ def _get_kinesis(self): return self.__kinesis def _set_kinesis(self, value): if value is not None and not isinstance(value, list): raise TypeError("kinesis must be list") if value is not None and not all(isinstance(i, KinesisConfig) for i in value): raise TypeError("kinesis list values must be KinesisConfig") self.__kinesis = value kinesis = property(_get_kinesis, _set_kinesis) """ Defines how the stream is uploaded to Kinesis. """ def _get_iot_sitewise(self): return self.__iot_sitewise def _set_iot_sitewise(self, value): if value is not None and not isinstance(value, list): raise TypeError("iot_sitewise must be list") if value is not None and not all( isinstance(i, IoTSiteWiseConfig) for i in value ): raise TypeError("iot_sitewise list values must be IoTSiteWiseConfig") self.__iot_sitewise = value iot_sitewise = property(_get_iot_sitewise, _set_iot_sitewise) """ Defines how the stream is uploaded to IoT SiteWise. """ def _get_s3_task_executor(self): return self.__s3_task_executor def _set_s3_task_executor(self, value): if value is not None and not isinstance(value, list): raise TypeError("s3_task_executor must be list") if value is not None and not all( isinstance(i, S3ExportTaskExecutorConfig) for i in value ): raise TypeError( "s3_task_executor list values must be S3ExportTaskExecutorConfig" ) self.__s3_task_executor = value s3_task_executor = property(_get_s3_task_executor, _set_s3_task_executor) """ Defines the list of configs for S3 task executors. """
[docs] @staticmethod def from_dict(d): v = {} if "http" in d: v["http"] = [ HTTPConfig.from_dict(p) if hasattr(HTTPConfig, "from_dict") else p for p in d["http"] ] if "iotAnalytics" in d: v["iot_analytics"] = [ IoTAnalyticsConfig.from_dict(p) if hasattr(IoTAnalyticsConfig, "from_dict") else p for p in d["iotAnalytics"] ] if "kinesis" in d: v["kinesis"] = [ KinesisConfig.from_dict(p) if hasattr(KinesisConfig, "from_dict") else p for p in d["kinesis"] ] if "IotSitewise" in d: v["iot_sitewise"] = [ IoTSiteWiseConfig.from_dict(p) if hasattr(IoTSiteWiseConfig, "from_dict") else p for p in d["IotSitewise"] ] if "s3TaskExecutor" in d: v["s3_task_executor"] = [ S3ExportTaskExecutorConfig.from_dict(p) if hasattr(S3ExportTaskExecutorConfig, "from_dict") else p for p in d["s3TaskExecutor"] ] return ExportDefinition(**v)
[docs] def as_dict(self): d = {} if self.__http is not None: d["http"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__http ] if self.__iot_analytics is not None: d["iotAnalytics"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__iot_analytics ] if self.__kinesis is not None: d["kinesis"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__kinesis ] if self.__iot_sitewise is not None: d["IotSitewise"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__iot_sitewise ] if self.__s3_task_executor is not None: d["s3TaskExecutor"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__s3_task_executor ] return d
def __repr__(self): return "<Class ExportDefinition. http: {}, iot_analytics: {}, kinesis: {}, iot_sitewise: {}, s3_task_executor: {}>".format( limitedRepr( self.__http[:20] if isinstance(self.__http, bytes) else self.__http ), limitedRepr( self.__iot_analytics[:20] if isinstance(self.__iot_analytics, bytes) else self.__iot_analytics ), limitedRepr( self.__kinesis[:20] if isinstance(self.__kinesis, bytes) else self.__kinesis ), limitedRepr( self.__iot_sitewise[:20] if isinstance(self.__iot_sitewise, bytes) else self.__iot_sitewise ), limitedRepr( self.__s3_task_executor[:20] if isinstance(self.__s3_task_executor, bytes) else self.__s3_task_executor ), )
[docs]class StrategyOnFull(enum.Enum): """ StrategyOnFull is used in the MessageStreamDefinition when creating a stream. It defines the behavior when the stream has reached the maximum size. RejectNewData: any append message request after the stream is full will be rejected with an exception. OverwriteOldestData: the oldest stream segments will be deleted until there is room for the new message. """ RejectNewData = 0 OverwriteOldestData = 1
[docs] @staticmethod def from_dict(d): return StrategyOnFull(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum StrategyOnFull. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class MessageStreamDefinition: """ Object defining a message stream used in the CreateMessageStream and UpdateMessageStream API. """ __slots__ = [ "__name", "__max_size", "__stream_segment_size", "__time_to_live_millis", "__strategy_on_full", "__persistence", "__flush_on_write", "__export_definition", ] _types_map = { "name": {"type": str, "subtype": None}, "max_size": {"type": int, "subtype": None}, "stream_segment_size": {"type": int, "subtype": None}, "time_to_live_millis": {"type": int, "subtype": None}, "strategy_on_full": {"type": StrategyOnFull, "subtype": None}, "persistence": {"type": Persistence, "subtype": None}, "flush_on_write": {"type": bool, "subtype": None}, "export_definition": {"type": ExportDefinition, "subtype": None}, } _formats_map = {} _validations_map = { "name": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, "max_size": { "required": False, "maximum": 9223372036854775807, "minimum": 1024, }, "stream_segment_size": { "required": False, "maximum": 2147483647, "minimum": 1024, }, "time_to_live_millis": { "required": False, "maximum": 9223372036854, "minimum": 60000, }, "strategy_on_full": { "required": True, }, "persistence": { "required": False, }, "flush_on_write": { "required": False, }, "export_definition": { "required": False, }, } def __init__( self, name: str = None, max_size: int = 268435456, stream_segment_size: int = 16777216, time_to_live_millis: int = None, strategy_on_full: StrategyOnFull = None, persistence: Persistence = None, flush_on_write: bool = None, export_definition: ExportDefinition = None, ): """ :param name: The unique name of the stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. :param max_size: The maximum size in bytes for the entire stream. Set to 256MB by default with a minimum of 1KB and a maximum of 8192PB. :param stream_segment_size: The size of each segment of the stream. Set to 16MB by default with a minimum of 1KB and a maximum of 2GB. Data is only deleted segment by segment, so the segment size is the smallest amount of data which can be deleted. :param time_to_live_millis: Time to live for each message in milliseconds. Data may be deleted at any time after the TTL expires; deletion is not guaranteed to occur immediately when the TTL expires. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. :param strategy_on_full: What to do when the maximum size of the stream is reached. RejectNewData: any append message request after the stream is full will be rejected with an exception. OverwriteOldestData: the oldest stream segments will be deleted until there is room for the new message. :param persistence: Stream persistence. If set to File, the file system will be used to persist messages long-term and is resilient to restarts. Memory should be used when performance matters more than durability as it only stores the stream in memory and never writes to the disk. :param flush_on_write: This only applies when Persistence is set to File mode. Waits for the filesystem to complete the write for every message. This is safer, but slower. Default is false. :param export_definition: Defines how and where the stream is uploaded. See the definition of the ExportDefinition object for more detail. """ pass self.__name = name self.__max_size = max_size self.__stream_segment_size = stream_segment_size self.__time_to_live_millis = time_to_live_millis self.__strategy_on_full = strategy_on_full self.__persistence = persistence self.__flush_on_write = flush_on_write self.__export_definition = export_definition def _get_name(self): return self.__name def _set_name(self, value): if not isinstance(value, str): raise TypeError("name must be str") self.__name = value name = property(_get_name, _set_name) """ The unique name of the stream. Must be an alphanumeric string including spaces, commas, periods, hyphens, and underscores with length between 1 and 255. """ def _get_max_size(self): return self.__max_size def _set_max_size(self, value): if value is not None and not isinstance(value, int): raise TypeError("max_size must be int") self.__max_size = value max_size = property(_get_max_size, _set_max_size) """ The maximum size in bytes for the entire stream. Set to 256MB by default with a minimum of 1KB and a maximum of 8192PB. """ def _get_stream_segment_size(self): return self.__stream_segment_size def _set_stream_segment_size(self, value): if value is not None and not isinstance(value, int): raise TypeError("stream_segment_size must be int") self.__stream_segment_size = value stream_segment_size = property(_get_stream_segment_size, _set_stream_segment_size) """ The size of each segment of the stream. Set to 16MB by default with a minimum of 1KB and a maximum of 2GB. Data is only deleted segment by segment, so the segment size is the smallest amount of data which can be deleted. """ def _get_time_to_live_millis(self): return self.__time_to_live_millis def _set_time_to_live_millis(self, value): if value is not None and not isinstance(value, int): raise TypeError("time_to_live_millis must be int") self.__time_to_live_millis = value time_to_live_millis = property(_get_time_to_live_millis, _set_time_to_live_millis) """ Time to live for each message in milliseconds. Data may be deleted at any time after the TTL expires; deletion is not guaranteed to occur immediately when the TTL expires. The minimum value is 60000 milliseconds and the maximum is 9223372036854 milliseconds. """ def _get_strategy_on_full(self): return self.__strategy_on_full def _set_strategy_on_full(self, value): if not isinstance(value, StrategyOnFull): raise TypeError("strategy_on_full must be StrategyOnFull") self.__strategy_on_full = value strategy_on_full = property(_get_strategy_on_full, _set_strategy_on_full) """ What to do when the maximum size of the stream is reached. RejectNewData: any append message request after the stream is full will be rejected with an exception. OverwriteOldestData: the oldest stream segments will be deleted until there is room for the new message. """ def _get_persistence(self): return self.__persistence def _set_persistence(self, value): if value is not None and not isinstance(value, Persistence): raise TypeError("persistence must be Persistence") self.__persistence = value persistence = property(_get_persistence, _set_persistence) """ Stream persistence. If set to File, the file system will be used to persist messages long-term and is resilient to restarts. Memory should be used when performance matters more than durability as it only stores the stream in memory and never writes to the disk. """ def _get_flush_on_write(self): return self.__flush_on_write def _set_flush_on_write(self, value): if value is not None and not isinstance(value, bool): raise TypeError("flush_on_write must be bool") self.__flush_on_write = value flush_on_write = property(_get_flush_on_write, _set_flush_on_write) """ This only applies when Persistence is set to File mode. Waits for the filesystem to complete the write for every message. This is safer, but slower. Default is false. """ def _get_export_definition(self): return self.__export_definition def _set_export_definition(self, value): if value is not None and not isinstance(value, ExportDefinition): raise TypeError("export_definition must be ExportDefinition") self.__export_definition = value export_definition = property(_get_export_definition, _set_export_definition) """ Defines how and where the stream is uploaded. See the definition of the ExportDefinition object for more detail. """
[docs] @staticmethod def from_dict(d): v = {} if "name" in d: v["name"] = ( str.from_dict(d["name"]) if hasattr(str, "from_dict") else d["name"] ) if "maxSize" in d: v["max_size"] = ( int.from_dict(d["maxSize"]) if hasattr(int, "from_dict") else d["maxSize"] ) if "streamSegmentSize" in d: v["stream_segment_size"] = ( int.from_dict(d["streamSegmentSize"]) if hasattr(int, "from_dict") else d["streamSegmentSize"] ) if "timeToLiveMillis" in d: v["time_to_live_millis"] = ( int.from_dict(d["timeToLiveMillis"]) if hasattr(int, "from_dict") else d["timeToLiveMillis"] ) if "strategyOnFull" in d: v["strategy_on_full"] = ( StrategyOnFull.from_dict(d["strategyOnFull"]) if hasattr(StrategyOnFull, "from_dict") else d["strategyOnFull"] ) if "persistence" in d: v["persistence"] = ( Persistence.from_dict(d["persistence"]) if hasattr(Persistence, "from_dict") else d["persistence"] ) if "flushOnWrite" in d: v["flush_on_write"] = ( bool.from_dict(d["flushOnWrite"]) if hasattr(bool, "from_dict") else d["flushOnWrite"] ) if "exportDefinition" in d: v["export_definition"] = ( ExportDefinition.from_dict(d["exportDefinition"]) if hasattr(ExportDefinition, "from_dict") else d["exportDefinition"] ) return MessageStreamDefinition(**v)
[docs] def as_dict(self): d = {} if self.__name is not None: d["name"] = ( self.__name.as_dict() if hasattr(self.__name, "as_dict") else self.__name ) if self.__max_size is not None: d["maxSize"] = ( self.__max_size.as_dict() if hasattr(self.__max_size, "as_dict") else self.__max_size ) if self.__stream_segment_size is not None: d["streamSegmentSize"] = ( self.__stream_segment_size.as_dict() if hasattr(self.__stream_segment_size, "as_dict") else self.__stream_segment_size ) if self.__time_to_live_millis is not None: d["timeToLiveMillis"] = ( self.__time_to_live_millis.as_dict() if hasattr(self.__time_to_live_millis, "as_dict") else self.__time_to_live_millis ) if self.__strategy_on_full is not None: d["strategyOnFull"] = ( self.__strategy_on_full.as_dict() if hasattr(self.__strategy_on_full, "as_dict") else self.__strategy_on_full ) if self.__persistence is not None: d["persistence"] = ( self.__persistence.as_dict() if hasattr(self.__persistence, "as_dict") else self.__persistence ) if self.__flush_on_write is not None: d["flushOnWrite"] = ( self.__flush_on_write.as_dict() if hasattr(self.__flush_on_write, "as_dict") else self.__flush_on_write ) if self.__export_definition is not None: d["exportDefinition"] = ( self.__export_definition.as_dict() if hasattr(self.__export_definition, "as_dict") else self.__export_definition ) return d
def __repr__(self): return "<Class MessageStreamDefinition. name: {}, max_size: {}, stream_segment_size: {}, time_to_live_millis: {}, strategy_on_full: {}, persistence: {}, flush_on_write: {}, export_definition: {}>".format( limitedRepr( self.__name[:20] if isinstance(self.__name, bytes) else self.__name ), limitedRepr( self.__max_size[:20] if isinstance(self.__max_size, bytes) else self.__max_size ), limitedRepr( self.__stream_segment_size[:20] if isinstance(self.__stream_segment_size, bytes) else self.__stream_segment_size ), limitedRepr( self.__time_to_live_millis[:20] if isinstance(self.__time_to_live_millis, bytes) else self.__time_to_live_millis ), limitedRepr( self.__strategy_on_full[:20] if isinstance(self.__strategy_on_full, bytes) else self.__strategy_on_full ), limitedRepr( self.__persistence[:20] if isinstance(self.__persistence, bytes) else self.__persistence ), limitedRepr( self.__flush_on_write[:20] if isinstance(self.__flush_on_write, bytes) else self.__flush_on_write ), limitedRepr( self.__export_definition[:20] if isinstance(self.__export_definition, bytes) else self.__export_definition ), )
[docs]class CreateMessageStreamRequest: """ (Internal Only) Request object for creating a message stream. """ __slots__ = [ "__request_id", "__definition", ] _types_map = { "request_id": {"type": str, "subtype": None}, "definition": {"type": MessageStreamDefinition, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "definition": { "required": True, }, } def __init__( self, request_id: str = None, definition: MessageStreamDefinition = None ): pass self.__request_id = request_id self.__definition = definition def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_definition(self): return self.__definition def _set_definition(self, value): if not isinstance(value, MessageStreamDefinition): raise TypeError("definition must be MessageStreamDefinition") self.__definition = value definition = property(_get_definition, _set_definition)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "definition" in d: v["definition"] = ( MessageStreamDefinition.from_dict(d["definition"]) if hasattr(MessageStreamDefinition, "from_dict") else d["definition"] ) return CreateMessageStreamRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__definition is not None: d["definition"] = ( self.__definition.as_dict() if hasattr(self.__definition, "as_dict") else self.__definition ) return d
def __repr__(self): return ( "<Class CreateMessageStreamRequest. request_id: {}, definition: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__definition[:20] if isinstance(self.__definition, bytes) else self.__definition ), ) )
[docs]class CreateMessageStreamResponse: """ Internal Only. """ __slots__ = [ "__request_id", "__status", "__error_message", ] _types_map = { "request_id": {"type": str, "subtype": None}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "status": { "required": True, }, "error_message": { "required": False, }, } def __init__( self, request_id: str = None, status: ResponseStatusCode = None, error_message: str = None, ): pass self.__request_id = request_id self.__status = status self.__error_message = error_message def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) return CreateMessageStreamResponse(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) return d
def __repr__(self): return "<Class CreateMessageStreamResponse. request_id: {}, status: {}, error_message: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), )
[docs]class UpdateMessageStreamRequest: """ (Internal Only) Request object for updating a message stream. """ __slots__ = [ "__request_id", "__definition", ] _types_map = { "request_id": {"type": str, "subtype": None}, "definition": {"type": MessageStreamDefinition, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "definition": { "required": True, }, } def __init__( self, request_id: str = None, definition: MessageStreamDefinition = None ): pass self.__request_id = request_id self.__definition = definition def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_definition(self): return self.__definition def _set_definition(self, value): if not isinstance(value, MessageStreamDefinition): raise TypeError("definition must be MessageStreamDefinition") self.__definition = value definition = property(_get_definition, _set_definition)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "definition" in d: v["definition"] = ( MessageStreamDefinition.from_dict(d["definition"]) if hasattr(MessageStreamDefinition, "from_dict") else d["definition"] ) return UpdateMessageStreamRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__definition is not None: d["definition"] = ( self.__definition.as_dict() if hasattr(self.__definition, "as_dict") else self.__definition ) return d
def __repr__(self): return ( "<Class UpdateMessageStreamRequest. request_id: {}, definition: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__definition[:20] if isinstance(self.__definition, bytes) else self.__definition ), ) )
[docs]class UpdateMessageStreamResponse: """ (Internal Only) Response for UpdateMessageStreamRequest. """ __slots__ = [ "__request_id", "__status", "__error_message", ] _types_map = { "request_id": {"type": str, "subtype": None}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "status": { "required": True, }, "error_message": { "required": False, }, } def __init__( self, request_id: str = None, status: ResponseStatusCode = None, error_message: str = None, ): pass self.__request_id = request_id self.__status = status self.__error_message = error_message def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) return UpdateMessageStreamResponse(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) return d
def __repr__(self): return "<Class UpdateMessageStreamResponse. request_id: {}, status: {}, error_message: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), )
[docs]class DeleteMessageStreamRequest: """ (Internal Only) Request object for deleting a message stream. """ __slots__ = [ "__request_id", "__name", ] _types_map = { "request_id": {"type": str, "subtype": None}, "name": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "name": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, } def __init__(self, request_id: str = None, name: str = None): pass self.__request_id = request_id self.__name = name def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_name(self): return self.__name def _set_name(self, value): if not isinstance(value, str): raise TypeError("name must be str") self.__name = value name = property(_get_name, _set_name)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "name" in d: v["name"] = ( str.from_dict(d["name"]) if hasattr(str, "from_dict") else d["name"] ) return DeleteMessageStreamRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__name is not None: d["name"] = ( self.__name.as_dict() if hasattr(self.__name, "as_dict") else self.__name ) return d
def __repr__(self): return "<Class DeleteMessageStreamRequest. request_id: {}, name: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__name[:20] if isinstance(self.__name, bytes) else self.__name ), )
[docs]class DeleteMessageStreamResponse: """ Internal Only. """ __slots__ = [ "__request_id", "__status", "__error_message", ] _types_map = { "request_id": {"type": str, "subtype": None}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "status": { "required": True, }, "error_message": { "required": False, }, } def __init__( self, request_id: str = None, status: ResponseStatusCode = None, error_message: str = None, ): pass self.__request_id = request_id self.__status = status self.__error_message = error_message def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) return DeleteMessageStreamResponse(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) return d
def __repr__(self): return "<Class DeleteMessageStreamResponse. request_id: {}, status: {}, error_message: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), )
[docs]class DescribeMessageStreamRequest: """ (Internal Only) Request object for describing a message stream. """ __slots__ = [ "__request_id", "__name", ] _types_map = { "request_id": {"type": str, "subtype": None}, "name": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "name": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, } def __init__(self, request_id: str = None, name: str = None): pass self.__request_id = request_id self.__name = name def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_name(self): return self.__name def _set_name(self, value): if not isinstance(value, str): raise TypeError("name must be str") self.__name = value name = property(_get_name, _set_name)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "name" in d: v["name"] = ( str.from_dict(d["name"]) if hasattr(str, "from_dict") else d["name"] ) return DescribeMessageStreamRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__name is not None: d["name"] = ( self.__name.as_dict() if hasattr(self.__name, "as_dict") else self.__name ) return d
def __repr__(self): return "<Class DescribeMessageStreamRequest. request_id: {}, name: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__name[:20] if isinstance(self.__name, bytes) else self.__name ), )
[docs]class MessageStreamInfo: """ Message stream information including its definition, storage status and export status. """
[docs] class storageStatus: """ Stream status including oldest/newest sequence number and total bytes. """ __slots__ = [ "__oldest_sequence_number", "__newest_sequence_number", "__total_bytes", ] _types_map = { "oldest_sequence_number": {"type": int, "subtype": None}, "newest_sequence_number": {"type": int, "subtype": None}, "total_bytes": {"type": int, "subtype": None}, } _formats_map = {} _validations_map = { "oldest_sequence_number": { "required": False, }, "newest_sequence_number": { "required": False, }, "total_bytes": { "required": False, }, } def __init__( self, oldest_sequence_number: int = None, newest_sequence_number: int = None, total_bytes: int = None, ): """ :param oldest_sequence_number: The sequence number of the first message which is still accessible in the stream. :param newest_sequence_number: The sequence number of the last appended message. :param total_bytes: The current total size of the stream in bytes. """ pass self.__oldest_sequence_number = oldest_sequence_number self.__newest_sequence_number = newest_sequence_number self.__total_bytes = total_bytes def _get_oldest_sequence_number(self): return self.__oldest_sequence_number def _set_oldest_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("oldest_sequence_number must be int") self.__oldest_sequence_number = value oldest_sequence_number = property( _get_oldest_sequence_number, _set_oldest_sequence_number ) """ The sequence number of the first message which is still accessible in the stream. """ def _get_newest_sequence_number(self): return self.__newest_sequence_number def _set_newest_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("newest_sequence_number must be int") self.__newest_sequence_number = value newest_sequence_number = property( _get_newest_sequence_number, _set_newest_sequence_number ) """ The sequence number of the last appended message. """ def _get_total_bytes(self): return self.__total_bytes def _set_total_bytes(self, value): if value is not None and not isinstance(value, int): raise TypeError("total_bytes must be int") self.__total_bytes = value total_bytes = property(_get_total_bytes, _set_total_bytes) """ The current total size of the stream in bytes. """
[docs] @staticmethod def from_dict(d): v = {} if "oldestSequenceNumber" in d: v["oldest_sequence_number"] = ( int.from_dict(d["oldestSequenceNumber"]) if hasattr(int, "from_dict") else d["oldestSequenceNumber"] ) if "newestSequenceNumber" in d: v["newest_sequence_number"] = ( int.from_dict(d["newestSequenceNumber"]) if hasattr(int, "from_dict") else d["newestSequenceNumber"] ) if "totalBytes" in d: v["total_bytes"] = ( int.from_dict(d["totalBytes"]) if hasattr(int, "from_dict") else d["totalBytes"] ) return MessageStreamInfo.storageStatus(**v)
[docs] def as_dict(self): d = {} if self.__oldest_sequence_number is not None: d["oldestSequenceNumber"] = ( self.__oldest_sequence_number.as_dict() if hasattr(self.__oldest_sequence_number, "as_dict") else self.__oldest_sequence_number ) if self.__newest_sequence_number is not None: d["newestSequenceNumber"] = ( self.__newest_sequence_number.as_dict() if hasattr(self.__newest_sequence_number, "as_dict") else self.__newest_sequence_number ) if self.__total_bytes is not None: d["totalBytes"] = ( self.__total_bytes.as_dict() if hasattr(self.__total_bytes, "as_dict") else self.__total_bytes ) return d
def __repr__(self): return "<Class storageStatus. oldest_sequence_number: {}, newest_sequence_number: {}, total_bytes: {}>".format( limitedRepr( self.__oldest_sequence_number[:20] if isinstance(self.__oldest_sequence_number, bytes) else self.__oldest_sequence_number ), limitedRepr( self.__newest_sequence_number[:20] if isinstance(self.__newest_sequence_number, bytes) else self.__newest_sequence_number ), limitedRepr( self.__total_bytes[:20] if isinstance(self.__total_bytes, bytes) else self.__total_bytes ), )
[docs] class exportStatuses: """ Export status including the export identifier and the last exported sequence number for that export task. """ __slots__ = [ "__export_config_identifier", "__last_exported_sequence_number", "__last_export_time", "__error_message", "__exported_bytes_from_stream", "__exported_messages_count", ] _types_map = { "export_config_identifier": {"type": str, "subtype": None}, "last_exported_sequence_number": {"type": int, "subtype": None}, "last_export_time": {"type": int, "subtype": None}, "error_message": {"type": str, "subtype": None}, "exported_bytes_from_stream": {"type": int, "subtype": None}, "exported_messages_count": {"type": int, "subtype": None}, } _formats_map = {} _validations_map = { "export_config_identifier": { "required": False, }, "last_exported_sequence_number": { "required": True, }, "last_export_time": { "required": False, }, "error_message": { "required": False, }, "exported_bytes_from_stream": { "required": False, }, "exported_messages_count": { "required": False, }, } def __init__( self, export_config_identifier: str = None, last_exported_sequence_number: int = None, last_export_time: int = None, error_message: str = None, exported_bytes_from_stream: int = None, exported_messages_count: int = None, ): """ :param export_config_identifier: The unique export identifier. :param last_exported_sequence_number: The sequence number of the last message which was successfully exported. :param last_export_time: The last time an export was attempted. Data is Unix epoch time in milliseconds. :param error_message: Error message from the last export attempt if it failed. :param exported_bytes_from_stream: Total bytes exported from the stream for this Export Config. It does not include the failed export attempts or messages which are skipped because of some non-retryable error. :param exported_messages_count: Total messages exported/processed. """ pass self.__export_config_identifier = export_config_identifier self.__last_exported_sequence_number = last_exported_sequence_number self.__last_export_time = last_export_time self.__error_message = error_message self.__exported_bytes_from_stream = exported_bytes_from_stream self.__exported_messages_count = exported_messages_count def _get_export_config_identifier(self): return self.__export_config_identifier def _set_export_config_identifier(self, value): if value is not None and not isinstance(value, str): raise TypeError("export_config_identifier must be str") self.__export_config_identifier = value export_config_identifier = property( _get_export_config_identifier, _set_export_config_identifier ) """ The unique export identifier. """ def _get_last_exported_sequence_number(self): return self.__last_exported_sequence_number def _set_last_exported_sequence_number(self, value): if not isinstance(value, int): raise TypeError("last_exported_sequence_number must be int") self.__last_exported_sequence_number = value last_exported_sequence_number = property( _get_last_exported_sequence_number, _set_last_exported_sequence_number ) """ The sequence number of the last message which was successfully exported. """ def _get_last_export_time(self): return self.__last_export_time def _set_last_export_time(self, value): if value is not None and not isinstance(value, int): raise TypeError("last_export_time must be int") self.__last_export_time = value last_export_time = property(_get_last_export_time, _set_last_export_time) """ The last time an export was attempted. Data is Unix epoch time in milliseconds. """ def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message) """ Error message from the last export attempt if it failed. """ def _get_exported_bytes_from_stream(self): return self.__exported_bytes_from_stream def _set_exported_bytes_from_stream(self, value): if value is not None and not isinstance(value, int): raise TypeError("exported_bytes_from_stream must be int") self.__exported_bytes_from_stream = value exported_bytes_from_stream = property( _get_exported_bytes_from_stream, _set_exported_bytes_from_stream ) """ Total bytes exported from the stream for this Export Config. It does not include the failed export attempts or messages which are skipped because of some non-retryable error. """ def _get_exported_messages_count(self): return self.__exported_messages_count def _set_exported_messages_count(self, value): if value is not None and not isinstance(value, int): raise TypeError("exported_messages_count must be int") self.__exported_messages_count = value exported_messages_count = property( _get_exported_messages_count, _set_exported_messages_count ) """ Total messages exported/processed. """
[docs] @staticmethod def from_dict(d): v = {} if "exportConfigIdentifier" in d: v["export_config_identifier"] = ( str.from_dict(d["exportConfigIdentifier"]) if hasattr(str, "from_dict") else d["exportConfigIdentifier"] ) if "lastExportedSequenceNumber" in d: v["last_exported_sequence_number"] = ( int.from_dict(d["lastExportedSequenceNumber"]) if hasattr(int, "from_dict") else d["lastExportedSequenceNumber"] ) if "lastExportTime" in d: v["last_export_time"] = ( int.from_dict(d["lastExportTime"]) if hasattr(int, "from_dict") else d["lastExportTime"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) if "exportedBytesFromStream" in d: v["exported_bytes_from_stream"] = ( int.from_dict(d["exportedBytesFromStream"]) if hasattr(int, "from_dict") else d["exportedBytesFromStream"] ) if "exportedMessagesCount" in d: v["exported_messages_count"] = ( int.from_dict(d["exportedMessagesCount"]) if hasattr(int, "from_dict") else d["exportedMessagesCount"] ) return MessageStreamInfo.exportStatuses(**v)
[docs] def as_dict(self): d = {} if self.__export_config_identifier is not None: d["exportConfigIdentifier"] = ( self.__export_config_identifier.as_dict() if hasattr(self.__export_config_identifier, "as_dict") else self.__export_config_identifier ) if self.__last_exported_sequence_number is not None: d["lastExportedSequenceNumber"] = ( self.__last_exported_sequence_number.as_dict() if hasattr(self.__last_exported_sequence_number, "as_dict") else self.__last_exported_sequence_number ) if self.__last_export_time is not None: d["lastExportTime"] = ( self.__last_export_time.as_dict() if hasattr(self.__last_export_time, "as_dict") else self.__last_export_time ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) if self.__exported_bytes_from_stream is not None: d["exportedBytesFromStream"] = ( self.__exported_bytes_from_stream.as_dict() if hasattr(self.__exported_bytes_from_stream, "as_dict") else self.__exported_bytes_from_stream ) if self.__exported_messages_count is not None: d["exportedMessagesCount"] = ( self.__exported_messages_count.as_dict() if hasattr(self.__exported_messages_count, "as_dict") else self.__exported_messages_count ) return d
def __repr__(self): return "<Class exportStatuses. export_config_identifier: {}, last_exported_sequence_number: {}, last_export_time: {}, error_message: {}, exported_bytes_from_stream: {}, exported_messages_count: {}>".format( limitedRepr( self.__export_config_identifier[:20] if isinstance(self.__export_config_identifier, bytes) else self.__export_config_identifier ), limitedRepr( self.__last_exported_sequence_number[:20] if isinstance(self.__last_exported_sequence_number, bytes) else self.__last_exported_sequence_number ), limitedRepr( self.__last_export_time[:20] if isinstance(self.__last_export_time, bytes) else self.__last_export_time ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), limitedRepr( self.__exported_bytes_from_stream[:20] if isinstance(self.__exported_bytes_from_stream, bytes) else self.__exported_bytes_from_stream ), limitedRepr( self.__exported_messages_count[:20] if isinstance(self.__exported_messages_count, bytes) else self.__exported_messages_count ), )
__slots__ = [ "__definition", "__storage_status", "__export_statuses", ] _types_map = { "definition": {"type": MessageStreamDefinition, "subtype": None}, "storage_status": {"type": storageStatus, "subtype": None}, "export_statuses": {"type": list, "subtype": exportStatuses}, } _formats_map = {} _validations_map = { "definition": { "required": True, }, "storage_status": { "required": True, }, "export_statuses": { "required": False, }, } def __init__( self, definition: MessageStreamDefinition = None, storage_status: storageStatus = None, export_statuses: List[exportStatuses] = None, ): """ :param storage_status: Stream status including oldest/newest sequence number and total bytes. """ pass self.__definition = definition self.__storage_status = storage_status self.__export_statuses = export_statuses def _get_definition(self): return self.__definition def _set_definition(self, value): if not isinstance(value, MessageStreamDefinition): raise TypeError("definition must be MessageStreamDefinition") self.__definition = value definition = property(_get_definition, _set_definition) def _get_storage_status(self): return self.__storage_status def _set_storage_status(self, value): if not isinstance(value, MessageStreamInfo.storageStatus): raise TypeError("storage_status must be MessageStreamInfo.storageStatus") self.__storage_status = value storage_status = property(_get_storage_status, _set_storage_status) """ Stream status including oldest/newest sequence number and total bytes. """ def _get_export_statuses(self): return self.__export_statuses def _set_export_statuses(self, value): if value is not None and not isinstance(value, list): raise TypeError("export_statuses must be list") if value is not None and not all( isinstance(i, MessageStreamInfo.exportStatuses) for i in value ): raise TypeError( "export_statuses list values must be MessageStreamInfo.exportStatuses" ) self.__export_statuses = value export_statuses = property(_get_export_statuses, _set_export_statuses)
[docs] @staticmethod def from_dict(d): v = {} if "definition" in d: v["definition"] = ( MessageStreamDefinition.from_dict(d["definition"]) if hasattr(MessageStreamDefinition, "from_dict") else d["definition"] ) if "storageStatus" in d: v["storage_status"] = ( MessageStreamInfo.storageStatus.from_dict(d["storageStatus"]) if hasattr(MessageStreamInfo.storageStatus, "from_dict") else d["storageStatus"] ) if "exportStatuses" in d: v["export_statuses"] = [ MessageStreamInfo.exportStatuses.from_dict(p) if hasattr(MessageStreamInfo.exportStatuses, "from_dict") else p for p in d["exportStatuses"] ] return MessageStreamInfo(**v)
[docs] def as_dict(self): d = {} if self.__definition is not None: d["definition"] = ( self.__definition.as_dict() if hasattr(self.__definition, "as_dict") else self.__definition ) if self.__storage_status is not None: d["storageStatus"] = ( self.__storage_status.as_dict() if hasattr(self.__storage_status, "as_dict") else self.__storage_status ) if self.__export_statuses is not None: d["exportStatuses"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__export_statuses ] return d
def __repr__(self): return "<Class MessageStreamInfo. definition: {}, storage_status: {}, export_statuses: {}>".format( limitedRepr( self.__definition[:20] if isinstance(self.__definition, bytes) else self.__definition ), limitedRepr( self.__storage_status[:20] if isinstance(self.__storage_status, bytes) else self.__storage_status ), limitedRepr( self.__export_statuses[:20] if isinstance(self.__export_statuses, bytes) else self.__export_statuses ), )
[docs]class DescribeMessageStreamResponse: """ (Internal Only) Response object for describing a message stream. """ __slots__ = [ "__request_id", "__status", "__error_message", "__message_stream_info", ] _types_map = { "request_id": {"type": str, "subtype": None}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, "message_stream_info": {"type": MessageStreamInfo, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "status": { "required": True, }, "error_message": { "required": False, }, "message_stream_info": { "required": False, }, } def __init__( self, request_id: str = None, status: ResponseStatusCode = None, error_message: str = None, message_stream_info: MessageStreamInfo = None, ): pass self.__request_id = request_id self.__status = status self.__error_message = error_message self.__message_stream_info = message_stream_info def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message) def _get_message_stream_info(self): return self.__message_stream_info def _set_message_stream_info(self, value): if value is not None and not isinstance(value, MessageStreamInfo): raise TypeError("message_stream_info must be MessageStreamInfo") self.__message_stream_info = value message_stream_info = property(_get_message_stream_info, _set_message_stream_info)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) if "messageStreamInfo" in d: v["message_stream_info"] = ( MessageStreamInfo.from_dict(d["messageStreamInfo"]) if hasattr(MessageStreamInfo, "from_dict") else d["messageStreamInfo"] ) return DescribeMessageStreamResponse(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) if self.__message_stream_info is not None: d["messageStreamInfo"] = ( self.__message_stream_info.as_dict() if hasattr(self.__message_stream_info, "as_dict") else self.__message_stream_info ) return d
def __repr__(self): return "<Class DescribeMessageStreamResponse. request_id: {}, status: {}, error_message: {}, message_stream_info: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), limitedRepr( self.__message_stream_info[:20] if isinstance(self.__message_stream_info, bytes) else self.__message_stream_info ), )
[docs]class AppendMessageRequest: """ (Internal Only) Request object for appending to a message stream. """ __slots__ = [ "__request_id", "__name", "__payload", ] _types_map = { "request_id": {"type": str, "subtype": None}, "name": {"type": str, "subtype": None}, "payload": {"type": bytes, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "name": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, "payload": { "required": True, "minLength": 1, }, } def __init__(self, request_id: str = None, name: str = None, payload: bytes = None): pass self.__request_id = request_id self.__name = name self.__payload = payload def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_name(self): return self.__name def _set_name(self, value): if not isinstance(value, str): raise TypeError("name must be str") self.__name = value name = property(_get_name, _set_name) def _get_payload(self): return self.__payload def _set_payload(self, value): if not isinstance(value, bytes): raise TypeError("payload must be bytes") self.__payload = value payload = property(_get_payload, _set_payload)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "name" in d: v["name"] = ( str.from_dict(d["name"]) if hasattr(str, "from_dict") else d["name"] ) if "payload" in d: v["payload"] = ( bytes.from_dict(d["payload"]) if hasattr(bytes, "from_dict") else d["payload"] ) return AppendMessageRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__name is not None: d["name"] = ( self.__name.as_dict() if hasattr(self.__name, "as_dict") else self.__name ) if self.__payload is not None: d["payload"] = ( self.__payload.as_dict() if hasattr(self.__payload, "as_dict") else self.__payload ) return d
def __repr__(self): return "<Class AppendMessageRequest. request_id: {}, name: {}, payload: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__name[:20] if isinstance(self.__name, bytes) else self.__name ), limitedRepr( self.__payload[:20] if isinstance(self.__payload, bytes) else self.__payload ), )
[docs]class AppendMessageResponse: """ Internal Only. """ __slots__ = [ "__request_id", "__status", "__error_message", "__sequence_number", ] _types_map = { "request_id": {"type": str, "subtype": None}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, "sequence_number": {"type": int, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "status": { "required": True, }, "error_message": { "required": False, }, "sequence_number": { "required": False, }, } def __init__( self, request_id: str = None, status: ResponseStatusCode = None, error_message: str = None, sequence_number: int = None, ): pass self.__request_id = request_id self.__status = status self.__error_message = error_message self.__sequence_number = sequence_number def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message) def _get_sequence_number(self): return self.__sequence_number def _set_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("sequence_number must be int") self.__sequence_number = value sequence_number = property(_get_sequence_number, _set_sequence_number)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) if "sequenceNumber" in d: v["sequence_number"] = ( int.from_dict(d["sequenceNumber"]) if hasattr(int, "from_dict") else d["sequenceNumber"] ) return AppendMessageResponse(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) if self.__sequence_number is not None: d["sequenceNumber"] = ( self.__sequence_number.as_dict() if hasattr(self.__sequence_number, "as_dict") else self.__sequence_number ) return d
def __repr__(self): return "<Class AppendMessageResponse. request_id: {}, status: {}, error_message: {}, sequence_number: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), limitedRepr( self.__sequence_number[:20] if isinstance(self.__sequence_number, bytes) else self.__sequence_number ), )
[docs]class ReadMessagesOptions: """ Options for the ReadMessages API. All fields are optional. """ __slots__ = [ "__desired_start_sequence_number", "__min_message_count", "__max_message_count", "__read_timeout_millis", ] _types_map = { "desired_start_sequence_number": {"type": int, "subtype": None}, "min_message_count": {"type": int, "subtype": None}, "max_message_count": {"type": int, "subtype": None}, "read_timeout_millis": {"type": int, "subtype": None}, } _formats_map = {} _validations_map = { "desired_start_sequence_number": { "required": False, "maximum": 9223372036854775807, "minimum": 0, }, "min_message_count": { "required": False, "maximum": 2147483647, "minimum": 1, }, "max_message_count": { "required": False, "maximum": 2147483647, "minimum": 1, }, "read_timeout_millis": { "required": False, "maximum": 9223372036854, "minimum": 0, }, } def __init__( self, desired_start_sequence_number: int = None, min_message_count: int = 1, max_message_count: int = None, read_timeout_millis: int = 0, ): """ :param desired_start_sequence_number: The desired beginning sequence number to start reading from. If the desired sequence number is less than the current minimum of the stream, then it will instead start reading from the current minimum. :param min_message_count: The minimum number of messages that will be returned. If not enough messages are available for reading, then NotEnoughMessages exception will be thrown. The minimum values is 1 and the maximum value is 2147483647. :param max_message_count: The maximum number of messages that will be returned. The minimum values is the value of the minimum message count and the maximum value is 2147483647. :param read_timeout_millis: The time to wait for messages in milliseconds. Default is 0, meaning that the server will not wait for messages. If it can fulfill the minimum messages it will return them, but otherwise NotEnoughMessages exception will be thrown. If the timeout is greater than zero, then the server will wait up to that time for more messages to be appended to the stream, waiting until the minimum number of messages is reached. The maximum value is the value of the client timeout. """ pass self.__desired_start_sequence_number = desired_start_sequence_number self.__min_message_count = min_message_count self.__max_message_count = max_message_count self.__read_timeout_millis = read_timeout_millis def _get_desired_start_sequence_number(self): return self.__desired_start_sequence_number def _set_desired_start_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("desired_start_sequence_number must be int") self.__desired_start_sequence_number = value desired_start_sequence_number = property( _get_desired_start_sequence_number, _set_desired_start_sequence_number ) """ The desired beginning sequence number to start reading from. If the desired sequence number is less than the current minimum of the stream, then it will instead start reading from the current minimum. """ def _get_min_message_count(self): return self.__min_message_count def _set_min_message_count(self, value): if value is not None and not isinstance(value, int): raise TypeError("min_message_count must be int") self.__min_message_count = value min_message_count = property(_get_min_message_count, _set_min_message_count) """ The minimum number of messages that will be returned. If not enough messages are available for reading, then NotEnoughMessages exception will be thrown. The minimum values is 1 and the maximum value is 2147483647. """ def _get_max_message_count(self): return self.__max_message_count def _set_max_message_count(self, value): if value is not None and not isinstance(value, int): raise TypeError("max_message_count must be int") self.__max_message_count = value max_message_count = property(_get_max_message_count, _set_max_message_count) """ The maximum number of messages that will be returned. The minimum values is the value of the minimum message count and the maximum value is 2147483647. """ def _get_read_timeout_millis(self): return self.__read_timeout_millis def _set_read_timeout_millis(self, value): if value is not None and not isinstance(value, int): raise TypeError("read_timeout_millis must be int") self.__read_timeout_millis = value read_timeout_millis = property(_get_read_timeout_millis, _set_read_timeout_millis) """ The time to wait for messages in milliseconds. Default is 0, meaning that the server will not wait for messages. If it can fulfill the minimum messages it will return them, but otherwise NotEnoughMessages exception will be thrown. If the timeout is greater than zero, then the server will wait up to that time for more messages to be appended to the stream, waiting until the minimum number of messages is reached. The maximum value is the value of the client timeout. """
[docs] @staticmethod def from_dict(d): v = {} if "desiredStartSequenceNumber" in d: v["desired_start_sequence_number"] = ( int.from_dict(d["desiredStartSequenceNumber"]) if hasattr(int, "from_dict") else d["desiredStartSequenceNumber"] ) if "minMessageCount" in d: v["min_message_count"] = ( int.from_dict(d["minMessageCount"]) if hasattr(int, "from_dict") else d["minMessageCount"] ) if "maxMessageCount" in d: v["max_message_count"] = ( int.from_dict(d["maxMessageCount"]) if hasattr(int, "from_dict") else d["maxMessageCount"] ) if "readTimeoutMillis" in d: v["read_timeout_millis"] = ( int.from_dict(d["readTimeoutMillis"]) if hasattr(int, "from_dict") else d["readTimeoutMillis"] ) return ReadMessagesOptions(**v)
[docs] def as_dict(self): d = {} if self.__desired_start_sequence_number is not None: d["desiredStartSequenceNumber"] = ( self.__desired_start_sequence_number.as_dict() if hasattr(self.__desired_start_sequence_number, "as_dict") else self.__desired_start_sequence_number ) if self.__min_message_count is not None: d["minMessageCount"] = ( self.__min_message_count.as_dict() if hasattr(self.__min_message_count, "as_dict") else self.__min_message_count ) if self.__max_message_count is not None: d["maxMessageCount"] = ( self.__max_message_count.as_dict() if hasattr(self.__max_message_count, "as_dict") else self.__max_message_count ) if self.__read_timeout_millis is not None: d["readTimeoutMillis"] = ( self.__read_timeout_millis.as_dict() if hasattr(self.__read_timeout_millis, "as_dict") else self.__read_timeout_millis ) return d
def __repr__(self): return "<Class ReadMessagesOptions. desired_start_sequence_number: {}, min_message_count: {}, max_message_count: {}, read_timeout_millis: {}>".format( limitedRepr( self.__desired_start_sequence_number[:20] if isinstance(self.__desired_start_sequence_number, bytes) else self.__desired_start_sequence_number ), limitedRepr( self.__min_message_count[:20] if isinstance(self.__min_message_count, bytes) else self.__min_message_count ), limitedRepr( self.__max_message_count[:20] if isinstance(self.__max_message_count, bytes) else self.__max_message_count ), limitedRepr( self.__read_timeout_millis[:20] if isinstance(self.__read_timeout_millis, bytes) else self.__read_timeout_millis ), )
[docs]class ReadMessagesRequest: """ (Internal Only) Request object for reading from a message stream. readMessagesOptions is optional. """ __slots__ = [ "__request_id", "__stream_name", "__read_messages_options", ] _types_map = { "request_id": {"type": str, "subtype": None}, "stream_name": {"type": str, "subtype": None}, "read_messages_options": {"type": ReadMessagesOptions, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "stream_name": { "required": True, "minLength": 1, "maxLength": 255, "pattern": "^[\w ,.\-_]*$", }, "read_messages_options": { "required": False, }, } def __init__( self, request_id: str = None, stream_name: str = None, read_messages_options: ReadMessagesOptions = None, ): pass self.__request_id = request_id self.__stream_name = stream_name self.__read_messages_options = read_messages_options def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_stream_name(self): return self.__stream_name def _set_stream_name(self, value): if not isinstance(value, str): raise TypeError("stream_name must be str") self.__stream_name = value stream_name = property(_get_stream_name, _set_stream_name) def _get_read_messages_options(self): return self.__read_messages_options def _set_read_messages_options(self, value): if value is not None and not isinstance(value, ReadMessagesOptions): raise TypeError("read_messages_options must be ReadMessagesOptions") self.__read_messages_options = value read_messages_options = property( _get_read_messages_options, _set_read_messages_options )
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "streamName" in d: v["stream_name"] = ( str.from_dict(d["streamName"]) if hasattr(str, "from_dict") else d["streamName"] ) if "readMessagesOptions" in d: v["read_messages_options"] = ( ReadMessagesOptions.from_dict(d["readMessagesOptions"]) if hasattr(ReadMessagesOptions, "from_dict") else d["readMessagesOptions"] ) return ReadMessagesRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__stream_name is not None: d["streamName"] = ( self.__stream_name.as_dict() if hasattr(self.__stream_name, "as_dict") else self.__stream_name ) if self.__read_messages_options is not None: d["readMessagesOptions"] = ( self.__read_messages_options.as_dict() if hasattr(self.__read_messages_options, "as_dict") else self.__read_messages_options ) return d
def __repr__(self): return "<Class ReadMessagesRequest. request_id: {}, stream_name: {}, read_messages_options: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__stream_name[:20] if isinstance(self.__stream_name, bytes) else self.__stream_name ), limitedRepr( self.__read_messages_options[:20] if isinstance(self.__read_messages_options, bytes) else self.__read_messages_options ), )
[docs]class Message: """ Message object containing metadata and the user's payload. """ __slots__ = [ "__stream_name", "__sequence_number", "__ingest_time", "__payload", ] _types_map = { "stream_name": {"type": str, "subtype": None}, "sequence_number": {"type": int, "subtype": None}, "ingest_time": {"type": int, "subtype": None}, "payload": {"type": bytes, "subtype": None}, } _formats_map = {} _validations_map = { "stream_name": { "required": True, }, "sequence_number": { "required": False, }, "ingest_time": { "required": False, }, "payload": { "required": True, }, } def __init__( self, stream_name: str = None, sequence_number: int = None, ingest_time: int = None, payload: bytes = None, ): """ :param stream_name: The name of the stream which this message is in. :param sequence_number: The sequence number of this message within the stream. :param ingest_time: The time that the message was ingested to Stream Manager. Data is Unix epoch time in milliseconds. :param payload: The binary message data. """ pass self.__stream_name = stream_name self.__sequence_number = sequence_number self.__ingest_time = ingest_time self.__payload = payload def _get_stream_name(self): return self.__stream_name def _set_stream_name(self, value): if not isinstance(value, str): raise TypeError("stream_name must be str") self.__stream_name = value stream_name = property(_get_stream_name, _set_stream_name) """ The name of the stream which this message is in. """ def _get_sequence_number(self): return self.__sequence_number def _set_sequence_number(self, value): if value is not None and not isinstance(value, int): raise TypeError("sequence_number must be int") self.__sequence_number = value sequence_number = property(_get_sequence_number, _set_sequence_number) """ The sequence number of this message within the stream. """ def _get_ingest_time(self): return self.__ingest_time def _set_ingest_time(self, value): if value is not None and not isinstance(value, int): raise TypeError("ingest_time must be int") self.__ingest_time = value ingest_time = property(_get_ingest_time, _set_ingest_time) """ The time that the message was ingested to Stream Manager. Data is Unix epoch time in milliseconds. """ def _get_payload(self): return self.__payload def _set_payload(self, value): if not isinstance(value, bytes): raise TypeError("payload must be bytes") self.__payload = value payload = property(_get_payload, _set_payload) """ The binary message data. """
[docs] @staticmethod def from_dict(d): v = {} if "streamName" in d: v["stream_name"] = ( str.from_dict(d["streamName"]) if hasattr(str, "from_dict") else d["streamName"] ) if "sequenceNumber" in d: v["sequence_number"] = ( int.from_dict(d["sequenceNumber"]) if hasattr(int, "from_dict") else d["sequenceNumber"] ) if "ingestTime" in d: v["ingest_time"] = ( int.from_dict(d["ingestTime"]) if hasattr(int, "from_dict") else d["ingestTime"] ) if "payload" in d: v["payload"] = ( bytes.from_dict(d["payload"]) if hasattr(bytes, "from_dict") else d["payload"] ) return Message(**v)
[docs] def as_dict(self): d = {} if self.__stream_name is not None: d["streamName"] = ( self.__stream_name.as_dict() if hasattr(self.__stream_name, "as_dict") else self.__stream_name ) if self.__sequence_number is not None: d["sequenceNumber"] = ( self.__sequence_number.as_dict() if hasattr(self.__sequence_number, "as_dict") else self.__sequence_number ) if self.__ingest_time is not None: d["ingestTime"] = ( self.__ingest_time.as_dict() if hasattr(self.__ingest_time, "as_dict") else self.__ingest_time ) if self.__payload is not None: d["payload"] = ( self.__payload.as_dict() if hasattr(self.__payload, "as_dict") else self.__payload ) return d
def __repr__(self): return "<Class Message. stream_name: {}, sequence_number: {}, ingest_time: {}, payload: {}>".format( limitedRepr( self.__stream_name[:20] if isinstance(self.__stream_name, bytes) else self.__stream_name ), limitedRepr( self.__sequence_number[:20] if isinstance(self.__sequence_number, bytes) else self.__sequence_number ), limitedRepr( self.__ingest_time[:20] if isinstance(self.__ingest_time, bytes) else self.__ingest_time ), limitedRepr( self.__payload[:20] if isinstance(self.__payload, bytes) else self.__payload ), )
[docs]class ReadMessagesResponse: """ Internal Only. """ __slots__ = [ "__request_id", "__messages", "__status", "__error_message", ] _types_map = { "request_id": {"type": str, "subtype": None}, "messages": {"type": list, "subtype": Message}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": False, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "messages": { "required": False, }, "status": { "required": False, }, "error_message": { "required": False, }, } def __init__( self, request_id: str = None, messages: List[Message] = None, status: ResponseStatusCode = None, error_message: str = None, ): pass self.__request_id = request_id self.__messages = messages self.__status = status self.__error_message = error_message def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if value is not None and not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_messages(self): return self.__messages def _set_messages(self, value): if value is not None and not isinstance(value, list): raise TypeError("messages must be list") if value is not None and not all(isinstance(i, Message) for i in value): raise TypeError("messages list values must be Message") self.__messages = value messages = property(_get_messages, _set_messages) def _get_status(self): return self.__status def _set_status(self, value): if value is not None and not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "messages" in d: v["messages"] = [ Message.from_dict(p) if hasattr(Message, "from_dict") else p for p in d["messages"] ] if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) return ReadMessagesResponse(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__messages is not None: d["messages"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__messages ] if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) return d
def __repr__(self): return "<Class ReadMessagesResponse. request_id: {}, messages: {}, status: {}, error_message: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__messages[:20] if isinstance(self.__messages, bytes) else self.__messages ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), )
[docs]class ListStreamsRequest: """ (Internal Only) Request object to list all available streams. There are no options. """ __slots__ = [ "__request_id", ] _types_map = { "request_id": {"type": str, "subtype": None}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, } def __init__(self, request_id: str = None): pass self.__request_id = request_id def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) return ListStreamsRequest(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) return d
def __repr__(self): return "<Class ListStreamsRequest. request_id: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ) )
[docs]class ListStreamsResponse: """ Internal Only. """ __slots__ = [ "__request_id", "__status", "__error_message", "__streams", ] _types_map = { "request_id": {"type": str, "subtype": None}, "status": {"type": ResponseStatusCode, "subtype": None}, "error_message": {"type": str, "subtype": None}, "streams": {"type": list, "subtype": str}, } _formats_map = {} _validations_map = { "request_id": { "required": True, "minLength": 1, "pattern": "^[\w ,.\-_]*$", }, "status": { "required": True, }, "error_message": { "required": False, }, "streams": { "required": False, }, } def __init__( self, request_id: str = None, status: ResponseStatusCode = None, error_message: str = None, streams: List[str] = None, ): pass self.__request_id = request_id self.__status = status self.__error_message = error_message self.__streams = streams def _get_request_id(self): return self.__request_id def _set_request_id(self, value): if not isinstance(value, str): raise TypeError("request_id must be str") self.__request_id = value request_id = property(_get_request_id, _set_request_id) def _get_status(self): return self.__status def _set_status(self, value): if not isinstance(value, ResponseStatusCode): raise TypeError("status must be ResponseStatusCode") self.__status = value status = property(_get_status, _set_status) def _get_error_message(self): return self.__error_message def _set_error_message(self, value): if value is not None and not isinstance(value, str): raise TypeError("error_message must be str") self.__error_message = value error_message = property(_get_error_message, _set_error_message) def _get_streams(self): return self.__streams def _set_streams(self, value): if value is not None and not isinstance(value, list): raise TypeError("streams must be list") if value is not None and not all(isinstance(i, str) for i in value): raise TypeError("streams list values must be str") self.__streams = value streams = property(_get_streams, _set_streams)
[docs] @staticmethod def from_dict(d): v = {} if "requestId" in d: v["request_id"] = ( str.from_dict(d["requestId"]) if hasattr(str, "from_dict") else d["requestId"] ) if "status" in d: v["status"] = ( ResponseStatusCode.from_dict(d["status"]) if hasattr(ResponseStatusCode, "from_dict") else d["status"] ) if "errorMessage" in d: v["error_message"] = ( str.from_dict(d["errorMessage"]) if hasattr(str, "from_dict") else d["errorMessage"] ) if "streams" in d: v["streams"] = [ str.from_dict(p) if hasattr(str, "from_dict") else p for p in d["streams"] ] return ListStreamsResponse(**v)
[docs] def as_dict(self): d = {} if self.__request_id is not None: d["requestId"] = ( self.__request_id.as_dict() if hasattr(self.__request_id, "as_dict") else self.__request_id ) if self.__status is not None: d["status"] = ( self.__status.as_dict() if hasattr(self.__status, "as_dict") else self.__status ) if self.__error_message is not None: d["errorMessage"] = ( self.__error_message.as_dict() if hasattr(self.__error_message, "as_dict") else self.__error_message ) if self.__streams is not None: d["streams"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__streams ] return d
def __repr__(self): return "<Class ListStreamsResponse. request_id: {}, status: {}, error_message: {}, streams: {}>".format( limitedRepr( self.__request_id[:20] if isinstance(self.__request_id, bytes) else self.__request_id ), limitedRepr( self.__status[:20] if isinstance(self.__status, bytes) else self.__status ), limitedRepr( self.__error_message[:20] if isinstance(self.__error_message, bytes) else self.__error_message ), limitedRepr( self.__streams[:20] if isinstance(self.__streams, bytes) else self.__streams ), )
[docs]class TimeInNanos: """ Contains a timestamp with optional nanosecond granularity. """ __slots__ = [ "__time_in_seconds", "__offset_in_nanos", ] _types_map = { "time_in_seconds": {"type": int, "subtype": None}, "offset_in_nanos": {"type": int, "subtype": None}, } _formats_map = {} _validations_map = { "time_in_seconds": { "required": True, "maximum": 31556889864403199, "minimum": 1, }, "offset_in_nanos": { "required": False, "maximum": 999999999, "minimum": 0, }, } def __init__(self, time_in_seconds: int = None, offset_in_nanos: int = None): """ :param time_in_seconds: The timestamp date, in seconds, in the Unix epoch format. Fractional nanosecond data is provided by offsetInNanos. :param offset_in_nanos: The nanosecond offset from timeInSeconds. """ pass self.__time_in_seconds = time_in_seconds self.__offset_in_nanos = offset_in_nanos def _get_time_in_seconds(self): return self.__time_in_seconds def _set_time_in_seconds(self, value): if not isinstance(value, int): raise TypeError("time_in_seconds must be int") self.__time_in_seconds = value time_in_seconds = property(_get_time_in_seconds, _set_time_in_seconds) """ The timestamp date, in seconds, in the Unix epoch format. Fractional nanosecond data is provided by offsetInNanos. """ def _get_offset_in_nanos(self): return self.__offset_in_nanos def _set_offset_in_nanos(self, value): if value is not None and not isinstance(value, int): raise TypeError("offset_in_nanos must be int") self.__offset_in_nanos = value offset_in_nanos = property(_get_offset_in_nanos, _set_offset_in_nanos) """ The nanosecond offset from timeInSeconds. """
[docs] @staticmethod def from_dict(d): v = {} if "timeInSeconds" in d: v["time_in_seconds"] = ( int.from_dict(d["timeInSeconds"]) if hasattr(int, "from_dict") else d["timeInSeconds"] ) if "offsetInNanos" in d: v["offset_in_nanos"] = ( int.from_dict(d["offsetInNanos"]) if hasattr(int, "from_dict") else d["offsetInNanos"] ) return TimeInNanos(**v)
[docs] def as_dict(self): d = {} if self.__time_in_seconds is not None: d["timeInSeconds"] = ( self.__time_in_seconds.as_dict() if hasattr(self.__time_in_seconds, "as_dict") else self.__time_in_seconds ) if self.__offset_in_nanos is not None: d["offsetInNanos"] = ( self.__offset_in_nanos.as_dict() if hasattr(self.__offset_in_nanos, "as_dict") else self.__offset_in_nanos ) return d
def __repr__(self): return "<Class TimeInNanos. time_in_seconds: {}, offset_in_nanos: {}>".format( limitedRepr( self.__time_in_seconds[:20] if isinstance(self.__time_in_seconds, bytes) else self.__time_in_seconds ), limitedRepr( self.__offset_in_nanos[:20] if isinstance(self.__offset_in_nanos, bytes) else self.__offset_in_nanos ), )
[docs]class Quality(enum.Enum): GOOD = "GOOD" BAD = "BAD" UNCERTAIN = "UNCERTAIN"
[docs] @staticmethod def from_dict(d): return Quality(d)
[docs] def as_dict(self): return self.value
def __repr__(self): return "<Enum Quality. {}: {}>".format( limitedRepr(self.name), limitedRepr(self.value) )
[docs]class Variant: """ Contains an asset property value (of a single type only). """ __slots__ = [ "__string_value", "__integer_value", "__double_value", "__boolean_value", ] _types_map = { "string_value": {"type": str, "subtype": None}, "integer_value": {"type": int, "subtype": None}, "double_value": {"type": float, "subtype": None}, "boolean_value": {"type": bool, "subtype": None}, } _formats_map = {} _validations_map = { "string_value": { "required": False, "minLength": 1, "maxLength": 1024, "pattern": "[^\u0000-\u001F\u007F]+", }, "integer_value": { "required": False, "maximum": 2147483647, "minimum": 0, }, "double_value": { "required": False, }, "boolean_value": { "required": False, }, } def __init__( self, string_value: str = None, integer_value: int = None, double_value: float = None, boolean_value: bool = None, ): """ :param string_value: Asset property data of type string (sequence of characters). :param integer_value: Asset property data of type integer (whole number). :param double_value: Asset property data of type double (floating point number). :param boolean_value: Asset property data of type Boolean (true or false). """ pass self.__string_value = string_value self.__integer_value = integer_value self.__double_value = double_value self.__boolean_value = boolean_value def _get_string_value(self): return self.__string_value def _set_string_value(self, value): if value is not None and not isinstance(value, str): raise TypeError("string_value must be str") self.__string_value = value string_value = property(_get_string_value, _set_string_value) """ Asset property data of type string (sequence of characters). """ def _get_integer_value(self): return self.__integer_value def _set_integer_value(self, value): if value is not None and not isinstance(value, int): raise TypeError("integer_value must be int") self.__integer_value = value integer_value = property(_get_integer_value, _set_integer_value) """ Asset property data of type integer (whole number). """ def _get_double_value(self): return self.__double_value def _set_double_value(self, value): if value is not None and not isinstance(value, float): raise TypeError("double_value must be float") self.__double_value = value double_value = property(_get_double_value, _set_double_value) """ Asset property data of type double (floating point number). """ def _get_boolean_value(self): return self.__boolean_value def _set_boolean_value(self, value): if value is not None and not isinstance(value, bool): raise TypeError("boolean_value must be bool") self.__boolean_value = value boolean_value = property(_get_boolean_value, _set_boolean_value) """ Asset property data of type Boolean (true or false). """
[docs] @staticmethod def from_dict(d): v = {} if "stringValue" in d: v["string_value"] = ( str.from_dict(d["stringValue"]) if hasattr(str, "from_dict") else d["stringValue"] ) if "integerValue" in d: v["integer_value"] = ( int.from_dict(d["integerValue"]) if hasattr(int, "from_dict") else d["integerValue"] ) if "doubleValue" in d: v["double_value"] = ( float.from_dict(d["doubleValue"]) if hasattr(float, "from_dict") else d["doubleValue"] ) if "booleanValue" in d: v["boolean_value"] = ( bool.from_dict(d["booleanValue"]) if hasattr(bool, "from_dict") else d["booleanValue"] ) return Variant(**v)
[docs] def as_dict(self): d = {} if self.__string_value is not None: d["stringValue"] = ( self.__string_value.as_dict() if hasattr(self.__string_value, "as_dict") else self.__string_value ) if self.__integer_value is not None: d["integerValue"] = ( self.__integer_value.as_dict() if hasattr(self.__integer_value, "as_dict") else self.__integer_value ) if self.__double_value is not None: d["doubleValue"] = ( self.__double_value.as_dict() if hasattr(self.__double_value, "as_dict") else self.__double_value ) if self.__boolean_value is not None: d["booleanValue"] = ( self.__boolean_value.as_dict() if hasattr(self.__boolean_value, "as_dict") else self.__boolean_value ) return d
def __repr__(self): return "<Class Variant. string_value: {}, integer_value: {}, double_value: {}, boolean_value: {}>".format( limitedRepr( self.__string_value[:20] if isinstance(self.__string_value, bytes) else self.__string_value ), limitedRepr( self.__integer_value[:20] if isinstance(self.__integer_value, bytes) else self.__integer_value ), limitedRepr( self.__double_value[:20] if isinstance(self.__double_value, bytes) else self.__double_value ), limitedRepr( self.__boolean_value[:20] if isinstance(self.__boolean_value, bytes) else self.__boolean_value ), )
[docs]class AssetPropertyValue: """ Contains asset property value information. """ __slots__ = [ "__value", "__timestamp", "__quality", ] _types_map = { "value": {"type": Variant, "subtype": None}, "timestamp": {"type": TimeInNanos, "subtype": None}, "quality": {"type": Quality, "subtype": None}, } _formats_map = {} _validations_map = { "value": { "required": True, }, "timestamp": { "required": True, }, "quality": { "required": False, }, } def __init__( self, value: Variant = None, timestamp: TimeInNanos = None, quality: Quality = None, ): """ :param value: The value of the asset property. :param timestamp: The timestamp of the asset property value. :param quality: The quality of the asset property value. """ pass self.__value = value self.__timestamp = timestamp self.__quality = quality def _get_value(self): return self.__value def _set_value(self, value): if not isinstance(value, Variant): raise TypeError("value must be Variant") self.__value = value value = property(_get_value, _set_value) """ The value of the asset property. """ def _get_timestamp(self): return self.__timestamp def _set_timestamp(self, value): if not isinstance(value, TimeInNanos): raise TypeError("timestamp must be TimeInNanos") self.__timestamp = value timestamp = property(_get_timestamp, _set_timestamp) """ The timestamp of the asset property value. """ def _get_quality(self): return self.__quality def _set_quality(self, value): if value is not None and not isinstance(value, Quality): raise TypeError("quality must be Quality") self.__quality = value quality = property(_get_quality, _set_quality) """ The quality of the asset property value. """
[docs] @staticmethod def from_dict(d): v = {} if "value" in d: v["value"] = ( Variant.from_dict(d["value"]) if hasattr(Variant, "from_dict") else d["value"] ) if "timestamp" in d: v["timestamp"] = ( TimeInNanos.from_dict(d["timestamp"]) if hasattr(TimeInNanos, "from_dict") else d["timestamp"] ) if "quality" in d: v["quality"] = ( Quality.from_dict(d["quality"]) if hasattr(Quality, "from_dict") else d["quality"] ) return AssetPropertyValue(**v)
[docs] def as_dict(self): d = {} if self.__value is not None: d["value"] = ( self.__value.as_dict() if hasattr(self.__value, "as_dict") else self.__value ) if self.__timestamp is not None: d["timestamp"] = ( self.__timestamp.as_dict() if hasattr(self.__timestamp, "as_dict") else self.__timestamp ) if self.__quality is not None: d["quality"] = ( self.__quality.as_dict() if hasattr(self.__quality, "as_dict") else self.__quality ) return d
def __repr__(self): return ( "<Class AssetPropertyValue. value: {}, timestamp: {}, quality: {}>".format( limitedRepr( self.__value[:20] if isinstance(self.__value, bytes) else self.__value ), limitedRepr( self.__timestamp[:20] if isinstance(self.__timestamp, bytes) else self.__timestamp ), limitedRepr( self.__quality[:20] if isinstance(self.__quality, bytes) else self.__quality ), ) )
[docs]class PutAssetPropertyValueEntry: """ Contains a list of value updates for a IoTSiteWise asset property in the list of asset entries consumed by the BatchPutAssetPropertyValue API. See https://docs.aws.amazon.com/iot-sitewise/latest/APIReference/API_BatchPutAssetPropertyValue.html. """ __slots__ = [ "__entry_id", "__asset_id", "__property_id", "__property_alias", "__property_values", ] _types_map = { "entry_id": {"type": str, "subtype": None}, "asset_id": {"type": str, "subtype": None}, "property_id": {"type": str, "subtype": None}, "property_alias": {"type": str, "subtype": None}, "property_values": {"type": list, "subtype": AssetPropertyValue}, } _formats_map = {} _validations_map = { "entry_id": { "required": True, "minLength": 1, "maxLength": 64, "pattern": "^[a-zA-Z0-9_-]+$", }, "asset_id": { "required": False, }, "property_id": { "required": False, }, "property_alias": { "required": False, "minLength": 1, "maxLength": 2048, "pattern": "[^\u0000-\u001F\u007F]+", }, "property_values": { "required": True, "maxItems": 10, "minItems": 1, }, } def __init__( self, entry_id: str = None, asset_id: str = None, property_id: str = None, property_alias: str = None, property_values: List[AssetPropertyValue] = None, ): """ :param entry_id: The user specified ID for the entry. You can use this ID to identify which entries failed. :param asset_id: The ID of the asset to update. :param property_id: The ID of the asset property for this entry. :param property_alias: The property alias that identifies the property, such as an OPC-UA server data stream path (for example, /company/windfarm/3/turbine/7/temperature). For more information, see https://docs.aws.amazon.com/iot-sitewise/latest/userguide/connect-data-streams.html. :param property_values: The list of property values to upload. You can specify up to 10 values. """ pass self.__entry_id = entry_id self.__asset_id = asset_id self.__property_id = property_id self.__property_alias = property_alias self.__property_values = property_values def _get_entry_id(self): return self.__entry_id def _set_entry_id(self, value): if not isinstance(value, str): raise TypeError("entry_id must be str") self.__entry_id = value entry_id = property(_get_entry_id, _set_entry_id) """ The user specified ID for the entry. You can use this ID to identify which entries failed. """ def _get_asset_id(self): return self.__asset_id def _set_asset_id(self, value): if value is not None and not isinstance(value, str): raise TypeError("asset_id must be str") self.__asset_id = value asset_id = property(_get_asset_id, _set_asset_id) """ The ID of the asset to update. """ def _get_property_id(self): return self.__property_id def _set_property_id(self, value): if value is not None and not isinstance(value, str): raise TypeError("property_id must be str") self.__property_id = value property_id = property(_get_property_id, _set_property_id) """ The ID of the asset property for this entry. """ def _get_property_alias(self): return self.__property_alias def _set_property_alias(self, value): if value is not None and not isinstance(value, str): raise TypeError("property_alias must be str") self.__property_alias = value property_alias = property(_get_property_alias, _set_property_alias) """ The property alias that identifies the property, such as an OPC-UA server data stream path (for example, /company/windfarm/3/turbine/7/temperature). For more information, see https://docs.aws.amazon.com/iot-sitewise/latest/userguide/connect-data-streams.html. """ def _get_property_values(self): return self.__property_values def _set_property_values(self, value): if not isinstance(value, list): raise TypeError("property_values must be list") if not all(isinstance(i, AssetPropertyValue) for i in value): raise TypeError("property_values list values must be AssetPropertyValue") self.__property_values = value property_values = property(_get_property_values, _set_property_values) """ The list of property values to upload. You can specify up to 10 values. """
[docs] @staticmethod def from_dict(d): v = {} if "entryId" in d: v["entry_id"] = ( str.from_dict(d["entryId"]) if hasattr(str, "from_dict") else d["entryId"] ) if "assetId" in d: v["asset_id"] = ( str.from_dict(d["assetId"]) if hasattr(str, "from_dict") else d["assetId"] ) if "propertyId" in d: v["property_id"] = ( str.from_dict(d["propertyId"]) if hasattr(str, "from_dict") else d["propertyId"] ) if "propertyAlias" in d: v["property_alias"] = ( str.from_dict(d["propertyAlias"]) if hasattr(str, "from_dict") else d["propertyAlias"] ) if "propertyValues" in d: v["property_values"] = [ AssetPropertyValue.from_dict(p) if hasattr(AssetPropertyValue, "from_dict") else p for p in d["propertyValues"] ] return PutAssetPropertyValueEntry(**v)
[docs] def as_dict(self): d = {} if self.__entry_id is not None: d["entryId"] = ( self.__entry_id.as_dict() if hasattr(self.__entry_id, "as_dict") else self.__entry_id ) if self.__asset_id is not None: d["assetId"] = ( self.__asset_id.as_dict() if hasattr(self.__asset_id, "as_dict") else self.__asset_id ) if self.__property_id is not None: d["propertyId"] = ( self.__property_id.as_dict() if hasattr(self.__property_id, "as_dict") else self.__property_id ) if self.__property_alias is not None: d["propertyAlias"] = ( self.__property_alias.as_dict() if hasattr(self.__property_alias, "as_dict") else self.__property_alias ) if self.__property_values is not None: d["propertyValues"] = [ p.as_dict() if hasattr(p, "as_dict") else p for p in self.__property_values ] return d
def __repr__(self): return "<Class PutAssetPropertyValueEntry. entry_id: {}, asset_id: {}, property_id: {}, property_alias: {}, property_values: {}>".format( limitedRepr( self.__entry_id[:20] if isinstance(self.__entry_id, bytes) else self.__entry_id ), limitedRepr( self.__asset_id[:20] if isinstance(self.__asset_id, bytes) else self.__asset_id ), limitedRepr( self.__property_id[:20] if isinstance(self.__property_id, bytes) else self.__property_id ), limitedRepr( self.__property_alias[:20] if isinstance(self.__property_alias, bytes) else self.__property_alias ), limitedRepr( self.__property_values[:20] if isinstance(self.__property_values, bytes) else self.__property_values ), )