// // Copyright 2010-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"). // You may not use this file except in compliance with the License. // A copy of the License is located at // // http://aws.amazon.com/apache2.0 // // or in the "license" file accompanying this file. This file is distributed // on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either // express or implied. See the License for the specific language governing // permissions and limitations under the License. // #import #import #import NS_ASSUME_NONNULL_BEGIN FOUNDATION_EXPORT NSString *const AWSIoTErrorDomain; typedef NS_ENUM(NSInteger, AWSIoTErrorType) { AWSIoTErrorUnknown, AWSIoTErrorCertificateConflict, AWSIoTErrorCertificateState, AWSIoTErrorCertificateValidation, AWSIoTErrorConflict, AWSIoTErrorConflictingResourceUpdate, AWSIoTErrorDeleteConflict, AWSIoTErrorIndexNotReady, AWSIoTErrorInternal, AWSIoTErrorInternalFailure, AWSIoTErrorInternalServer, AWSIoTErrorInvalidAggregation, AWSIoTErrorInvalidQuery, AWSIoTErrorInvalidRequest, AWSIoTErrorInvalidResponse, AWSIoTErrorInvalidStateTransition, AWSIoTErrorLimitExceeded, AWSIoTErrorMalformedPolicy, AWSIoTErrorNotConfigured, AWSIoTErrorRegistrationCodeValidation, AWSIoTErrorResourceAlreadyExists, AWSIoTErrorResourceNotFound, AWSIoTErrorResourceRegistrationFailure, AWSIoTErrorServiceQuotaExceeded, AWSIoTErrorServiceUnavailable, AWSIoTErrorSqlParse, AWSIoTErrorTaskAlreadyExists, AWSIoTErrorThrottling, AWSIoTErrorTransferAlreadyCompleted, AWSIoTErrorTransferConflict, AWSIoTErrorUnauthorized, AWSIoTErrorValidation, AWSIoTErrorVersionConflict, AWSIoTErrorVersionsLimitExceeded, }; typedef NS_ENUM(NSInteger, AWSIoTAbortAction) { AWSIoTAbortActionUnknown, AWSIoTAbortActionCancel, }; typedef NS_ENUM(NSInteger, AWSIoTActionType) { AWSIoTActionTypeUnknown, AWSIoTActionTypePublish, AWSIoTActionTypeSubscribe, AWSIoTActionTypeReceive, AWSIoTActionTypeConnect, }; typedef NS_ENUM(NSInteger, AWSIoTAggregationTypeName) { AWSIoTAggregationTypeNameUnknown, AWSIoTAggregationTypeNameStatistics, AWSIoTAggregationTypeNamePercentiles, AWSIoTAggregationTypeNameCardinality, }; typedef NS_ENUM(NSInteger, AWSIoTAlertTargetType) { AWSIoTAlertTargetTypeUnknown, AWSIoTAlertTargetTypeSns, }; typedef NS_ENUM(NSInteger, AWSIoTAuditCheckRunStatus) { AWSIoTAuditCheckRunStatusUnknown, AWSIoTAuditCheckRunStatusInProgress, AWSIoTAuditCheckRunStatusWaitingForDataCollection, AWSIoTAuditCheckRunStatusCanceled, AWSIoTAuditCheckRunStatusCompletedCompliant, AWSIoTAuditCheckRunStatusCompletedNonCompliant, AWSIoTAuditCheckRunStatusFailed, }; typedef NS_ENUM(NSInteger, AWSIoTAuditFindingSeverity) { AWSIoTAuditFindingSeverityUnknown, AWSIoTAuditFindingSeverityCritical, AWSIoTAuditFindingSeverityHigh, AWSIoTAuditFindingSeverityMedium, AWSIoTAuditFindingSeverityLow, }; typedef NS_ENUM(NSInteger, AWSIoTAuditFrequency) { AWSIoTAuditFrequencyUnknown, AWSIoTAuditFrequencyDaily, AWSIoTAuditFrequencyWeekly, AWSIoTAuditFrequencyBiweekly, AWSIoTAuditFrequencyMonthly, }; typedef NS_ENUM(NSInteger, AWSIoTAuditMitigationActionsExecutionStatus) { AWSIoTAuditMitigationActionsExecutionStatusUnknown, AWSIoTAuditMitigationActionsExecutionStatusInProgress, AWSIoTAuditMitigationActionsExecutionStatusCompleted, AWSIoTAuditMitigationActionsExecutionStatusFailed, AWSIoTAuditMitigationActionsExecutionStatusCanceled, AWSIoTAuditMitigationActionsExecutionStatusSkipped, AWSIoTAuditMitigationActionsExecutionStatusPending, }; typedef NS_ENUM(NSInteger, AWSIoTAuditMitigationActionsTaskStatus) { AWSIoTAuditMitigationActionsTaskStatusUnknown, AWSIoTAuditMitigationActionsTaskStatusInProgress, AWSIoTAuditMitigationActionsTaskStatusCompleted, AWSIoTAuditMitigationActionsTaskStatusFailed, AWSIoTAuditMitigationActionsTaskStatusCanceled, }; typedef NS_ENUM(NSInteger, AWSIoTAuditNotificationType) { AWSIoTAuditNotificationTypeUnknown, AWSIoTAuditNotificationTypeSns, }; typedef NS_ENUM(NSInteger, AWSIoTAuditTaskStatus) { AWSIoTAuditTaskStatusUnknown, AWSIoTAuditTaskStatusInProgress, AWSIoTAuditTaskStatusCompleted, AWSIoTAuditTaskStatusFailed, AWSIoTAuditTaskStatusCanceled, }; typedef NS_ENUM(NSInteger, AWSIoTAuditTaskType) { AWSIoTAuditTaskTypeUnknown, AWSIoTAuditTaskTypeOnDemandAuditTask, AWSIoTAuditTaskTypeScheduledAuditTask, }; typedef NS_ENUM(NSInteger, AWSIoTAuthDecision) { AWSIoTAuthDecisionUnknown, AWSIoTAuthDecisionAllowed, AWSIoTAuthDecisionExplicitDeny, AWSIoTAuthDecisionImplicitDeny, }; typedef NS_ENUM(NSInteger, AWSIoTAuthorizerStatus) { AWSIoTAuthorizerStatusUnknown, AWSIoTAuthorizerStatusActive, AWSIoTAuthorizerStatusInactive, }; typedef NS_ENUM(NSInteger, AWSIoTAutoRegistrationStatus) { AWSIoTAutoRegistrationStatusUnknown, AWSIoTAutoRegistrationStatusEnable, AWSIoTAutoRegistrationStatusDisable, }; typedef NS_ENUM(NSInteger, AWSIoTAwsJobAbortCriteriaAbortAction) { AWSIoTAwsJobAbortCriteriaAbortActionUnknown, AWSIoTAwsJobAbortCriteriaAbortActionCancel, }; typedef NS_ENUM(NSInteger, AWSIoTAwsJobAbortCriteriaFailureType) { AWSIoTAwsJobAbortCriteriaFailureTypeUnknown, AWSIoTAwsJobAbortCriteriaFailureTypeFailed, AWSIoTAwsJobAbortCriteriaFailureTypeRejected, AWSIoTAwsJobAbortCriteriaFailureTypeTimedOut, AWSIoTAwsJobAbortCriteriaFailureTypeAll, }; typedef NS_ENUM(NSInteger, AWSIoTBehaviorCriteriaType) { AWSIoTBehaviorCriteriaTypeUnknown, AWSIoTBehaviorCriteriaTypeStatic, AWSIoTBehaviorCriteriaTypeStatistical, AWSIoTBehaviorCriteriaTypeMachineLearning, }; typedef NS_ENUM(NSInteger, AWSIoTCACertificateStatus) { AWSIoTCACertificateStatusUnknown, AWSIoTCACertificateStatusActive, AWSIoTCACertificateStatusInactive, }; typedef NS_ENUM(NSInteger, AWSIoTCACertificateUpdateAction) { AWSIoTCACertificateUpdateActionUnknown, AWSIoTCACertificateUpdateActionDeactivate, }; typedef NS_ENUM(NSInteger, AWSIoTCannedAccessControlList) { AWSIoTCannedAccessControlListUnknown, AWSIoTCannedAccessControlListPrivate, AWSIoTCannedAccessControlListPublicRead, AWSIoTCannedAccessControlListPublicReadWrite, AWSIoTCannedAccessControlListAwsExecRead, AWSIoTCannedAccessControlListAuthenticatedRead, AWSIoTCannedAccessControlListBucketOwnerRead, AWSIoTCannedAccessControlListBucketOwnerFullControl, AWSIoTCannedAccessControlListLogDeliveryWrite, }; typedef NS_ENUM(NSInteger, AWSIoTCertificateMode) { AWSIoTCertificateModeUnknown, AWSIoTCertificateModeDefault, AWSIoTCertificateModeSniOnly, }; typedef NS_ENUM(NSInteger, AWSIoTCertificateStatus) { AWSIoTCertificateStatusUnknown, AWSIoTCertificateStatusActive, AWSIoTCertificateStatusInactive, AWSIoTCertificateStatusRevoked, AWSIoTCertificateStatusPendingTransfer, AWSIoTCertificateStatusRegisterInactive, AWSIoTCertificateStatusPendingActivation, }; typedef NS_ENUM(NSInteger, AWSIoTComparisonOperator) { AWSIoTComparisonOperatorUnknown, AWSIoTComparisonOperatorLessThan, AWSIoTComparisonOperatorLessThanEquals, AWSIoTComparisonOperatorGreaterThan, AWSIoTComparisonOperatorGreaterThanEquals, AWSIoTComparisonOperatorInCidrSet, AWSIoTComparisonOperatorNotInCidrSet, AWSIoTComparisonOperatorInPortSet, AWSIoTComparisonOperatorNotInPortSet, AWSIoTComparisonOperatorInSet, AWSIoTComparisonOperatorNotInSet, }; typedef NS_ENUM(NSInteger, AWSIoTConfidenceLevel) { AWSIoTConfidenceLevelUnknown, AWSIoTConfidenceLevelLow, AWSIoTConfidenceLevelMedium, AWSIoTConfidenceLevelHigh, }; typedef NS_ENUM(NSInteger, AWSIoTCustomMetricType) { AWSIoTCustomMetricTypeUnknown, AWSIoTCustomMetricTypeStringList, AWSIoTCustomMetricTypeIpAddressList, AWSIoTCustomMetricTypeNumberList, AWSIoTCustomMetricTypeNumber, }; typedef NS_ENUM(NSInteger, AWSIoTDayOfWeek) { AWSIoTDayOfWeekUnknown, AWSIoTDayOfWeekSun, AWSIoTDayOfWeekMon, AWSIoTDayOfWeekTue, AWSIoTDayOfWeekWed, AWSIoTDayOfWeekThu, AWSIoTDayOfWeekFri, AWSIoTDayOfWeekSat, }; typedef NS_ENUM(NSInteger, AWSIoTDetectMitigationActionExecutionStatus) { AWSIoTDetectMitigationActionExecutionStatusUnknown, AWSIoTDetectMitigationActionExecutionStatusInProgress, AWSIoTDetectMitigationActionExecutionStatusSuccessful, AWSIoTDetectMitigationActionExecutionStatusFailed, AWSIoTDetectMitigationActionExecutionStatusSkipped, }; typedef NS_ENUM(NSInteger, AWSIoTDetectMitigationActionsTaskStatus) { AWSIoTDetectMitigationActionsTaskStatusUnknown, AWSIoTDetectMitigationActionsTaskStatusInProgress, AWSIoTDetectMitigationActionsTaskStatusSuccessful, AWSIoTDetectMitigationActionsTaskStatusFailed, AWSIoTDetectMitigationActionsTaskStatusCanceled, }; typedef NS_ENUM(NSInteger, AWSIoTDeviceCertificateUpdateAction) { AWSIoTDeviceCertificateUpdateActionUnknown, AWSIoTDeviceCertificateUpdateActionDeactivate, }; typedef NS_ENUM(NSInteger, AWSIoTDeviceDefenderIndexingMode) { AWSIoTDeviceDefenderIndexingModeUnknown, AWSIoTDeviceDefenderIndexingModeOff, AWSIoTDeviceDefenderIndexingModeViolations, }; typedef NS_ENUM(NSInteger, AWSIoTDimensionType) { AWSIoTDimensionTypeUnknown, AWSIoTDimensionTypeTopicFilter, }; typedef NS_ENUM(NSInteger, AWSIoTDimensionValueOperator) { AWSIoTDimensionValueOperatorUnknown, AWSIoTDimensionValueOperatorIN, AWSIoTDimensionValueOperatorNotIn, }; typedef NS_ENUM(NSInteger, AWSIoTDomainConfigurationStatus) { AWSIoTDomainConfigurationStatusUnknown, AWSIoTDomainConfigurationStatusEnabled, AWSIoTDomainConfigurationStatusDisabled, }; typedef NS_ENUM(NSInteger, AWSIoTDomainType) { AWSIoTDomainTypeUnknown, AWSIoTDomainTypeEndpoint, AWSIoTDomainTypeAwsManaged, AWSIoTDomainTypeCustomerManaged, }; typedef NS_ENUM(NSInteger, AWSIoTDynamicGroupStatus) { AWSIoTDynamicGroupStatusUnknown, AWSIoTDynamicGroupStatusActive, AWSIoTDynamicGroupStatusBuilding, AWSIoTDynamicGroupStatusRebuilding, }; typedef NS_ENUM(NSInteger, AWSIoTDynamoKeyType) { AWSIoTDynamoKeyTypeUnknown, AWSIoTDynamoKeyTypeString, AWSIoTDynamoKeyTypeNumber, }; typedef NS_ENUM(NSInteger, AWSIoTEventType) { AWSIoTEventTypeUnknown, AWSIoTEventTypeThing, AWSIoTEventTypeThingGroup, AWSIoTEventTypeThingType, AWSIoTEventTypeThingGroupMembership, AWSIoTEventTypeThingGroupHierarchy, AWSIoTEventTypeThingTypeAssociation, AWSIoTEventTypeJob, AWSIoTEventTypeJobExecution, AWSIoTEventTypePolicy, AWSIoTEventTypeCertificate, AWSIoTEventTypeCaCertificate, }; typedef NS_ENUM(NSInteger, AWSIoTFieldType) { AWSIoTFieldTypeUnknown, AWSIoTFieldTypeNumber, AWSIoTFieldTypeString, AWSIoTFieldTypeBoolean, }; typedef NS_ENUM(NSInteger, AWSIoTFleetMetricUnit) { AWSIoTFleetMetricUnitUnknown, AWSIoTFleetMetricUnitSeconds, AWSIoTFleetMetricUnitMicroseconds, AWSIoTFleetMetricUnitMilliseconds, AWSIoTFleetMetricUnitBytes, AWSIoTFleetMetricUnitKilobytes, AWSIoTFleetMetricUnitMegabytes, AWSIoTFleetMetricUnitGigabytes, AWSIoTFleetMetricUnitTerabytes, AWSIoTFleetMetricUnitBits, AWSIoTFleetMetricUnitKilobits, AWSIoTFleetMetricUnitMegabits, AWSIoTFleetMetricUnitGigabits, AWSIoTFleetMetricUnitTerabits, AWSIoTFleetMetricUnitPercent, AWSIoTFleetMetricUnitCount, AWSIoTFleetMetricUnitBytesSecond, AWSIoTFleetMetricUnitKilobytesSecond, AWSIoTFleetMetricUnitMegabytesSecond, AWSIoTFleetMetricUnitGigabytesSecond, AWSIoTFleetMetricUnitTerabytesSecond, AWSIoTFleetMetricUnitBitsSecond, AWSIoTFleetMetricUnitKilobitsSecond, AWSIoTFleetMetricUnitMegabitsSecond, AWSIoTFleetMetricUnitGigabitsSecond, AWSIoTFleetMetricUnitTerabitsSecond, AWSIoTFleetMetricUnitCountSecond, AWSIoTFleetMetricUnitNone, }; typedef NS_ENUM(NSInteger, AWSIoTIndexStatus) { AWSIoTIndexStatusUnknown, AWSIoTIndexStatusActive, AWSIoTIndexStatusBuilding, AWSIoTIndexStatusRebuilding, }; typedef NS_ENUM(NSInteger, AWSIoTJobEndBehavior) { AWSIoTJobEndBehaviorUnknown, AWSIoTJobEndBehaviorStopRollout, AWSIoTJobEndBehaviorCancel, AWSIoTJobEndBehaviorForceCancel, }; typedef NS_ENUM(NSInteger, AWSIoTJobExecutionFailureType) { AWSIoTJobExecutionFailureTypeUnknown, AWSIoTJobExecutionFailureTypeFailed, AWSIoTJobExecutionFailureTypeRejected, AWSIoTJobExecutionFailureTypeTimedOut, AWSIoTJobExecutionFailureTypeAll, }; typedef NS_ENUM(NSInteger, AWSIoTJobExecutionStatus) { AWSIoTJobExecutionStatusUnknown, AWSIoTJobExecutionStatusQueued, AWSIoTJobExecutionStatusInProgress, AWSIoTJobExecutionStatusSucceeded, AWSIoTJobExecutionStatusFailed, AWSIoTJobExecutionStatusTimedOut, AWSIoTJobExecutionStatusRejected, AWSIoTJobExecutionStatusRemoved, AWSIoTJobExecutionStatusCanceled, }; typedef NS_ENUM(NSInteger, AWSIoTJobStatus) { AWSIoTJobStatusUnknown, AWSIoTJobStatusInProgress, AWSIoTJobStatusCanceled, AWSIoTJobStatusCompleted, AWSIoTJobStatusDeletionInProgress, AWSIoTJobStatusScheduled, }; typedef NS_ENUM(NSInteger, AWSIoTLogLevel) { AWSIoTLogLevelUnknown, AWSIoTLogLevelDebug, AWSIoTLogLevelInfo, AWSIoTLogLevelError, AWSIoTLogLevelWarn, AWSIoTLogLevelDisabled, }; typedef NS_ENUM(NSInteger, AWSIoTLogTargetType) { AWSIoTLogTargetTypeUnknown, AWSIoTLogTargetTypeDefault, AWSIoTLogTargetTypeThingGroup, AWSIoTLogTargetTypeClientId, AWSIoTLogTargetTypeSourceIp, AWSIoTLogTargetTypePrincipalId, }; typedef NS_ENUM(NSInteger, AWSIoTMessageFormat) { AWSIoTMessageFormatUnknown, AWSIoTMessageFormatRAW, AWSIoTMessageFormatJson, }; typedef NS_ENUM(NSInteger, AWSIoTMitigationActionType) { AWSIoTMitigationActionTypeUnknown, AWSIoTMitigationActionTypeUpdateDeviceCertificate, AWSIoTMitigationActionTypeUpdateCaCertificate, AWSIoTMitigationActionTypeAddThingsToThingGroup, AWSIoTMitigationActionTypeReplaceDefaultPolicyVersion, AWSIoTMitigationActionTypeEnableIotLogging, AWSIoTMitigationActionTypePublishFindingToSns, }; typedef NS_ENUM(NSInteger, AWSIoTModelStatus) { AWSIoTModelStatusUnknown, AWSIoTModelStatusPendingBuild, AWSIoTModelStatusActive, AWSIoTModelStatusExpired, }; typedef NS_ENUM(NSInteger, AWSIoTNamedShadowIndexingMode) { AWSIoTNamedShadowIndexingModeUnknown, AWSIoTNamedShadowIndexingModeOff, AWSIoTNamedShadowIndexingModeOn, }; typedef NS_ENUM(NSInteger, AWSIoTOTAUpdateStatus) { AWSIoTOTAUpdateStatusUnknown, AWSIoTOTAUpdateStatusCreatePending, AWSIoTOTAUpdateStatusCreateInProgress, AWSIoTOTAUpdateStatusCreateComplete, AWSIoTOTAUpdateStatusCreateFailed, AWSIoTOTAUpdateStatusDeleteInProgress, AWSIoTOTAUpdateStatusDeleteFailed, }; typedef NS_ENUM(NSInteger, AWSIoTPackageVersionAction) { AWSIoTPackageVersionActionUnknown, AWSIoTPackageVersionActionPublish, AWSIoTPackageVersionActionDeprecate, }; typedef NS_ENUM(NSInteger, AWSIoTPackageVersionStatus) { AWSIoTPackageVersionStatusUnknown, AWSIoTPackageVersionStatusDraft, AWSIoTPackageVersionStatusPublished, AWSIoTPackageVersionStatusDeprecated, }; typedef NS_ENUM(NSInteger, AWSIoTPolicyTemplateName) { AWSIoTPolicyTemplateNameUnknown, AWSIoTPolicyTemplateNameBlankPolicy, }; typedef NS_ENUM(NSInteger, AWSIoTProtocols) { AWSIoTProtocolsUnknown, AWSIoTProtocolsMqtt, AWSIoTProtocolsHttp, }; typedef NS_ENUM(NSInteger, AWSIoTReportType) { AWSIoTReportTypeUnknown, AWSIoTReportTypeErrors, AWSIoTReportTypeResults, }; typedef NS_ENUM(NSInteger, AWSIoTResourceType) { AWSIoTResourceTypeUnknown, AWSIoTResourceTypeDeviceCertificate, AWSIoTResourceTypeCaCertificate, AWSIoTResourceTypeIotPolicy, AWSIoTResourceTypeCognitoIdentityPool, AWSIoTResourceTypeClientId, AWSIoTResourceTypeAccountSettings, AWSIoTResourceTypeRoleAlias, AWSIoTResourceTypeIamRole, AWSIoTResourceTypeIssuerCertificate, }; typedef NS_ENUM(NSInteger, AWSIoTRetryableFailureType) { AWSIoTRetryableFailureTypeUnknown, AWSIoTRetryableFailureTypeFailed, AWSIoTRetryableFailureTypeTimedOut, AWSIoTRetryableFailureTypeAll, }; typedef NS_ENUM(NSInteger, AWSIoTServerCertificateStatus) { AWSIoTServerCertificateStatusUnknown, AWSIoTServerCertificateStatusInvalid, AWSIoTServerCertificateStatusValid, }; typedef NS_ENUM(NSInteger, AWSIoTServiceType) { AWSIoTServiceTypeUnknown, AWSIoTServiceTypeData, AWSIoTServiceTypeCredentialProvider, AWSIoTServiceTypeJobs, }; typedef NS_ENUM(NSInteger, AWSIoTStatus) { AWSIoTStatusUnknown, AWSIoTStatusInProgress, AWSIoTStatusCompleted, AWSIoTStatusFailed, AWSIoTStatusCancelled, AWSIoTStatusCancelling, }; typedef NS_ENUM(NSInteger, AWSIoTTargetSelection) { AWSIoTTargetSelectionUnknown, AWSIoTTargetSelectionContinuous, AWSIoTTargetSelectionSnapshot, }; typedef NS_ENUM(NSInteger, AWSIoTTemplateType) { AWSIoTTemplateTypeUnknown, AWSIoTTemplateTypeFleetProvisioning, AWSIoTTemplateTypeJitp, }; typedef NS_ENUM(NSInteger, AWSIoTThingConnectivityIndexingMode) { AWSIoTThingConnectivityIndexingModeUnknown, AWSIoTThingConnectivityIndexingModeOff, AWSIoTThingConnectivityIndexingModeStatus, }; typedef NS_ENUM(NSInteger, AWSIoTThingGroupIndexingMode) { AWSIoTThingGroupIndexingModeUnknown, AWSIoTThingGroupIndexingModeOff, AWSIoTThingGroupIndexingModeOn, }; typedef NS_ENUM(NSInteger, AWSIoTThingIndexingMode) { AWSIoTThingIndexingModeUnknown, AWSIoTThingIndexingModeOff, AWSIoTThingIndexingModeRegistry, AWSIoTThingIndexingModeRegistryAndShadow, }; typedef NS_ENUM(NSInteger, AWSIoTTopicRuleDestinationStatus) { AWSIoTTopicRuleDestinationStatusUnknown, AWSIoTTopicRuleDestinationStatusEnabled, AWSIoTTopicRuleDestinationStatusInProgress, AWSIoTTopicRuleDestinationStatusDisabled, AWSIoTTopicRuleDestinationStatusError, AWSIoTTopicRuleDestinationStatusDeleting, }; typedef NS_ENUM(NSInteger, AWSIoTVerificationState) { AWSIoTVerificationStateUnknown, AWSIoTVerificationStateFalsePositive, AWSIoTVerificationStateBenignPositive, AWSIoTVerificationStateTruePositive, }; typedef NS_ENUM(NSInteger, AWSIoTViolationEventType) { AWSIoTViolationEventTypeUnknown, AWSIoTViolationEventTypeInAlarm, AWSIoTViolationEventTypeAlarmCleared, AWSIoTViolationEventTypeAlarmInvalidated, }; @class AWSIoTAbortConfig; @class AWSIoTAbortCriteria; @class AWSIoTAcceptCertificateTransferRequest; @class AWSIoTAction; @class AWSIoTActiveViolation; @class AWSIoTAddThingToBillingGroupRequest; @class AWSIoTAddThingToBillingGroupResponse; @class AWSIoTAddThingToThingGroupRequest; @class AWSIoTAddThingToThingGroupResponse; @class AWSIoTAddThingsToThingGroupParams; @class AWSIoTAggregationType; @class AWSIoTAlertTarget; @class AWSIoTAllowed; @class AWSIoTAssetPropertyTimestamp; @class AWSIoTAssetPropertyValue; @class AWSIoTAssetPropertyVariant; @class AWSIoTAssociateTargetsWithJobRequest; @class AWSIoTAssociateTargetsWithJobResponse; @class AWSIoTAttachPolicyRequest; @class AWSIoTAttachPrincipalPolicyRequest; @class AWSIoTAttachSecurityProfileRequest; @class AWSIoTAttachSecurityProfileResponse; @class AWSIoTAttachThingPrincipalRequest; @class AWSIoTAttachThingPrincipalResponse; @class AWSIoTAttributePayload; @class AWSIoTAuditCheckConfiguration; @class AWSIoTAuditCheckDetails; @class AWSIoTAuditFinding; @class AWSIoTAuditMitigationActionExecutionMetadata; @class AWSIoTAuditMitigationActionsTaskMetadata; @class AWSIoTAuditMitigationActionsTaskTarget; @class AWSIoTAuditNotificationTarget; @class AWSIoTAuditSuppression; @class AWSIoTAuditTaskMetadata; @class AWSIoTAuthInfo; @class AWSIoTAuthResult; @class AWSIoTAuthorizerConfig; @class AWSIoTAuthorizerDescription; @class AWSIoTAuthorizerSummary; @class AWSIoTAwsJobAbortConfig; @class AWSIoTAwsJobAbortCriteria; @class AWSIoTAwsJobExecutionsRolloutConfig; @class AWSIoTAwsJobExponentialRolloutRate; @class AWSIoTAwsJobPresignedUrlConfig; @class AWSIoTAwsJobRateIncreaseCriteria; @class AWSIoTAwsJobTimeoutConfig; @class AWSIoTBehavior; @class AWSIoTBehaviorCriteria; @class AWSIoTBehaviorModelTrainingSummary; @class AWSIoTBillingGroupMetadata; @class AWSIoTBillingGroupProperties; @class AWSIoTBucket; @class AWSIoTBucketsAggregationType; @class AWSIoTCACertificate; @class AWSIoTCACertificateDescription; @class AWSIoTCancelAuditMitigationActionsTaskRequest; @class AWSIoTCancelAuditMitigationActionsTaskResponse; @class AWSIoTCancelAuditTaskRequest; @class AWSIoTCancelAuditTaskResponse; @class AWSIoTCancelCertificateTransferRequest; @class AWSIoTCancelDetectMitigationActionsTaskRequest; @class AWSIoTCancelDetectMitigationActionsTaskResponse; @class AWSIoTCancelJobExecutionRequest; @class AWSIoTCancelJobRequest; @class AWSIoTCancelJobResponse; @class AWSIoTCertificate; @class AWSIoTCertificateDescription; @class AWSIoTCertificateValidity; @class AWSIoTClearDefaultAuthorizerRequest; @class AWSIoTClearDefaultAuthorizerResponse; @class AWSIoTCloudwatchAlarmAction; @class AWSIoTCloudwatchLogsAction; @class AWSIoTCloudwatchMetricAction; @class AWSIoTCodeSigning; @class AWSIoTCodeSigningCertificateChain; @class AWSIoTCodeSigningSignature; @class AWSIoTConfiguration; @class AWSIoTConfirmTopicRuleDestinationRequest; @class AWSIoTConfirmTopicRuleDestinationResponse; @class AWSIoTCreateAuditSuppressionRequest; @class AWSIoTCreateAuditSuppressionResponse; @class AWSIoTCreateAuthorizerRequest; @class AWSIoTCreateAuthorizerResponse; @class AWSIoTCreateBillingGroupRequest; @class AWSIoTCreateBillingGroupResponse; @class AWSIoTCreateCertificateFromCsrRequest; @class AWSIoTCreateCertificateFromCsrResponse; @class AWSIoTCreateCustomMetricRequest; @class AWSIoTCreateCustomMetricResponse; @class AWSIoTCreateDimensionRequest; @class AWSIoTCreateDimensionResponse; @class AWSIoTCreateDomainConfigurationRequest; @class AWSIoTCreateDomainConfigurationResponse; @class AWSIoTCreateDynamicThingGroupRequest; @class AWSIoTCreateDynamicThingGroupResponse; @class AWSIoTCreateFleetMetricRequest; @class AWSIoTCreateFleetMetricResponse; @class AWSIoTCreateJobRequest; @class AWSIoTCreateJobResponse; @class AWSIoTCreateJobTemplateRequest; @class AWSIoTCreateJobTemplateResponse; @class AWSIoTCreateKeysAndCertificateRequest; @class AWSIoTCreateKeysAndCertificateResponse; @class AWSIoTCreateMitigationActionRequest; @class AWSIoTCreateMitigationActionResponse; @class AWSIoTCreateOTAUpdateRequest; @class AWSIoTCreateOTAUpdateResponse; @class AWSIoTCreatePackageRequest; @class AWSIoTCreatePackageResponse; @class AWSIoTCreatePackageVersionRequest; @class AWSIoTCreatePackageVersionResponse; @class AWSIoTCreatePolicyRequest; @class AWSIoTCreatePolicyResponse; @class AWSIoTCreatePolicyVersionRequest; @class AWSIoTCreatePolicyVersionResponse; @class AWSIoTCreateProvisioningClaimRequest; @class AWSIoTCreateProvisioningClaimResponse; @class AWSIoTCreateProvisioningTemplateRequest; @class AWSIoTCreateProvisioningTemplateResponse; @class AWSIoTCreateProvisioningTemplateVersionRequest; @class AWSIoTCreateProvisioningTemplateVersionResponse; @class AWSIoTCreateRoleAliasRequest; @class AWSIoTCreateRoleAliasResponse; @class AWSIoTCreateScheduledAuditRequest; @class AWSIoTCreateScheduledAuditResponse; @class AWSIoTCreateSecurityProfileRequest; @class AWSIoTCreateSecurityProfileResponse; @class AWSIoTCreateStreamRequest; @class AWSIoTCreateStreamResponse; @class AWSIoTCreateThingGroupRequest; @class AWSIoTCreateThingGroupResponse; @class AWSIoTCreateThingRequest; @class AWSIoTCreateThingResponse; @class AWSIoTCreateThingTypeRequest; @class AWSIoTCreateThingTypeResponse; @class AWSIoTCreateTopicRuleDestinationRequest; @class AWSIoTCreateTopicRuleDestinationResponse; @class AWSIoTCreateTopicRuleRequest; @class AWSIoTCustomCodeSigning; @class AWSIoTDeleteAccountAuditConfigurationRequest; @class AWSIoTDeleteAccountAuditConfigurationResponse; @class AWSIoTDeleteAuditSuppressionRequest; @class AWSIoTDeleteAuditSuppressionResponse; @class AWSIoTDeleteAuthorizerRequest; @class AWSIoTDeleteAuthorizerResponse; @class AWSIoTDeleteBillingGroupRequest; @class AWSIoTDeleteBillingGroupResponse; @class AWSIoTDeleteCACertificateRequest; @class AWSIoTDeleteCACertificateResponse; @class AWSIoTDeleteCertificateRequest; @class AWSIoTDeleteCustomMetricRequest; @class AWSIoTDeleteCustomMetricResponse; @class AWSIoTDeleteDimensionRequest; @class AWSIoTDeleteDimensionResponse; @class AWSIoTDeleteDomainConfigurationRequest; @class AWSIoTDeleteDomainConfigurationResponse; @class AWSIoTDeleteDynamicThingGroupRequest; @class AWSIoTDeleteDynamicThingGroupResponse; @class AWSIoTDeleteFleetMetricRequest; @class AWSIoTDeleteJobExecutionRequest; @class AWSIoTDeleteJobRequest; @class AWSIoTDeleteJobTemplateRequest; @class AWSIoTDeleteMitigationActionRequest; @class AWSIoTDeleteMitigationActionResponse; @class AWSIoTDeleteOTAUpdateRequest; @class AWSIoTDeleteOTAUpdateResponse; @class AWSIoTDeletePackageRequest; @class AWSIoTDeletePackageResponse; @class AWSIoTDeletePackageVersionRequest; @class AWSIoTDeletePackageVersionResponse; @class AWSIoTDeletePolicyRequest; @class AWSIoTDeletePolicyVersionRequest; @class AWSIoTDeleteProvisioningTemplateRequest; @class AWSIoTDeleteProvisioningTemplateResponse; @class AWSIoTDeleteProvisioningTemplateVersionRequest; @class AWSIoTDeleteProvisioningTemplateVersionResponse; @class AWSIoTDeleteRegistrationCodeRequest; @class AWSIoTDeleteRegistrationCodeResponse; @class AWSIoTDeleteRoleAliasRequest; @class AWSIoTDeleteRoleAliasResponse; @class AWSIoTDeleteScheduledAuditRequest; @class AWSIoTDeleteScheduledAuditResponse; @class AWSIoTDeleteSecurityProfileRequest; @class AWSIoTDeleteSecurityProfileResponse; @class AWSIoTDeleteStreamRequest; @class AWSIoTDeleteStreamResponse; @class AWSIoTDeleteThingGroupRequest; @class AWSIoTDeleteThingGroupResponse; @class AWSIoTDeleteThingRequest; @class AWSIoTDeleteThingResponse; @class AWSIoTDeleteThingTypeRequest; @class AWSIoTDeleteThingTypeResponse; @class AWSIoTDeleteTopicRuleDestinationRequest; @class AWSIoTDeleteTopicRuleDestinationResponse; @class AWSIoTDeleteTopicRuleRequest; @class AWSIoTDeleteV2LoggingLevelRequest; @class AWSIoTDenied; @class AWSIoTDeprecateThingTypeRequest; @class AWSIoTDeprecateThingTypeResponse; @class AWSIoTDescribeAccountAuditConfigurationRequest; @class AWSIoTDescribeAccountAuditConfigurationResponse; @class AWSIoTDescribeAuditFindingRequest; @class AWSIoTDescribeAuditFindingResponse; @class AWSIoTDescribeAuditMitigationActionsTaskRequest; @class AWSIoTDescribeAuditMitigationActionsTaskResponse; @class AWSIoTDescribeAuditSuppressionRequest; @class AWSIoTDescribeAuditSuppressionResponse; @class AWSIoTDescribeAuditTaskRequest; @class AWSIoTDescribeAuditTaskResponse; @class AWSIoTDescribeAuthorizerRequest; @class AWSIoTDescribeAuthorizerResponse; @class AWSIoTDescribeBillingGroupRequest; @class AWSIoTDescribeBillingGroupResponse; @class AWSIoTDescribeCACertificateRequest; @class AWSIoTDescribeCACertificateResponse; @class AWSIoTDescribeCertificateRequest; @class AWSIoTDescribeCertificateResponse; @class AWSIoTDescribeCustomMetricRequest; @class AWSIoTDescribeCustomMetricResponse; @class AWSIoTDescribeDefaultAuthorizerRequest; @class AWSIoTDescribeDefaultAuthorizerResponse; @class AWSIoTDescribeDetectMitigationActionsTaskRequest; @class AWSIoTDescribeDetectMitigationActionsTaskResponse; @class AWSIoTDescribeDimensionRequest; @class AWSIoTDescribeDimensionResponse; @class AWSIoTDescribeDomainConfigurationRequest; @class AWSIoTDescribeDomainConfigurationResponse; @class AWSIoTDescribeEndpointRequest; @class AWSIoTDescribeEndpointResponse; @class AWSIoTDescribeEventConfigurationsRequest; @class AWSIoTDescribeEventConfigurationsResponse; @class AWSIoTDescribeFleetMetricRequest; @class AWSIoTDescribeFleetMetricResponse; @class AWSIoTDescribeIndexRequest; @class AWSIoTDescribeIndexResponse; @class AWSIoTDescribeJobExecutionRequest; @class AWSIoTDescribeJobExecutionResponse; @class AWSIoTDescribeJobRequest; @class AWSIoTDescribeJobResponse; @class AWSIoTDescribeJobTemplateRequest; @class AWSIoTDescribeJobTemplateResponse; @class AWSIoTDescribeManagedJobTemplateRequest; @class AWSIoTDescribeManagedJobTemplateResponse; @class AWSIoTDescribeMitigationActionRequest; @class AWSIoTDescribeMitigationActionResponse; @class AWSIoTDescribeProvisioningTemplateRequest; @class AWSIoTDescribeProvisioningTemplateResponse; @class AWSIoTDescribeProvisioningTemplateVersionRequest; @class AWSIoTDescribeProvisioningTemplateVersionResponse; @class AWSIoTDescribeRoleAliasRequest; @class AWSIoTDescribeRoleAliasResponse; @class AWSIoTDescribeScheduledAuditRequest; @class AWSIoTDescribeScheduledAuditResponse; @class AWSIoTDescribeSecurityProfileRequest; @class AWSIoTDescribeSecurityProfileResponse; @class AWSIoTDescribeStreamRequest; @class AWSIoTDescribeStreamResponse; @class AWSIoTDescribeThingGroupRequest; @class AWSIoTDescribeThingGroupResponse; @class AWSIoTDescribeThingRegistrationTaskRequest; @class AWSIoTDescribeThingRegistrationTaskResponse; @class AWSIoTDescribeThingRequest; @class AWSIoTDescribeThingResponse; @class AWSIoTDescribeThingTypeRequest; @class AWSIoTDescribeThingTypeResponse; @class AWSIoTDestination; @class AWSIoTDetachPolicyRequest; @class AWSIoTDetachPrincipalPolicyRequest; @class AWSIoTDetachSecurityProfileRequest; @class AWSIoTDetachSecurityProfileResponse; @class AWSIoTDetachThingPrincipalRequest; @class AWSIoTDetachThingPrincipalResponse; @class AWSIoTDetectMitigationActionExecution; @class AWSIoTDetectMitigationActionsTaskStatistics; @class AWSIoTDetectMitigationActionsTaskSummary; @class AWSIoTDetectMitigationActionsTaskTarget; @class AWSIoTDisableTopicRuleRequest; @class AWSIoTDocumentParameter; @class AWSIoTDomainConfigurationSummary; @class AWSIoTDynamoDBAction; @class AWSIoTDynamoDBv2Action; @class AWSIoTEffectivePolicy; @class AWSIoTElasticsearchAction; @class AWSIoTEnableIoTLoggingParams; @class AWSIoTEnableTopicRuleRequest; @class AWSIoTErrorInfo; @class AWSIoTExplicitDeny; @class AWSIoTExponentialRolloutRate; @class AWSIoTField; @class AWSIoTFileLocation; @class AWSIoTFirehoseAction; @class AWSIoTFleetMetricNameAndArn; @class AWSIoTGetBehaviorModelTrainingSummariesRequest; @class AWSIoTGetBehaviorModelTrainingSummariesResponse; @class AWSIoTGetBucketsAggregationRequest; @class AWSIoTGetBucketsAggregationResponse; @class AWSIoTGetCardinalityRequest; @class AWSIoTGetCardinalityResponse; @class AWSIoTGetEffectivePoliciesRequest; @class AWSIoTGetEffectivePoliciesResponse; @class AWSIoTGetIndexingConfigurationRequest; @class AWSIoTGetIndexingConfigurationResponse; @class AWSIoTGetJobDocumentRequest; @class AWSIoTGetJobDocumentResponse; @class AWSIoTGetLoggingOptionsRequest; @class AWSIoTGetLoggingOptionsResponse; @class AWSIoTGetOTAUpdateRequest; @class AWSIoTGetOTAUpdateResponse; @class AWSIoTGetPackageConfigurationRequest; @class AWSIoTGetPackageConfigurationResponse; @class AWSIoTGetPackageRequest; @class AWSIoTGetPackageResponse; @class AWSIoTGetPackageVersionRequest; @class AWSIoTGetPackageVersionResponse; @class AWSIoTGetPercentilesRequest; @class AWSIoTGetPercentilesResponse; @class AWSIoTGetPolicyRequest; @class AWSIoTGetPolicyResponse; @class AWSIoTGetPolicyVersionRequest; @class AWSIoTGetPolicyVersionResponse; @class AWSIoTGetRegistrationCodeRequest; @class AWSIoTGetRegistrationCodeResponse; @class AWSIoTGetStatisticsRequest; @class AWSIoTGetStatisticsResponse; @class AWSIoTGetTopicRuleDestinationRequest; @class AWSIoTGetTopicRuleDestinationResponse; @class AWSIoTGetTopicRuleRequest; @class AWSIoTGetTopicRuleResponse; @class AWSIoTGetV2LoggingOptionsRequest; @class AWSIoTGetV2LoggingOptionsResponse; @class AWSIoTGroupNameAndArn; @class AWSIoTHttpAction; @class AWSIoTHttpActionHeader; @class AWSIoTHttpAuthorization; @class AWSIoTHttpContext; @class AWSIoTHttpUrlDestinationConfiguration; @class AWSIoTHttpUrlDestinationProperties; @class AWSIoTHttpUrlDestinationSummary; @class AWSIoTImplicitDeny; @class AWSIoTIndexingFilter; @class AWSIoTIotAnalyticsAction; @class AWSIoTIotEventsAction; @class AWSIoTIotSiteWiseAction; @class AWSIoTIssuerCertificateIdentifier; @class AWSIoTJob; @class AWSIoTJobExecution; @class AWSIoTJobExecutionStatusDetails; @class AWSIoTJobExecutionSummary; @class AWSIoTJobExecutionSummaryForJob; @class AWSIoTJobExecutionSummaryForThing; @class AWSIoTJobExecutionsRetryConfig; @class AWSIoTJobExecutionsRolloutConfig; @class AWSIoTJobProcessDetails; @class AWSIoTJobSummary; @class AWSIoTJobTemplateSummary; @class AWSIoTKafkaAction; @class AWSIoTKeyPair; @class AWSIoTKinesisAction; @class AWSIoTLambdaAction; @class AWSIoTListActiveViolationsRequest; @class AWSIoTListActiveViolationsResponse; @class AWSIoTListAttachedPoliciesRequest; @class AWSIoTListAttachedPoliciesResponse; @class AWSIoTListAuditFindingsRequest; @class AWSIoTListAuditFindingsResponse; @class AWSIoTListAuditMitigationActionsExecutionsRequest; @class AWSIoTListAuditMitigationActionsExecutionsResponse; @class AWSIoTListAuditMitigationActionsTasksRequest; @class AWSIoTListAuditMitigationActionsTasksResponse; @class AWSIoTListAuditSuppressionsRequest; @class AWSIoTListAuditSuppressionsResponse; @class AWSIoTListAuditTasksRequest; @class AWSIoTListAuditTasksResponse; @class AWSIoTListAuthorizersRequest; @class AWSIoTListAuthorizersResponse; @class AWSIoTListBillingGroupsRequest; @class AWSIoTListBillingGroupsResponse; @class AWSIoTListCACertificatesRequest; @class AWSIoTListCACertificatesResponse; @class AWSIoTListCertificatesByCARequest; @class AWSIoTListCertificatesByCAResponse; @class AWSIoTListCertificatesRequest; @class AWSIoTListCertificatesResponse; @class AWSIoTListCustomMetricsRequest; @class AWSIoTListCustomMetricsResponse; @class AWSIoTListDetectMitigationActionsExecutionsRequest; @class AWSIoTListDetectMitigationActionsExecutionsResponse; @class AWSIoTListDetectMitigationActionsTasksRequest; @class AWSIoTListDetectMitigationActionsTasksResponse; @class AWSIoTListDimensionsRequest; @class AWSIoTListDimensionsResponse; @class AWSIoTListDomainConfigurationsRequest; @class AWSIoTListDomainConfigurationsResponse; @class AWSIoTListFleetMetricsRequest; @class AWSIoTListFleetMetricsResponse; @class AWSIoTListIndicesRequest; @class AWSIoTListIndicesResponse; @class AWSIoTListJobExecutionsForJobRequest; @class AWSIoTListJobExecutionsForJobResponse; @class AWSIoTListJobExecutionsForThingRequest; @class AWSIoTListJobExecutionsForThingResponse; @class AWSIoTListJobTemplatesRequest; @class AWSIoTListJobTemplatesResponse; @class AWSIoTListJobsRequest; @class AWSIoTListJobsResponse; @class AWSIoTListManagedJobTemplatesRequest; @class AWSIoTListManagedJobTemplatesResponse; @class AWSIoTListMetricValuesRequest; @class AWSIoTListMetricValuesResponse; @class AWSIoTListMitigationActionsRequest; @class AWSIoTListMitigationActionsResponse; @class AWSIoTListOTAUpdatesRequest; @class AWSIoTListOTAUpdatesResponse; @class AWSIoTListOutgoingCertificatesRequest; @class AWSIoTListOutgoingCertificatesResponse; @class AWSIoTListPackageVersionsRequest; @class AWSIoTListPackageVersionsResponse; @class AWSIoTListPackagesRequest; @class AWSIoTListPackagesResponse; @class AWSIoTListPoliciesRequest; @class AWSIoTListPoliciesResponse; @class AWSIoTListPolicyPrincipalsRequest; @class AWSIoTListPolicyPrincipalsResponse; @class AWSIoTListPolicyVersionsRequest; @class AWSIoTListPolicyVersionsResponse; @class AWSIoTListPrincipalPoliciesRequest; @class AWSIoTListPrincipalPoliciesResponse; @class AWSIoTListPrincipalThingsRequest; @class AWSIoTListPrincipalThingsResponse; @class AWSIoTListProvisioningTemplateVersionsRequest; @class AWSIoTListProvisioningTemplateVersionsResponse; @class AWSIoTListProvisioningTemplatesRequest; @class AWSIoTListProvisioningTemplatesResponse; @class AWSIoTListRelatedResourcesForAuditFindingRequest; @class AWSIoTListRelatedResourcesForAuditFindingResponse; @class AWSIoTListRoleAliasesRequest; @class AWSIoTListRoleAliasesResponse; @class AWSIoTListScheduledAuditsRequest; @class AWSIoTListScheduledAuditsResponse; @class AWSIoTListSecurityProfilesForTargetRequest; @class AWSIoTListSecurityProfilesForTargetResponse; @class AWSIoTListSecurityProfilesRequest; @class AWSIoTListSecurityProfilesResponse; @class AWSIoTListStreamsRequest; @class AWSIoTListStreamsResponse; @class AWSIoTListTagsForResourceRequest; @class AWSIoTListTagsForResourceResponse; @class AWSIoTListTargetsForPolicyRequest; @class AWSIoTListTargetsForPolicyResponse; @class AWSIoTListTargetsForSecurityProfileRequest; @class AWSIoTListTargetsForSecurityProfileResponse; @class AWSIoTListThingGroupsForThingRequest; @class AWSIoTListThingGroupsForThingResponse; @class AWSIoTListThingGroupsRequest; @class AWSIoTListThingGroupsResponse; @class AWSIoTListThingPrincipalsRequest; @class AWSIoTListThingPrincipalsResponse; @class AWSIoTListThingRegistrationTaskReportsRequest; @class AWSIoTListThingRegistrationTaskReportsResponse; @class AWSIoTListThingRegistrationTasksRequest; @class AWSIoTListThingRegistrationTasksResponse; @class AWSIoTListThingTypesRequest; @class AWSIoTListThingTypesResponse; @class AWSIoTListThingsInBillingGroupRequest; @class AWSIoTListThingsInBillingGroupResponse; @class AWSIoTListThingsInThingGroupRequest; @class AWSIoTListThingsInThingGroupResponse; @class AWSIoTListThingsRequest; @class AWSIoTListThingsResponse; @class AWSIoTListTopicRuleDestinationsRequest; @class AWSIoTListTopicRuleDestinationsResponse; @class AWSIoTListTopicRulesRequest; @class AWSIoTListTopicRulesResponse; @class AWSIoTListV2LoggingLevelsRequest; @class AWSIoTListV2LoggingLevelsResponse; @class AWSIoTListViolationEventsRequest; @class AWSIoTListViolationEventsResponse; @class AWSIoTLocationAction; @class AWSIoTLocationTimestamp; @class AWSIoTLogTarget; @class AWSIoTLogTargetConfiguration; @class AWSIoTLoggingOptionsPayload; @class AWSIoTMachineLearningDetectionConfig; @class AWSIoTMaintenanceWindow; @class AWSIoTManagedJobTemplateSummary; @class AWSIoTMetricDatum; @class AWSIoTMetricDimension; @class AWSIoTMetricToRetain; @class AWSIoTMetricValue; @class AWSIoTMitigationAction; @class AWSIoTMitigationActionIdentifier; @class AWSIoTMitigationActionParams; @class AWSIoTMqttContext; @class AWSIoTMqttHeaders; @class AWSIoTNonCompliantResource; @class AWSIoTOTAUpdateFile; @class AWSIoTOTAUpdateInfo; @class AWSIoTOTAUpdateSummary; @class AWSIoTOpenSearchAction; @class AWSIoTOutgoingCertificate; @class AWSIoTPackageSummary; @class AWSIoTPackageVersionSummary; @class AWSIoTPercentPair; @class AWSIoTPolicy; @class AWSIoTPolicyVersion; @class AWSIoTPolicyVersionIdentifier; @class AWSIoTPresignedUrlConfig; @class AWSIoTProvisioningHook; @class AWSIoTProvisioningTemplateSummary; @class AWSIoTProvisioningTemplateVersionSummary; @class AWSIoTPublishFindingToSnsParams; @class AWSIoTPutAssetPropertyValueEntry; @class AWSIoTPutItemInput; @class AWSIoTPutVerificationStateOnViolationRequest; @class AWSIoTPutVerificationStateOnViolationResponse; @class AWSIoTRateIncreaseCriteria; @class AWSIoTRegisterCACertificateRequest; @class AWSIoTRegisterCACertificateResponse; @class AWSIoTRegisterCertificateRequest; @class AWSIoTRegisterCertificateResponse; @class AWSIoTRegisterCertificateWithoutCARequest; @class AWSIoTRegisterCertificateWithoutCAResponse; @class AWSIoTRegisterThingRequest; @class AWSIoTRegisterThingResponse; @class AWSIoTRegistrationConfig; @class AWSIoTRejectCertificateTransferRequest; @class AWSIoTRelatedResource; @class AWSIoTRemoveThingFromBillingGroupRequest; @class AWSIoTRemoveThingFromBillingGroupResponse; @class AWSIoTRemoveThingFromThingGroupRequest; @class AWSIoTRemoveThingFromThingGroupResponse; @class AWSIoTReplaceDefaultPolicyVersionParams; @class AWSIoTReplaceTopicRuleRequest; @class AWSIoTRepublishAction; @class AWSIoTResourceIdentifier; @class AWSIoTRetryCriteria; @class AWSIoTRoleAliasDescription; @class AWSIoTS3Action; @class AWSIoTS3Destination; @class AWSIoTS3Location; @class AWSIoTSalesforceAction; @class AWSIoTScheduledAuditMetadata; @class AWSIoTScheduledJobRollout; @class AWSIoTSchedulingConfig; @class AWSIoTSearchIndexRequest; @class AWSIoTSearchIndexResponse; @class AWSIoTSecurityProfileIdentifier; @class AWSIoTSecurityProfileTarget; @class AWSIoTSecurityProfileTargetMapping; @class AWSIoTServerCertificateSummary; @class AWSIoTSetDefaultAuthorizerRequest; @class AWSIoTSetDefaultAuthorizerResponse; @class AWSIoTSetDefaultPolicyVersionRequest; @class AWSIoTSetLoggingOptionsRequest; @class AWSIoTSetV2LoggingLevelRequest; @class AWSIoTSetV2LoggingOptionsRequest; @class AWSIoTSigV4Authorization; @class AWSIoTSigningProfileParameter; @class AWSIoTSnsAction; @class AWSIoTSqsAction; @class AWSIoTStartAuditMitigationActionsTaskRequest; @class AWSIoTStartAuditMitigationActionsTaskResponse; @class AWSIoTStartDetectMitigationActionsTaskRequest; @class AWSIoTStartDetectMitigationActionsTaskResponse; @class AWSIoTStartOnDemandAuditTaskRequest; @class AWSIoTStartOnDemandAuditTaskResponse; @class AWSIoTStartSigningJobParameter; @class AWSIoTStartThingRegistrationTaskRequest; @class AWSIoTStartThingRegistrationTaskResponse; @class AWSIoTStatisticalThreshold; @class AWSIoTStatistics; @class AWSIoTStepFunctionsAction; @class AWSIoTStopThingRegistrationTaskRequest; @class AWSIoTStopThingRegistrationTaskResponse; @class AWSIoTStream; @class AWSIoTStreamFile; @class AWSIoTStreamInfo; @class AWSIoTStreamSummary; @class AWSIoTTag; @class AWSIoTTagResourceRequest; @class AWSIoTTagResourceResponse; @class AWSIoTTaskStatistics; @class AWSIoTTaskStatisticsForAuditCheck; @class AWSIoTTermsAggregation; @class AWSIoTTestAuthorizationRequest; @class AWSIoTTestAuthorizationResponse; @class AWSIoTTestInvokeAuthorizerRequest; @class AWSIoTTestInvokeAuthorizerResponse; @class AWSIoTThingAttribute; @class AWSIoTThingConnectivity; @class AWSIoTThingDocument; @class AWSIoTThingGroupDocument; @class AWSIoTThingGroupIndexingConfiguration; @class AWSIoTThingGroupMetadata; @class AWSIoTThingGroupProperties; @class AWSIoTThingIndexingConfiguration; @class AWSIoTThingTypeDefinition; @class AWSIoTThingTypeMetadata; @class AWSIoTThingTypeProperties; @class AWSIoTTimeoutConfig; @class AWSIoTTimestreamAction; @class AWSIoTTimestreamDimension; @class AWSIoTTimestreamTimestamp; @class AWSIoTTlsConfig; @class AWSIoTTlsContext; @class AWSIoTTopicRule; @class AWSIoTTopicRuleDestination; @class AWSIoTTopicRuleDestinationConfiguration; @class AWSIoTTopicRuleDestinationSummary; @class AWSIoTTopicRuleListItem; @class AWSIoTTopicRulePayload; @class AWSIoTTransferCertificateRequest; @class AWSIoTTransferCertificateResponse; @class AWSIoTTransferData; @class AWSIoTUntagResourceRequest; @class AWSIoTUntagResourceResponse; @class AWSIoTUpdateAccountAuditConfigurationRequest; @class AWSIoTUpdateAccountAuditConfigurationResponse; @class AWSIoTUpdateAuditSuppressionRequest; @class AWSIoTUpdateAuditSuppressionResponse; @class AWSIoTUpdateAuthorizerRequest; @class AWSIoTUpdateAuthorizerResponse; @class AWSIoTUpdateBillingGroupRequest; @class AWSIoTUpdateBillingGroupResponse; @class AWSIoTUpdateCACertificateParams; @class AWSIoTUpdateCACertificateRequest; @class AWSIoTUpdateCertificateRequest; @class AWSIoTUpdateCustomMetricRequest; @class AWSIoTUpdateCustomMetricResponse; @class AWSIoTUpdateDeviceCertificateParams; @class AWSIoTUpdateDimensionRequest; @class AWSIoTUpdateDimensionResponse; @class AWSIoTUpdateDomainConfigurationRequest; @class AWSIoTUpdateDomainConfigurationResponse; @class AWSIoTUpdateDynamicThingGroupRequest; @class AWSIoTUpdateDynamicThingGroupResponse; @class AWSIoTUpdateEventConfigurationsRequest; @class AWSIoTUpdateEventConfigurationsResponse; @class AWSIoTUpdateFleetMetricRequest; @class AWSIoTUpdateIndexingConfigurationRequest; @class AWSIoTUpdateIndexingConfigurationResponse; @class AWSIoTUpdateJobRequest; @class AWSIoTUpdateMitigationActionRequest; @class AWSIoTUpdateMitigationActionResponse; @class AWSIoTUpdatePackageConfigurationRequest; @class AWSIoTUpdatePackageConfigurationResponse; @class AWSIoTUpdatePackageRequest; @class AWSIoTUpdatePackageResponse; @class AWSIoTUpdatePackageVersionRequest; @class AWSIoTUpdatePackageVersionResponse; @class AWSIoTUpdateProvisioningTemplateRequest; @class AWSIoTUpdateProvisioningTemplateResponse; @class AWSIoTUpdateRoleAliasRequest; @class AWSIoTUpdateRoleAliasResponse; @class AWSIoTUpdateScheduledAuditRequest; @class AWSIoTUpdateScheduledAuditResponse; @class AWSIoTUpdateSecurityProfileRequest; @class AWSIoTUpdateSecurityProfileResponse; @class AWSIoTUpdateStreamRequest; @class AWSIoTUpdateStreamResponse; @class AWSIoTUpdateThingGroupRequest; @class AWSIoTUpdateThingGroupResponse; @class AWSIoTUpdateThingGroupsForThingRequest; @class AWSIoTUpdateThingGroupsForThingResponse; @class AWSIoTUpdateThingRequest; @class AWSIoTUpdateThingResponse; @class AWSIoTUpdateTopicRuleDestinationRequest; @class AWSIoTUpdateTopicRuleDestinationResponse; @class AWSIoTUserProperty; @class AWSIoTValidateSecurityProfileBehaviorsRequest; @class AWSIoTValidateSecurityProfileBehaviorsResponse; @class AWSIoTValidationError; @class AWSIoTVersionUpdateByJobsConfig; @class AWSIoTViolationEvent; @class AWSIoTViolationEventAdditionalInfo; @class AWSIoTViolationEventOccurrenceRange; @class AWSIoTVpcDestinationConfiguration; @class AWSIoTVpcDestinationProperties; @class AWSIoTVpcDestinationSummary; /**

The criteria that determine when and how a job abort takes place.

Required parameters: [criteriaList] */ @interface AWSIoTAbortConfig : AWSModel /**

The list of criteria that determine when and how to abort the job.

*/ @property (nonatomic, strong) NSArray * _Nullable criteriaList; @end /**

The criteria that determine when and how a job abort takes place.

Required parameters: [failureType, action, thresholdPercentage, minNumberOfExecutedThings] */ @interface AWSIoTAbortCriteria : AWSModel /**

The type of job action to take to initiate the job abort.

*/ @property (nonatomic, assign) AWSIoTAbortAction action; /**

The type of job execution failures that can initiate a job abort.

*/ @property (nonatomic, assign) AWSIoTJobExecutionFailureType failureType; /**

The minimum number of things which must receive job execution notifications before the job can be aborted.

*/ @property (nonatomic, strong) NSNumber * _Nullable minNumberOfExecutedThings; /**

The minimum percentage of job execution failures that must occur to initiate the job abort.

Amazon Web Services IoT Core supports up to two digits after the decimal (for example, 10.9 and 10.99, but not 10.999).

*/ @property (nonatomic, strong) NSNumber * _Nullable thresholdPercentage; @end /**

The input for the AcceptCertificateTransfer operation.

Required parameters: [certificateId] */ @interface AWSIoTAcceptCertificateTransferRequest : AWSRequest /**

The ID of the certificate. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

Specifies whether the certificate is active.

*/ @property (nonatomic, strong) NSNumber * _Nullable setAsActive; @end /**

Describes the actions associated with a rule.

*/ @interface AWSIoTAction : AWSModel /**

Change the state of a CloudWatch alarm.

*/ @property (nonatomic, strong) AWSIoTCloudwatchAlarmAction * _Nullable cloudwatchAlarm; /**

Send data to CloudWatch Logs.

*/ @property (nonatomic, strong) AWSIoTCloudwatchLogsAction * _Nullable cloudwatchLogs; /**

Capture a CloudWatch metric.

*/ @property (nonatomic, strong) AWSIoTCloudwatchMetricAction * _Nullable cloudwatchMetric; /**

Write to a DynamoDB table.

*/ @property (nonatomic, strong) AWSIoTDynamoDBAction * _Nullable dynamoDB; /**

Write to a DynamoDB table. This is a new version of the DynamoDB action. It allows you to write each attribute in an MQTT message payload into a separate DynamoDB column.

*/ @property (nonatomic, strong) AWSIoTDynamoDBv2Action * _Nullable dynamoDBv2; /**

Write data to an Amazon OpenSearch Service domain.

The Elasticsearch action can only be used by existing rule actions. To create a new rule action or to update an existing rule action, use the OpenSearch rule action instead. For more information, see OpenSearchAction.

*/ @property (nonatomic, strong) AWSIoTElasticsearchAction * _Nullable elasticsearch; /**

Write to an Amazon Kinesis Firehose stream.

*/ @property (nonatomic, strong) AWSIoTFirehoseAction * _Nullable firehose; /**

Send data to an HTTPS endpoint.

*/ @property (nonatomic, strong) AWSIoTHttpAction * _Nullable http; /**

Sends message data to an IoT Analytics channel.

*/ @property (nonatomic, strong) AWSIoTIotAnalyticsAction * _Nullable iotAnalytics; /**

Sends an input to an IoT Events detector.

*/ @property (nonatomic, strong) AWSIoTIotEventsAction * _Nullable iotEvents; /**

Sends data from the MQTT message that triggered the rule to IoT SiteWise asset properties.

*/ @property (nonatomic, strong) AWSIoTIotSiteWiseAction * _Nullable iotSiteWise; /**

Send messages to an Amazon Managed Streaming for Apache Kafka (Amazon MSK) or self-managed Apache Kafka cluster.

*/ @property (nonatomic, strong) AWSIoTKafkaAction * _Nullable kafka; /**

Write data to an Amazon Kinesis stream.

*/ @property (nonatomic, strong) AWSIoTKinesisAction * _Nullable kinesis; /**

Invoke a Lambda function.

*/ @property (nonatomic, strong) AWSIoTLambdaAction * _Nullable lambda; /**

The Amazon Location Service rule action sends device location updates from an MQTT message to an Amazon Location tracker resource.

*/ @property (nonatomic, strong) AWSIoTLocationAction * _Nullable location; /**

Write data to an Amazon OpenSearch Service domain.

*/ @property (nonatomic, strong) AWSIoTOpenSearchAction * _Nullable openSearch; /**

Publish to another MQTT topic.

*/ @property (nonatomic, strong) AWSIoTRepublishAction * _Nullable republish; /**

Write to an Amazon S3 bucket.

*/ @property (nonatomic, strong) AWSIoTS3Action * _Nullable s3; /**

Send a message to a Salesforce IoT Cloud Input Stream.

*/ @property (nonatomic, strong) AWSIoTSalesforceAction * _Nullable salesforce; /**

Publish to an Amazon SNS topic.

*/ @property (nonatomic, strong) AWSIoTSnsAction * _Nullable sns; /**

Publish to an Amazon SQS queue.

*/ @property (nonatomic, strong) AWSIoTSqsAction * _Nullable sqs; /**

Starts execution of a Step Functions state machine.

*/ @property (nonatomic, strong) AWSIoTStepFunctionsAction * _Nullable stepFunctions; /**

The Timestream rule action writes attributes (measures) from an MQTT message into an Amazon Timestream table. For more information, see the Timestream topic rule action documentation.

*/ @property (nonatomic, strong) AWSIoTTimestreamAction * _Nullable timestream; @end /**

Information about an active Device Defender security profile behavior violation.

*/ @interface AWSIoTActiveViolation : AWSModel /**

The behavior that is being violated.

*/ @property (nonatomic, strong) AWSIoTBehavior * _Nullable behavior; /**

The time the most recent violation occurred.

*/ @property (nonatomic, strong) NSDate * _Nullable lastViolationTime; /**

The value of the metric (the measurement) that caused the most recent violation.

*/ @property (nonatomic, strong) AWSIoTMetricValue * _Nullable lastViolationValue; /**

The security profile with the behavior is in violation.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The name of the thing responsible for the active violation.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The verification state of the violation (detect alarm).

*/ @property (nonatomic, assign) AWSIoTVerificationState verificationState; /**

The description of the verification state of the violation.

*/ @property (nonatomic, strong) NSString * _Nullable verificationStateDescription; /**

The details of a violation event.

*/ @property (nonatomic, strong) AWSIoTViolationEventAdditionalInfo * _Nullable violationEventAdditionalInfo; /**

The ID of the active violation.

*/ @property (nonatomic, strong) NSString * _Nullable violationId; /**

The time the violation started.

*/ @property (nonatomic, strong) NSDate * _Nullable violationStartTime; @end /** */ @interface AWSIoTAddThingToBillingGroupRequest : AWSRequest /**

The ARN of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupArn; /**

The name of the billing group.

This call is asynchronous. It might take several seconds for the detachment to propagate.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The ARN of the thing to be added to the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; /**

The name of the thing to be added to the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTAddThingToBillingGroupResponse : AWSModel @end /** */ @interface AWSIoTAddThingToThingGroupRequest : AWSRequest /**

Override dynamic thing groups with static thing groups when 10-group limit is reached. If a thing belongs to 10 thing groups, and one or more of those groups are dynamic thing groups, adding a thing to a static group removes the thing from the last dynamic group.

*/ @property (nonatomic, strong) NSNumber * _Nullable overrideDynamicGroups; /**

The ARN of the thing to add to a group.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; /**

The ARN of the group to which you are adding a thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupArn; /**

The name of the group to which you are adding a thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; /**

The name of the thing to add to a group.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTAddThingToThingGroupResponse : AWSModel @end /**

Parameters used when defining a mitigation action that move a set of things to a thing group.

Required parameters: [thingGroupNames] */ @interface AWSIoTAddThingsToThingGroupParams : AWSModel /**

Specifies if this mitigation action can move the things that triggered the mitigation action even if they are part of one or more dynamic thing groups.

*/ @property (nonatomic, strong) NSNumber * _Nullable overrideDynamicGroups; /**

The list of groups to which you want to add the things that triggered the mitigation action. You can add a thing to a maximum of 10 groups, but you can't add a thing to more than one group in the same hierarchy.

*/ @property (nonatomic, strong) NSArray * _Nullable thingGroupNames; @end /**

The type of aggregation queries.

Required parameters: [name] */ @interface AWSIoTAggregationType : AWSModel /**

The name of the aggregation type.

*/ @property (nonatomic, assign) AWSIoTAggregationTypeName name; /**

A list of the values of aggregation types.

*/ @property (nonatomic, strong) NSArray * _Nullable values; @end /**

A structure containing the alert target ARN and the role ARN.

Required parameters: [alertTargetArn, roleArn] */ @interface AWSIoTAlertTarget : AWSModel /**

The Amazon Resource Name (ARN) of the notification target to which alerts are sent.

*/ @property (nonatomic, strong) NSString * _Nullable alertTargetArn; /**

The ARN of the role that grants permission to send alerts to the notification target.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Contains information that allowed the authorization.

*/ @interface AWSIoTAllowed : AWSModel /**

A list of policies that allowed the authentication.

*/ @property (nonatomic, strong) NSArray * _Nullable policies; @end /**

An asset property timestamp entry containing the following information.

Required parameters: [timeInSeconds] */ @interface AWSIoTAssetPropertyTimestamp : AWSModel /**

Optional. A string that contains the nanosecond time offset. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable offsetInNanos; /**

A string that contains the time in seconds since epoch. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable timeInSeconds; @end /**

An asset property value entry containing the following information.

Required parameters: [value, timestamp] */ @interface AWSIoTAssetPropertyValue : AWSModel /**

Optional. A string that describes the quality of the value. Accepts substitution templates. Must be GOOD, BAD, or UNCERTAIN.

*/ @property (nonatomic, strong) NSString * _Nullable quality; /**

The asset property value timestamp.

*/ @property (nonatomic, strong) AWSIoTAssetPropertyTimestamp * _Nullable timestamp; /**

The value of the asset property.

*/ @property (nonatomic, strong) AWSIoTAssetPropertyVariant * _Nullable value; @end /**

Contains an asset property value (of a single type).

*/ @interface AWSIoTAssetPropertyVariant : AWSModel /**

Optional. A string that contains the boolean value (true or false) of the value entry. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable booleanValueProperty; /**

Optional. A string that contains the double value of the value entry. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable doubleValueProperty; /**

Optional. A string that contains the integer value of the value entry. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable integerValueProperty; /**

Optional. The string value of the value entry. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable stringValueProperty; @end /** */ @interface AWSIoTAssociateTargetsWithJobRequest : AWSRequest /**

An optional comment string describing why the job was associated with the targets.

*/ @property (nonatomic, strong) NSString * _Nullable comment; /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The namespace used to indicate that a job is a customer-managed job.

When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.

$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/

The namespaceId feature is in public preview.

*/ @property (nonatomic, strong) NSString * _Nullable namespaceId; /**

A list of thing group ARNs that define the targets of the job.

*/ @property (nonatomic, strong) NSArray * _Nullable targets; @end /** */ @interface AWSIoTAssociateTargetsWithJobResponse : AWSModel /**

A short text description of the job.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

An ARN identifying the job.

*/ @property (nonatomic, strong) NSString * _Nullable jobArn; /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; @end /** */ @interface AWSIoTAttachPolicyRequest : AWSRequest /**

The name of the policy to attach.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The identity to which the policy is attached. For example, a thing group or a certificate.

*/ @property (nonatomic, strong) NSString * _Nullable target; @end /**

The input for the AttachPrincipalPolicy operation.

Required parameters: [policyName, principal] */ @interface AWSIoTAttachPrincipalPolicyRequest : AWSRequest /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The principal, which can be a certificate ARN (as returned from the CreateCertificate operation) or an Amazon Cognito ID.

*/ @property (nonatomic, strong) NSString * _Nullable principal; @end /** */ @interface AWSIoTAttachSecurityProfileRequest : AWSRequest /**

The security profile that is attached.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The ARN of the target (thing group) to which the security profile is attached.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileTargetArn; @end /** */ @interface AWSIoTAttachSecurityProfileResponse : AWSModel @end /**

The input for the AttachThingPrincipal operation.

Required parameters: [thingName, principal] */ @interface AWSIoTAttachThingPrincipalRequest : AWSRequest /**

The principal, which can be a certificate ARN (as returned from the CreateCertificate operation) or an Amazon Cognito ID.

*/ @property (nonatomic, strong) NSString * _Nullable principal; /**

The name of the thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /**

The output from the AttachThingPrincipal operation.

*/ @interface AWSIoTAttachThingPrincipalResponse : AWSModel @end /**

The attribute payload.

*/ @interface AWSIoTAttributePayload : AWSModel /**

A JSON string containing up to three key-value pair in JSON format. For example:

{\"attributes\":{\"string1\":\"string2\"}}

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

Specifies whether the list of attributes provided in the AttributePayload is merged with the attributes stored in the registry, instead of overwriting them.

To remove an attribute, call UpdateThing with an empty attribute value.

The merge attribute is only valid when calling UpdateThing or UpdateThingGroup.

*/ @property (nonatomic, strong) NSNumber * _Nullable merge; @end /**

Which audit checks are enabled and disabled for this account.

*/ @interface AWSIoTAuditCheckConfiguration : AWSModel /**

True if this audit check is enabled for this account.

*/ @property (nonatomic, strong) NSNumber * _Nullable enabled; @end /**

Information about the audit check.

*/ @interface AWSIoTAuditCheckDetails : AWSModel /**

True if the check is complete and found all resources compliant.

*/ @property (nonatomic, strong) NSNumber * _Nullable checkCompliant; /**

The completion status of this check. One of "IN_PROGRESS", "WAITING_FOR_DATA_COLLECTION", "CANCELED", "COMPLETED_COMPLIANT", "COMPLETED_NON_COMPLIANT", or "FAILED".

*/ @property (nonatomic, assign) AWSIoTAuditCheckRunStatus checkRunStatus; /**

The code of any error encountered when this check is performed during this audit. One of "INSUFFICIENT_PERMISSIONS" or "AUDIT_CHECK_DISABLED".

*/ @property (nonatomic, strong) NSString * _Nullable errorCode; /**

The message associated with any error encountered when this check is performed during this audit.

*/ @property (nonatomic, strong) NSString * _Nullable message; /**

The number of resources that were found noncompliant during the check.

*/ @property (nonatomic, strong) NSNumber * _Nullable nonCompliantResourcesCount; /**

Describes how many of the non-compliant resources created during the evaluation of an audit check were marked as suppressed.

*/ @property (nonatomic, strong) NSNumber * _Nullable suppressedNonCompliantResourcesCount; /**

The number of resources on which the check was performed.

*/ @property (nonatomic, strong) NSNumber * _Nullable totalResourcesCount; @end /**

The findings (results) of the audit.

*/ @interface AWSIoTAuditFinding : AWSModel /**

The audit check that generated this result.

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

A unique identifier for this set of audit findings. This identifier is used to apply mitigation tasks to one or more sets of findings.

*/ @property (nonatomic, strong) NSString * _Nullable findingId; /**

The time the result (finding) was discovered.

*/ @property (nonatomic, strong) NSDate * _Nullable findingTime; /**

Indicates whether the audit finding was suppressed or not during reporting.

*/ @property (nonatomic, strong) NSNumber * _Nullable isSuppressed; /**

The resource that was found to be noncompliant with the audit check.

*/ @property (nonatomic, strong) AWSIoTNonCompliantResource * _Nullable nonCompliantResource; /**

The reason the resource was noncompliant.

*/ @property (nonatomic, strong) NSString * _Nullable reasonForNonCompliance; /**

A code that indicates the reason that the resource was noncompliant.

*/ @property (nonatomic, strong) NSString * _Nullable reasonForNonComplianceCode; /**

The list of related resources.

*/ @property (nonatomic, strong) NSArray * _Nullable relatedResources; /**

The severity of the result (finding).

*/ @property (nonatomic, assign) AWSIoTAuditFindingSeverity severity; /**

The ID of the audit that generated this result (finding).

*/ @property (nonatomic, strong) NSString * _Nullable taskId; /**

The time the audit started.

*/ @property (nonatomic, strong) NSDate * _Nullable taskStartTime; @end /**

Returned by ListAuditMitigationActionsTask, this object contains information that describes a mitigation action that has been started.

*/ @interface AWSIoTAuditMitigationActionExecutionMetadata : AWSModel /**

The unique identifier for the mitigation action being applied by the task.

*/ @property (nonatomic, strong) NSString * _Nullable actionId; /**

The friendly name of the mitigation action being applied by the task.

*/ @property (nonatomic, strong) NSString * _Nullable actionName; /**

The date and time when the task was completed or canceled. Blank if the task is still running.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

If an error occurred, the code that indicates which type of error occurred.

*/ @property (nonatomic, strong) NSString * _Nullable errorCode; /**

The unique identifier for the findings to which the task and associated mitigation action are applied.

*/ @property (nonatomic, strong) NSString * _Nullable findingId; /**

If an error occurred, a message that describes the error.

*/ @property (nonatomic, strong) NSString * _Nullable message; /**

The date and time when the task was started.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

The current status of the task being executed.

*/ @property (nonatomic, assign) AWSIoTAuditMitigationActionsExecutionStatus status; /**

The unique identifier for the task that applies the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /**

Information about an audit mitigation actions task that is returned by ListAuditMitigationActionsTasks.

*/ @interface AWSIoTAuditMitigationActionsTaskMetadata : AWSModel /**

The time at which the audit mitigation actions task was started.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

The unique identifier for the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; /**

The current state of the audit mitigation actions task.

*/ @property (nonatomic, assign) AWSIoTAuditMitigationActionsTaskStatus taskStatus; @end /**

Used in MitigationActionParams, this information identifies the target findings to which the mitigation actions are applied. Only one entry appears.

*/ @interface AWSIoTAuditMitigationActionsTaskTarget : AWSModel /**

Specifies a filter in the form of an audit check and set of reason codes that identify the findings from the audit to which the audit mitigation actions task apply.

*/ @property (nonatomic, strong) NSDictionary *> * _Nullable auditCheckToReasonCodeFilter; /**

If the task will apply a mitigation action to findings from a specific audit, this value uniquely identifies the audit.

*/ @property (nonatomic, strong) NSString * _Nullable auditTaskId; /**

If the task will apply a mitigation action to one or more listed findings, this value uniquely identifies those findings.

*/ @property (nonatomic, strong) NSArray * _Nullable findingIds; @end /**

Information about the targets to which audit notifications are sent.

*/ @interface AWSIoTAuditNotificationTarget : AWSModel /**

True if notifications to the target are enabled.

*/ @property (nonatomic, strong) NSNumber * _Nullable enabled; /**

The ARN of the role that grants permission to send notifications to the target.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The ARN of the target (SNS topic) to which audit notifications are sent.

*/ @property (nonatomic, strong) NSString * _Nullable targetArn; @end /**

Filters out specific findings of a Device Defender audit.

Required parameters: [checkName, resourceIdentifier] */ @interface AWSIoTAuditSuppression : AWSModel /**

An audit check name. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

The description of the audit suppression.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The expiration date (epoch timestamp in seconds) that you want the suppression to adhere to.

*/ @property (nonatomic, strong) NSDate * _Nullable expirationDate; /**

Information that identifies the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; /**

Indicates whether a suppression should exist indefinitely or not.

*/ @property (nonatomic, strong) NSNumber * _Nullable suppressIndefinitely; @end /**

The audits that were performed.

*/ @interface AWSIoTAuditTaskMetadata : AWSModel /**

The ID of this audit.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; /**

The status of this audit. One of "IN_PROGRESS", "COMPLETED", "FAILED", or "CANCELED".

*/ @property (nonatomic, assign) AWSIoTAuditTaskStatus taskStatus; /**

The type of this audit. One of "ON_DEMAND_AUDIT_TASK" or "SCHEDULED_AUDIT_TASK".

*/ @property (nonatomic, assign) AWSIoTAuditTaskType taskType; @end /**

A collection of authorization information.

Required parameters: [resources] */ @interface AWSIoTAuthInfo : AWSModel /**

The type of action for which the principal is being authorized.

*/ @property (nonatomic, assign) AWSIoTActionType actionType; /**

The resources for which the principal is being authorized to perform the specified action.

*/ @property (nonatomic, strong) NSArray * _Nullable resources; @end /**

The authorizer result.

*/ @interface AWSIoTAuthResult : AWSModel /**

The policies and statements that allowed the specified action.

*/ @property (nonatomic, strong) AWSIoTAllowed * _Nullable allowed; /**

The final authorization decision of this scenario. Multiple statements are taken into account when determining the authorization decision. An explicit deny statement can override multiple allow statements.

*/ @property (nonatomic, assign) AWSIoTAuthDecision authDecision; /**

Authorization information.

*/ @property (nonatomic, strong) AWSIoTAuthInfo * _Nullable authInfo; /**

The policies and statements that denied the specified action.

*/ @property (nonatomic, strong) AWSIoTDenied * _Nullable denied; /**

Contains any missing context values found while evaluating policy.

*/ @property (nonatomic, strong) NSArray * _Nullable missingContextValues; @end /**

An object that specifies the authorization service for a domain.

*/ @interface AWSIoTAuthorizerConfig : AWSModel /**

A Boolean that specifies whether the domain configuration's authorization service can be overridden.

*/ @property (nonatomic, strong) NSNumber * _Nullable allowAuthorizerOverride; /**

The name of the authorization service for a domain configuration.

*/ @property (nonatomic, strong) NSString * _Nullable defaultAuthorizerName; @end /**

The authorizer description.

*/ @interface AWSIoTAuthorizerDescription : AWSModel /**

The authorizer ARN.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerArn; /**

The authorizer's Lambda function ARN.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerFunctionArn; /**

The authorizer name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; /**

The UNIX timestamp of when the authorizer was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

When true, the result from the authorizer’s Lambda function is cached for the time specified in refreshAfterInSeconds. The cached result is used while the device reuses the same HTTP connection.

*/ @property (nonatomic, strong) NSNumber * _Nullable enableCachingForHttp; /**

The UNIX timestamp of when the authorizer was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

Specifies whether IoT validates the token signature in an authorization request.

*/ @property (nonatomic, strong) NSNumber * _Nullable signingDisabled; /**

The status of the authorizer.

*/ @property (nonatomic, assign) AWSIoTAuthorizerStatus status; /**

The key used to extract the token from the HTTP headers.

*/ @property (nonatomic, strong) NSString * _Nullable tokenKeyName; /**

The public keys used to validate the token signature returned by your custom authentication service.

*/ @property (nonatomic, strong) NSDictionary * _Nullable tokenSigningPublicKeys; @end /**

The authorizer summary.

*/ @interface AWSIoTAuthorizerSummary : AWSModel /**

The authorizer ARN.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerArn; /**

The authorizer name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; @end /**

The criteria that determine when and how a job abort takes place.

Required parameters: [abortCriteriaList] */ @interface AWSIoTAwsJobAbortConfig : AWSModel /**

The list of criteria that determine when and how to abort the job.

*/ @property (nonatomic, strong) NSArray * _Nullable abortCriteriaList; @end /**

The criteria that determine when and how a job abort takes place.

Required parameters: [failureType, action, thresholdPercentage, minNumberOfExecutedThings] */ @interface AWSIoTAwsJobAbortCriteria : AWSModel /**

The type of job action to take to initiate the job abort.

*/ @property (nonatomic, assign) AWSIoTAwsJobAbortCriteriaAbortAction action; /**

The type of job execution failures that can initiate a job abort.

*/ @property (nonatomic, assign) AWSIoTAwsJobAbortCriteriaFailureType failureType; /**

The minimum number of things which must receive job execution notifications before the job can be aborted.

*/ @property (nonatomic, strong) NSNumber * _Nullable minNumberOfExecutedThings; /**

The minimum percentage of job execution failures that must occur to initiate the job abort.

Amazon Web Services IoT Core supports up to two digits after the decimal (for example, 10.9 and 10.99, but not 10.999).

*/ @property (nonatomic, strong) NSNumber * _Nullable thresholdPercentage; @end /**

Configuration for the rollout of OTA updates.

*/ @interface AWSIoTAwsJobExecutionsRolloutConfig : AWSModel /**

The rate of increase for a job rollout. This parameter allows you to define an exponential rate increase for a job rollout.

*/ @property (nonatomic, strong) AWSIoTAwsJobExponentialRolloutRate * _Nullable exponentialRate; /**

The maximum number of OTA update job executions started per minute.

*/ @property (nonatomic, strong) NSNumber * _Nullable maximumPerMinute; @end /**

The rate of increase for a job rollout. This parameter allows you to define an exponential rate increase for a job rollout.

Required parameters: [baseRatePerMinute, incrementFactor, rateIncreaseCriteria] */ @interface AWSIoTAwsJobExponentialRolloutRate : AWSModel /**

The minimum number of things that will be notified of a pending job, per minute, at the start of the job rollout. This is the initial rate of the rollout.

*/ @property (nonatomic, strong) NSNumber * _Nullable baseRatePerMinute; /**

The rate of increase for a job rollout. The number of things notified is multiplied by this factor.

*/ @property (nonatomic, strong) NSNumber * _Nullable incrementFactor; /**

The criteria to initiate the increase in rate of rollout for a job.

Amazon Web Services IoT Core supports up to one digit after the decimal (for example, 1.5, but not 1.55).

*/ @property (nonatomic, strong) AWSIoTAwsJobRateIncreaseCriteria * _Nullable rateIncreaseCriteria; @end /**

Configuration information for pre-signed URLs. Valid when protocols contains HTTP.

*/ @interface AWSIoTAwsJobPresignedUrlConfig : AWSModel /**

How long (in seconds) pre-signed URLs are valid. Valid values are 60 - 3600, the default value is 1800 seconds. Pre-signed URLs are generated when a request for the job document is received.

*/ @property (nonatomic, strong) NSNumber * _Nullable expiresInSec; @end /**

The criteria to initiate the increase in rate of rollout for a job.

*/ @interface AWSIoTAwsJobRateIncreaseCriteria : AWSModel /**

When this number of things have been notified, it will initiate an increase in the rollout rate.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfNotifiedThings; /**

When this number of things have succeeded in their job execution, it will initiate an increase in the rollout rate.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfSucceededThings; @end /**

Specifies the amount of time each device has to finish its execution of the job. A timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the timer expires, it will be automatically set to TIMED_OUT.

*/ @interface AWSIoTAwsJobTimeoutConfig : AWSModel /**

Specifies the amount of time, in minutes, this device has to finish execution of this job. The timeout interval can be anywhere between 1 minute and 7 days (1 to 10080 minutes). The in progress timer can't be updated and will apply to all job executions for the job. Whenever a job execution remains in the IN_PROGRESS status for longer than this interval, the job execution will fail and switch to the terminal TIMED_OUT status.

*/ @property (nonatomic, strong) NSNumber * _Nullable inProgressTimeoutInMinutes; @end /**

A Device Defender security profile behavior.

Required parameters: [name] */ @interface AWSIoTBehavior : AWSModel /**

The criteria that determine if a device is behaving normally in regard to the metric.

*/ @property (nonatomic, strong) AWSIoTBehaviorCriteria * _Nullable criteria; /**

What is measured by the behavior.

*/ @property (nonatomic, strong) NSString * _Nullable metric; /**

The dimension for a metric in your behavior. For example, using a TOPIC_FILTER dimension, you can narrow down the scope of the metric to only MQTT topics where the name matches the pattern specified in the dimension. This can't be used with custom metrics.

*/ @property (nonatomic, strong) AWSIoTMetricDimension * _Nullable metricDimension; /**

The name you've given to the behavior.

*/ @property (nonatomic, strong) NSString * _Nullable name; /**

Suppresses alerts.

*/ @property (nonatomic, strong) NSNumber * _Nullable suppressAlerts; @end /**

The criteria by which the behavior is determined to be normal.

*/ @interface AWSIoTBehaviorCriteria : AWSModel /**

The operator that relates the thing measured (metric) to the criteria (containing a value or statisticalThreshold). Valid operators include:

  • string-list: in-set and not-in-set

  • number-list: in-set and not-in-set

  • ip-address-list: in-cidr-set and not-in-cidr-set

  • number: less-than, less-than-equals, greater-than, and greater-than-equals

*/ @property (nonatomic, assign) AWSIoTComparisonOperator comparisonOperator; /**

If a device is in violation of the behavior for the specified number of consecutive datapoints, an alarm occurs. If not specified, the default is 1.

*/ @property (nonatomic, strong) NSNumber * _Nullable consecutiveDatapointsToAlarm; /**

If an alarm has occurred and the offending device is no longer in violation of the behavior for the specified number of consecutive datapoints, the alarm is cleared. If not specified, the default is 1.

*/ @property (nonatomic, strong) NSNumber * _Nullable consecutiveDatapointsToClear; /**

Use this to specify the time duration over which the behavior is evaluated, for those criteria that have a time dimension (for example, NUM_MESSAGES_SENT). For a statisticalThreshhold metric comparison, measurements from all devices are accumulated over this time duration before being used to calculate percentiles, and later, measurements from an individual device are also accumulated over this time duration before being given a percentile rank. Cannot be used with list-based metric datatypes.

*/ @property (nonatomic, strong) NSNumber * _Nullable durationSeconds; /**

The configuration of an ML Detect

*/ @property (nonatomic, strong) AWSIoTMachineLearningDetectionConfig * _Nullable mlDetectionConfig; /**

A statistical ranking (percentile)that indicates a threshold value by which a behavior is determined to be in compliance or in violation of the behavior.

*/ @property (nonatomic, strong) AWSIoTStatisticalThreshold * _Nullable statisticalThreshold; /**

The value to be compared with the metric.

*/ @property (nonatomic, strong) AWSIoTMetricValue * _Nullable value; @end /**

The summary of an ML Detect behavior model.

*/ @interface AWSIoTBehaviorModelTrainingSummary : AWSModel /**

The name of the behavior.

*/ @property (nonatomic, strong) NSString * _Nullable behaviorName; /**

The percentage of datapoints collected.

*/ @property (nonatomic, strong) NSNumber * _Nullable datapointsCollectionPercentage; /**

The date the model was last refreshed.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModelRefreshDate; /**

The status of the behavior model.

*/ @property (nonatomic, assign) AWSIoTModelStatus modelStatus; /**

The name of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The date a training model started collecting data.

*/ @property (nonatomic, strong) NSDate * _Nullable trainingDataCollectionStartDate; @end /**

Additional information about the billing group.

*/ @interface AWSIoTBillingGroupMetadata : AWSModel /**

The date the billing group was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; @end /**

The properties of a billing group.

*/ @interface AWSIoTBillingGroupProperties : AWSModel /**

The description of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupDescription; @end /**

A count of documents that meets a specific aggregation criteria.

*/ @interface AWSIoTBucket : AWSModel /**

The number of documents that have the value counted for the particular bucket.

*/ @property (nonatomic, strong) NSNumber * _Nullable count; /**

The value counted for the particular bucket.

*/ @property (nonatomic, strong) NSString * _Nullable keyValue; @end /**

The type of bucketed aggregation performed.

*/ @interface AWSIoTBucketsAggregationType : AWSModel /**

Performs an aggregation that will return a list of buckets. The list of buckets is a ranked list of the number of occurrences of an aggregation field value.

*/ @property (nonatomic, strong) AWSIoTTermsAggregation * _Nullable termsAggregation; @end /**

A CA certificate.

*/ @interface AWSIoTCACertificate : AWSModel /**

The ARN of the CA certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The ID of the CA certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The date the CA certificate was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The status of the CA certificate.

The status value REGISTER_INACTIVE is deprecated and should not be used.

*/ @property (nonatomic, assign) AWSIoTCACertificateStatus status; @end /**

Describes a CA certificate.

*/ @interface AWSIoTCACertificateDescription : AWSModel /**

Whether the CA certificate configured for auto registration of device certificates. Valid values are "ENABLE" and "DISABLE"

*/ @property (nonatomic, assign) AWSIoTAutoRegistrationStatus autoRegistrationStatus; /**

The CA certificate ARN.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The CA certificate ID.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The mode of the CA.

All the device certificates that are registered using this CA will be registered in the same mode as the CA. For more information about certificate mode for device certificates, see certificate mode.

*/ @property (nonatomic, assign) AWSIoTCertificateMode certificateMode; /**

The CA certificate data, in PEM format.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePem; /**

The date the CA certificate was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The customer version of the CA certificate.

*/ @property (nonatomic, strong) NSNumber * _Nullable customerVersion; /**

The generation ID of the CA certificate.

*/ @property (nonatomic, strong) NSString * _Nullable generationId; /**

The date the CA certificate was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The owner of the CA certificate.

*/ @property (nonatomic, strong) NSString * _Nullable ownedBy; /**

The status of a CA certificate.

*/ @property (nonatomic, assign) AWSIoTCACertificateStatus status; /**

When the CA certificate is valid.

*/ @property (nonatomic, strong) AWSIoTCertificateValidity * _Nullable validity; @end /** */ @interface AWSIoTCancelAuditMitigationActionsTaskRequest : AWSRequest /**

The unique identifier for the task that you want to cancel.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTCancelAuditMitigationActionsTaskResponse : AWSModel @end /** */ @interface AWSIoTCancelAuditTaskRequest : AWSRequest /**

The ID of the audit you want to cancel. You can only cancel an audit that is "IN_PROGRESS".

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTCancelAuditTaskResponse : AWSModel @end /**

The input for the CancelCertificateTransfer operation.

Required parameters: [certificateId] */ @interface AWSIoTCancelCertificateTransferRequest : AWSRequest /**

The ID of the certificate. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; @end /** */ @interface AWSIoTCancelDetectMitigationActionsTaskRequest : AWSRequest /**

The unique identifier of the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTCancelDetectMitigationActionsTaskResponse : AWSModel @end /** */ @interface AWSIoTCancelJobExecutionRequest : AWSRequest /**

(Optional) The expected current version of the job execution. Each time you update the job execution, its version is incremented. If the version of the job execution stored in Jobs does not match, the update is rejected with a VersionMismatch error, and an ErrorResponse that contains the current job execution status data is returned. (This makes it unnecessary to perform a separate DescribeJobExecution request in order to obtain the job execution status data.)

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

(Optional) If true the job execution will be canceled if it has status IN_PROGRESS or QUEUED, otherwise the job execution will be canceled only if it has status QUEUED. If you attempt to cancel a job execution that is IN_PROGRESS, and you do not set force to true, then an InvalidStateTransitionException will be thrown. The default is false.

Canceling a job execution which is "IN_PROGRESS", will cause the device to be unable to update the job execution status. Use caution and ensure that the device is able to recover to a valid state.

*/ @property (nonatomic, strong) NSNumber * _Nullable force; /**

The ID of the job to be canceled.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

A collection of name/value pairs that describe the status of the job execution. If not specified, the statusDetails are unchanged. You can specify at most 10 name/value pairs.

*/ @property (nonatomic, strong) NSDictionary * _Nullable statusDetails; /**

The name of the thing whose execution of the job will be canceled.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTCancelJobRequest : AWSRequest /**

An optional comment string describing why the job was canceled.

*/ @property (nonatomic, strong) NSString * _Nullable comment; /**

(Optional) If true job executions with status "IN_PROGRESS" and "QUEUED" are canceled, otherwise only job executions with status "QUEUED" are canceled. The default is false.

Canceling a job which is "IN_PROGRESS", will cause a device which is executing the job to be unable to update the job execution status. Use caution and ensure that each device executing a job which is canceled is able to recover to a valid state.

*/ @property (nonatomic, strong) NSNumber * _Nullable force; /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

(Optional)A reason code string that explains why the job was canceled.

*/ @property (nonatomic, strong) NSString * _Nullable reasonCode; @end /** */ @interface AWSIoTCancelJobResponse : AWSModel /**

A short text description of the job.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The job ARN.

*/ @property (nonatomic, strong) NSString * _Nullable jobArn; /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; @end /**

Information about a certificate.

*/ @interface AWSIoTCertificate : AWSModel /**

The ARN of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The ID of the certificate. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The mode of the certificate.

DEFAULT: A certificate in DEFAULT mode is either generated by Amazon Web Services IoT Core or registered with an issuer certificate authority (CA) in DEFAULT mode. Devices with certificates in DEFAULT mode aren't required to send the Server Name Indication (SNI) extension when connecting to Amazon Web Services IoT Core. However, to use features such as custom domains and VPC endpoints, we recommend that you use the SNI extension when connecting to Amazon Web Services IoT Core.

SNI_ONLY: A certificate in SNI_ONLY mode is registered without an issuer CA. Devices with certificates in SNI_ONLY mode must send the SNI extension when connecting to Amazon Web Services IoT Core.

*/ @property (nonatomic, assign) AWSIoTCertificateMode certificateMode; /**

The date and time the certificate was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The status of the certificate.

The status value REGISTER_INACTIVE is deprecated and should not be used.

*/ @property (nonatomic, assign) AWSIoTCertificateStatus status; @end /**

Describes a certificate.

*/ @interface AWSIoTCertificateDescription : AWSModel /**

The certificate ID of the CA certificate used to sign this certificate.

*/ @property (nonatomic, strong) NSString * _Nullable caCertificateId; /**

The ARN of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The ID of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The mode of the certificate.

DEFAULT: A certificate in DEFAULT mode is either generated by Amazon Web Services IoT Core or registered with an issuer certificate authority (CA) in DEFAULT mode. Devices with certificates in DEFAULT mode aren't required to send the Server Name Indication (SNI) extension when connecting to Amazon Web Services IoT Core. However, to use features such as custom domains and VPC endpoints, we recommend that you use the SNI extension when connecting to Amazon Web Services IoT Core.

SNI_ONLY: A certificate in SNI_ONLY mode is registered without an issuer CA. Devices with certificates in SNI_ONLY mode must send the SNI extension when connecting to Amazon Web Services IoT Core.

For more information about the value for SNI extension, see Transport security in IoT.

*/ @property (nonatomic, assign) AWSIoTCertificateMode certificateMode; /**

The certificate data, in PEM format.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePem; /**

The date and time the certificate was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The customer version of the certificate.

*/ @property (nonatomic, strong) NSNumber * _Nullable customerVersion; /**

The generation ID of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable generationId; /**

The date and time the certificate was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The ID of the Amazon Web Services account that owns the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable ownedBy; /**

The ID of the Amazon Web Services account of the previous owner of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable previousOwnedBy; /**

The status of the certificate.

*/ @property (nonatomic, assign) AWSIoTCertificateStatus status; /**

The transfer data.

*/ @property (nonatomic, strong) AWSIoTTransferData * _Nullable transferData; /**

When the certificate is valid.

*/ @property (nonatomic, strong) AWSIoTCertificateValidity * _Nullable validity; @end /**

When the certificate is valid.

*/ @interface AWSIoTCertificateValidity : AWSModel /**

The certificate is not valid after this date.

*/ @property (nonatomic, strong) NSDate * _Nullable notAfter; /**

The certificate is not valid before this date.

*/ @property (nonatomic, strong) NSDate * _Nullable notBefore; @end /** */ @interface AWSIoTClearDefaultAuthorizerRequest : AWSRequest @end /** */ @interface AWSIoTClearDefaultAuthorizerResponse : AWSModel @end /**

Describes an action that updates a CloudWatch alarm.

Required parameters: [roleArn, alarmName, stateReason, stateValue] */ @interface AWSIoTCloudwatchAlarmAction : AWSModel /**

The CloudWatch alarm name.

*/ @property (nonatomic, strong) NSString * _Nullable alarmName; /**

The IAM role that allows access to the CloudWatch alarm.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The reason for the alarm change.

*/ @property (nonatomic, strong) NSString * _Nullable stateReason; /**

The value of the alarm state. Acceptable values are: OK, ALARM, INSUFFICIENT_DATA.

*/ @property (nonatomic, strong) NSString * _Nullable stateValue; @end /**

Describes an action that sends data to CloudWatch Logs.

Required parameters: [roleArn, logGroupName] */ @interface AWSIoTCloudwatchLogsAction : AWSModel /**

Indicates whether batches of log records will be extracted and uploaded into CloudWatch. Values include true or false(default).

*/ @property (nonatomic, strong) NSNumber * _Nullable batchMode; /**

The CloudWatch log group to which the action sends data.

*/ @property (nonatomic, strong) NSString * _Nullable logGroupName; /**

The IAM role that allows access to the CloudWatch log.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Describes an action that captures a CloudWatch metric.

Required parameters: [roleArn, metricNamespace, metricName, metricValue, metricUnit] */ @interface AWSIoTCloudwatchMetricAction : AWSModel /**

The CloudWatch metric name.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The CloudWatch metric namespace name.

*/ @property (nonatomic, strong) NSString * _Nullable metricNamespace; /**

An optional Unix timestamp.

*/ @property (nonatomic, strong) NSString * _Nullable metricTimestamp; /**

The metric unit supported by CloudWatch.

*/ @property (nonatomic, strong) NSString * _Nullable metricUnit; /**

The CloudWatch metric value.

*/ @property (nonatomic, strong) NSString * _Nullable metricValue; /**

The IAM role that allows access to the CloudWatch metric.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Describes the method to use when code signing a file.

*/ @interface AWSIoTCodeSigning : AWSModel /**

The ID of the AWSSignerJob which was created to sign the file.

*/ @property (nonatomic, strong) NSString * _Nullable awsSignerJobId; /**

A custom method for code signing a file.

*/ @property (nonatomic, strong) AWSIoTCustomCodeSigning * _Nullable customCodeSigning; /**

Describes the code-signing job.

*/ @property (nonatomic, strong) AWSIoTStartSigningJobParameter * _Nullable startSigningJobParameter; @end /**

Describes the certificate chain being used when code signing a file.

*/ @interface AWSIoTCodeSigningCertificateChain : AWSModel /**

The name of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateName; /**

A base64 encoded binary representation of the code signing certificate chain.

*/ @property (nonatomic, strong) NSString * _Nullable inlineDocument; @end /**

Describes the signature for a file.

*/ @interface AWSIoTCodeSigningSignature : AWSModel /**

A base64 encoded binary representation of the code signing signature.

*/ @property (nonatomic, strong) NSData * _Nullable inlineDocument; @end /**

Configuration.

*/ @interface AWSIoTConfiguration : AWSModel /**

True to enable the configuration.

*/ @property (nonatomic, strong) NSNumber * _Nullable enabled; @end /** */ @interface AWSIoTConfirmTopicRuleDestinationRequest : AWSRequest /**

The token used to confirm ownership or access to the topic rule confirmation URL.

*/ @property (nonatomic, strong) NSString * _Nullable confirmationToken; @end /** */ @interface AWSIoTConfirmTopicRuleDestinationResponse : AWSModel @end /** */ @interface AWSIoTCreateAuditSuppressionRequest : AWSRequest /**

An audit check name. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

Each audit supression must have a unique client request token. If you try to create a new audit suppression with the same token as one that already exists, an exception occurs. If you omit this value, Amazon Web Services SDKs will automatically generate a unique client request.

*/ @property (nonatomic, strong) NSString * _Nullable clientRequestToken; /**

The description of the audit suppression.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The epoch timestamp in seconds at which this suppression expires.

*/ @property (nonatomic, strong) NSDate * _Nullable expirationDate; /**

Information that identifies the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; /**

Indicates whether a suppression should exist indefinitely or not.

*/ @property (nonatomic, strong) NSNumber * _Nullable suppressIndefinitely; @end /** */ @interface AWSIoTCreateAuditSuppressionResponse : AWSModel @end /** */ @interface AWSIoTCreateAuthorizerRequest : AWSRequest /**

The ARN of the authorizer's Lambda function.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerFunctionArn; /**

The authorizer name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; /**

When true, the result from the authorizer’s Lambda function is cached for clients that use persistent HTTP connections. The results are cached for the time specified by the Lambda function in refreshAfterInSeconds. This value does not affect authorization of clients that use MQTT connections.

The default value is false.

*/ @property (nonatomic, strong) NSNumber * _Nullable enableCachingForHttp; /**

Specifies whether IoT validates the token signature in an authorization request.

*/ @property (nonatomic, strong) NSNumber * _Nullable signingDisabled; /**

The status of the create authorizer request.

*/ @property (nonatomic, assign) AWSIoTAuthorizerStatus status; /**

Metadata which can be used to manage the custom authorizer.

For URI Request parameters use format: ...key1=value1&key2=value2...

For the CLI command-line parameter use format: &&tags "key1=value1&key2=value2..."

For the cli-input-json file use format: "tags": "key1=value1&key2=value2..."

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

The name of the token key used to extract the token from the HTTP headers.

*/ @property (nonatomic, strong) NSString * _Nullable tokenKeyName; /**

The public keys used to verify the digital signature returned by your custom authentication service.

*/ @property (nonatomic, strong) NSDictionary * _Nullable tokenSigningPublicKeys; @end /** */ @interface AWSIoTCreateAuthorizerResponse : AWSModel /**

The authorizer ARN.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerArn; /**

The authorizer's name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; @end /** */ @interface AWSIoTCreateBillingGroupRequest : AWSRequest /**

The name you wish to give to the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The properties of the billing group.

*/ @property (nonatomic, strong) AWSIoTBillingGroupProperties * _Nullable billingGroupProperties; /**

Metadata which can be used to manage the billing group.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /** */ @interface AWSIoTCreateBillingGroupResponse : AWSModel /**

The ARN of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupArn; /**

The ID of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupId; /**

The name you gave to the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; @end /**

The input for the CreateCertificateFromCsr operation.

Required parameters: [certificateSigningRequest] */ @interface AWSIoTCreateCertificateFromCsrRequest : AWSRequest /**

The certificate signing request (CSR).

*/ @property (nonatomic, strong) NSString * _Nullable certificateSigningRequest; /**

Specifies whether the certificate is active.

*/ @property (nonatomic, strong) NSNumber * _Nullable setAsActive; @end /**

The output from the CreateCertificateFromCsr operation.

*/ @interface AWSIoTCreateCertificateFromCsrResponse : AWSModel /**

The Amazon Resource Name (ARN) of the certificate. You can use the ARN as a principal for policy operations.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The ID of the certificate. Certificate management operations only take a certificateId.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The certificate data, in PEM format.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePem; @end /** */ @interface AWSIoTCreateCustomMetricRequest : AWSRequest /**

Each custom metric must have a unique client request token. If you try to create a new custom metric that already exists with a different token, an exception occurs. If you omit this value, Amazon Web Services SDKs will automatically generate a unique client request.

*/ @property (nonatomic, strong) NSString * _Nullable clientRequestToken; /**

The friendly name in the console for the custom metric. This name doesn't have to be unique. Don't use this name as the metric identifier in the device metric report. You can update the friendly name after you define it.

*/ @property (nonatomic, strong) NSString * _Nullable displayName; /**

The name of the custom metric. This will be used in the metric report submitted from the device/thing. The name can't begin with aws:. You can't change the name after you define it.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The type of the custom metric.

The type number only takes a single metric value as an input, but when you submit the metrics value in the DeviceMetrics report, you must pass it as an array with a single value.

*/ @property (nonatomic, assign) AWSIoTCustomMetricType metricType; /**

Metadata that can be used to manage the custom metric.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /** */ @interface AWSIoTCreateCustomMetricResponse : AWSModel /**

The Amazon Resource Number (ARN) of the custom metric. For example, arn:aws-partition:iot:region:accountId:custommetric/metricName

*/ @property (nonatomic, strong) NSString * _Nullable metricArn; /**

The name of the custom metric to be used in the metric report.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; @end /** */ @interface AWSIoTCreateDimensionRequest : AWSRequest /**

Each dimension must have a unique client request token. If you try to create a new dimension with the same token as a dimension that already exists, an exception occurs. If you omit this value, Amazon Web Services SDKs will automatically generate a unique client request.

*/ @property (nonatomic, strong) NSString * _Nullable clientRequestToken; /**

A unique identifier for the dimension. Choose something that describes the type and value to make it easy to remember what it does.

*/ @property (nonatomic, strong) NSString * _Nullable name; /**

Specifies the value or list of values for the dimension. For TOPIC_FILTER dimensions, this is a pattern used to match the MQTT topic (for example, "admin/#").

*/ @property (nonatomic, strong) NSArray * _Nullable stringValues; /**

Metadata that can be used to manage the dimension.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

Specifies the type of dimension. Supported types: TOPIC_FILTER.

*/ @property (nonatomic, assign) AWSIoTDimensionType types; @end /** */ @interface AWSIoTCreateDimensionResponse : AWSModel /**

The Amazon Resource Name (ARN) of the created dimension.

*/ @property (nonatomic, strong) NSString * _Nullable arn; /**

A unique identifier for the dimension.

*/ @property (nonatomic, strong) NSString * _Nullable name; @end /** */ @interface AWSIoTCreateDomainConfigurationRequest : AWSRequest /**

An object that specifies the authorization service for a domain.

*/ @property (nonatomic, strong) AWSIoTAuthorizerConfig * _Nullable authorizerConfig; /**

The name of the domain configuration. This value must be unique to a region.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationName; /**

The name of the domain.

*/ @property (nonatomic, strong) NSString * _Nullable domainName; /**

The ARNs of the certificates that IoT passes to the device during the TLS handshake. Currently you can specify only one certificate ARN. This value is not required for Amazon Web Services-managed domains.

*/ @property (nonatomic, strong) NSArray * _Nullable serverCertificateArns; /**

The type of service delivered by the endpoint.

Amazon Web Services IoT Core currently supports only the DATA service type.

*/ @property (nonatomic, assign) AWSIoTServiceType serviceType; /**

Metadata which can be used to manage the domain configuration.

For URI Request parameters use format: ...key1=value1&key2=value2...

For the CLI command-line parameter use format: &&tags "key1=value1&key2=value2..."

For the cli-input-json file use format: "tags": "key1=value1&key2=value2..."

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

An object that specifies the TLS configuration for a domain.

*/ @property (nonatomic, strong) AWSIoTTlsConfig * _Nullable tlsConfig; /**

The certificate used to validate the server certificate and prove domain name ownership. This certificate must be signed by a public certificate authority. This value is not required for Amazon Web Services-managed domains.

*/ @property (nonatomic, strong) NSString * _Nullable validationCertificateArn; @end /** */ @interface AWSIoTCreateDomainConfigurationResponse : AWSModel /**

The ARN of the domain configuration.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationArn; /**

The name of the domain configuration.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationName; @end /** */ @interface AWSIoTCreateDynamicThingGroupRequest : AWSRequest /**

The dynamic thing group index name.

Currently one index is supported: AWS_Things.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The dynamic thing group search query string.

See Query Syntax for information about query string syntax.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The dynamic thing group query version.

Currently one query version is supported: "2017-09-30". If not specified, the query version defaults to this value.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; /**

Metadata which can be used to manage the dynamic thing group.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

The dynamic thing group name to create.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; /**

The dynamic thing group properties.

*/ @property (nonatomic, strong) AWSIoTThingGroupProperties * _Nullable thingGroupProperties; @end /** */ @interface AWSIoTCreateDynamicThingGroupResponse : AWSModel /**

The dynamic thing group index name.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The dynamic thing group search query string.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The dynamic thing group query version.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; /**

The dynamic thing group ARN.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupArn; /**

The dynamic thing group ID.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupId; /**

The dynamic thing group name.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; @end /** */ @interface AWSIoTCreateFleetMetricRequest : AWSRequest /**

The field to aggregate.

*/ @property (nonatomic, strong) NSString * _Nullable aggregationField; /**

The type of the aggregation query.

*/ @property (nonatomic, strong) AWSIoTAggregationType * _Nullable aggregationType; /**

The fleet metric description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The name of the index to search.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The name of the fleet metric to create.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The time in seconds between fleet metric emissions. Range [60(1 min), 86400(1 day)] and must be multiple of 60.

*/ @property (nonatomic, strong) NSNumber * _Nullable period; /**

The search query string.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The query version.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; /**

Metadata, which can be used to manage the fleet metric.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

Used to support unit transformation such as milliseconds to seconds. The unit must be supported by CW metric. Default to null.

*/ @property (nonatomic, assign) AWSIoTFleetMetricUnit unit; @end /** */ @interface AWSIoTCreateFleetMetricResponse : AWSModel /**

The Amazon Resource Name (ARN) of the new fleet metric.

*/ @property (nonatomic, strong) NSString * _Nullable metricArn; /**

The name of the fleet metric to create.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; @end /** */ @interface AWSIoTCreateJobRequest : AWSRequest /**

Allows you to create the criteria to abort a job.

*/ @property (nonatomic, strong) AWSIoTAbortConfig * _Nullable abortConfig; /**

A short text description of the job.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The package version Amazon Resource Names (ARNs) that are installed on the device when the job successfully completes.

Note:The following Length Constraints relates to a single string. Up to five strings are allowed.

*/ @property (nonatomic, strong) NSArray * _Nullable destinationPackageVersions; /**

The job document. Required if you don't specify a value for documentSource.

*/ @property (nonatomic, strong) NSString * _Nullable document; /**

Parameters of an Amazon Web Services managed template that you can specify to create the job document.

documentParameters can only be used when creating jobs from Amazon Web Services managed templates. This parameter can't be used with custom job templates or to create jobs from them.

*/ @property (nonatomic, strong) NSDictionary * _Nullable documentParameters; /**

An S3 link, or S3 object URL, to the job document. The link is an Amazon S3 object URL and is required if you don't specify a value for document.

For example, --document-source https://s3.region-code.amazonaws.com/example-firmware/device-firmware.1.0

For more information, see Methods for accessing a bucket.

*/ @property (nonatomic, strong) NSString * _Nullable documentSource; /**

Allows you to create the criteria to retry a job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRetryConfig * _Nullable jobExecutionsRetryConfig; /**

Allows you to create a staged rollout of the job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRolloutConfig * _Nullable jobExecutionsRolloutConfig; /**

A job identifier which must be unique for your Amazon Web Services account. We recommend using a UUID. Alpha-numeric characters, "-" and "_" are valid for use here.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The ARN of the job template used to create the job.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateArn; /**

The namespace used to indicate that a job is a customer-managed job.

When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.

$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/

The namespaceId feature is in public preview.

*/ @property (nonatomic, strong) NSString * _Nullable namespaceId; /**

Configuration information for pre-signed S3 URLs.

*/ @property (nonatomic, strong) AWSIoTPresignedUrlConfig * _Nullable presignedUrlConfig; /**

The configuration that allows you to schedule a job for a future date and time in addition to specifying the end behavior for each job execution.

*/ @property (nonatomic, strong) AWSIoTSchedulingConfig * _Nullable schedulingConfig; /**

Metadata which can be used to manage the job.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

Specifies whether the job will continue to run (CONTINUOUS), or will be complete after all those things specified as targets have completed the job (SNAPSHOT). If continuous, the job may also be run on a thing when a change is detected in a target. For example, a job will run on a thing when the thing is added to a target group, even after the job was completed by all things originally in the group.

We recommend that you use continuous jobs instead of snapshot jobs for dynamic thing group targets. By using continuous jobs, devices that join the group receive the job execution even after the job has been created.

*/ @property (nonatomic, assign) AWSIoTTargetSelection targetSelection; /**

A list of things and thing groups to which the job should be sent.

*/ @property (nonatomic, strong) NSArray * _Nullable targets; /**

Specifies the amount of time each device has to finish its execution of the job. The timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the time expires, it will be automatically set to TIMED_OUT.

*/ @property (nonatomic, strong) AWSIoTTimeoutConfig * _Nullable timeoutConfig; @end /** */ @interface AWSIoTCreateJobResponse : AWSModel /**

The job description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The job ARN.

*/ @property (nonatomic, strong) NSString * _Nullable jobArn; /**

The unique identifier you assigned to this job.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; @end /** */ @interface AWSIoTCreateJobTemplateRequest : AWSRequest /**

The criteria that determine when and how a job abort takes place.

*/ @property (nonatomic, strong) AWSIoTAbortConfig * _Nullable abortConfig; /**

A description of the job document.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The package version Amazon Resource Names (ARNs) that are installed on the device when the job successfully completes.

Note:The following Length Constraints relates to a single string. Up to five strings are allowed.

*/ @property (nonatomic, strong) NSArray * _Nullable destinationPackageVersions; /**

The job document. Required if you don't specify a value for documentSource.

*/ @property (nonatomic, strong) NSString * _Nullable document; /**

An S3 link to the job document to use in the template. Required if you don't specify a value for document.

If the job document resides in an S3 bucket, you must use a placeholder link when specifying the document.

The placeholder link is of the following form:

${aws:iot:s3-presigned-url:https://s3.amazonaws.com/bucket/key}

where bucket is your bucket name and key is the object in the bucket to which you are linking.

*/ @property (nonatomic, strong) NSString * _Nullable documentSource; /**

The ARN of the job to use as the basis for the job template.

*/ @property (nonatomic, strong) NSString * _Nullable jobArn; /**

Allows you to create the criteria to retry a job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRetryConfig * _Nullable jobExecutionsRetryConfig; /**

Allows you to create a staged rollout of a job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRolloutConfig * _Nullable jobExecutionsRolloutConfig; /**

A unique identifier for the job template. We recommend using a UUID. Alpha-numeric characters, "-", and "_" are valid for use here.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateId; /**

Allows you to configure an optional maintenance window for the rollout of a job document to all devices in the target group for a job.

*/ @property (nonatomic, strong) NSArray * _Nullable maintenanceWindows; /**

Configuration for pre-signed S3 URLs.

*/ @property (nonatomic, strong) AWSIoTPresignedUrlConfig * _Nullable presignedUrlConfig; /**

Metadata that can be used to manage the job template.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

Specifies the amount of time each device has to finish its execution of the job. A timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the timer expires, it will be automatically set to TIMED_OUT.

*/ @property (nonatomic, strong) AWSIoTTimeoutConfig * _Nullable timeoutConfig; @end /** */ @interface AWSIoTCreateJobTemplateResponse : AWSModel /**

The ARN of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateArn; /**

The unique identifier of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateId; @end /**

The input for the CreateKeysAndCertificate operation.

Requires permission to access the CreateKeysAndCertificateRequest action.

*/ @interface AWSIoTCreateKeysAndCertificateRequest : AWSRequest /**

Specifies whether the certificate is active.

*/ @property (nonatomic, strong) NSNumber * _Nullable setAsActive; @end /**

The output of the CreateKeysAndCertificate operation.

*/ @interface AWSIoTCreateKeysAndCertificateResponse : AWSModel /**

The ARN of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The ID of the certificate. IoT issues a default subject name for the certificate (for example, IoT Certificate).

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The certificate data, in PEM format.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePem; /**

The generated key pair.

*/ @property (nonatomic, strong) AWSIoTKeyPair * _Nullable keyPair; @end /** */ @interface AWSIoTCreateMitigationActionRequest : AWSRequest /**

A friendly name for the action. Choose a friendly name that accurately describes the action (for example, EnableLoggingAction).

*/ @property (nonatomic, strong) NSString * _Nullable actionName; /**

Defines the type of action and the parameters for that action.

*/ @property (nonatomic, strong) AWSIoTMitigationActionParams * _Nullable actionParams; /**

The ARN of the IAM role that is used to apply the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

Metadata that can be used to manage the mitigation action.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /** */ @interface AWSIoTCreateMitigationActionResponse : AWSModel /**

The ARN for the new mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionArn; /**

A unique identifier for the new mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionId; @end /** */ @interface AWSIoTCreateOTAUpdateRequest : AWSRequest /**

A list of additional OTA update parameters which are name-value pairs.

*/ @property (nonatomic, strong) NSDictionary * _Nullable additionalParameters; /**

The criteria that determine when and how a job abort takes place.

*/ @property (nonatomic, strong) AWSIoTAwsJobAbortConfig * _Nullable awsJobAbortConfig; /**

Configuration for the rollout of OTA updates.

*/ @property (nonatomic, strong) AWSIoTAwsJobExecutionsRolloutConfig * _Nullable awsJobExecutionsRolloutConfig; /**

Configuration information for pre-signed URLs.

*/ @property (nonatomic, strong) AWSIoTAwsJobPresignedUrlConfig * _Nullable awsJobPresignedUrlConfig; /**

Specifies the amount of time each device has to finish its execution of the job. A timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the timer expires, it will be automatically set to TIMED_OUT.

*/ @property (nonatomic, strong) AWSIoTAwsJobTimeoutConfig * _Nullable awsJobTimeoutConfig; /**

The description of the OTA update.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The files to be streamed by the OTA update.

*/ @property (nonatomic, strong) NSArray * _Nullable files; /**

The ID of the OTA update to be created.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateId; /**

The protocol used to transfer the OTA update image. Valid values are [HTTP], [MQTT], [HTTP, MQTT]. When both HTTP and MQTT are specified, the target device can choose the protocol.

*/ @property (nonatomic, strong) NSArray * _Nullable protocols; /**

The IAM role that grants Amazon Web Services IoT Core access to the Amazon S3, IoT jobs and Amazon Web Services Code Signing resources to create an OTA update job.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

Metadata which can be used to manage updates.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

Specifies whether the update will continue to run (CONTINUOUS), or will be complete after all the things specified as targets have completed the update (SNAPSHOT). If continuous, the update may also be run on a thing when a change is detected in a target. For example, an update will run on a thing when the thing is added to a target group, even after the update was completed by all things originally in the group. Valid values: CONTINUOUS | SNAPSHOT.

*/ @property (nonatomic, assign) AWSIoTTargetSelection targetSelection; /**

The devices targeted to receive OTA updates.

*/ @property (nonatomic, strong) NSArray * _Nullable targets; @end /** */ @interface AWSIoTCreateOTAUpdateResponse : AWSModel /**

The IoT job ARN associated with the OTA update.

*/ @property (nonatomic, strong) NSString * _Nullable awsIotJobArn; /**

The IoT job ID associated with the OTA update.

*/ @property (nonatomic, strong) NSString * _Nullable awsIotJobId; /**

The OTA update ARN.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateArn; /**

The OTA update ID.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateId; /**

The OTA update status.

*/ @property (nonatomic, assign) AWSIoTOTAUpdateStatus otaUpdateStatus; @end /** */ @interface AWSIoTCreatePackageRequest : AWSRequest /**

A unique case-sensitive identifier that you can provide to ensure the idempotency of the request. Don't reuse this client token if a new idempotent request is required.

*/ @property (nonatomic, strong) NSString * _Nullable clientToken; /**

A summary of the package being created. This can be used to outline the package's contents or purpose.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The name of the new package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

Metadata that can be used to manage the package.

*/ @property (nonatomic, strong) NSDictionary * _Nullable tags; @end /** */ @interface AWSIoTCreatePackageResponse : AWSModel /**

The package description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The Amazon Resource Name (ARN) for the package.

*/ @property (nonatomic, strong) NSString * _Nullable packageArn; /**

The name of the package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; @end /** */ @interface AWSIoTCreatePackageVersionRequest : AWSRequest /**

Metadata that can be used to define a package version’s configuration. For example, the S3 file location, configuration options that are being sent to the device or fleet.

The combined size of all the attributes on a package version is limited to 3KB.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

A unique case-sensitive identifier that you can provide to ensure the idempotency of the request. Don't reuse this client token if a new idempotent request is required.

*/ @property (nonatomic, strong) NSString * _Nullable clientToken; /**

A summary of the package version being created. This can be used to outline the package's contents or purpose.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The name of the associated package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

Metadata that can be used to manage the package version.

*/ @property (nonatomic, strong) NSDictionary * _Nullable tags; /**

The name of the new package version.

*/ @property (nonatomic, strong) NSString * _Nullable versionName; @end /** */ @interface AWSIoTCreatePackageVersionResponse : AWSModel /**

Metadata that were added to the package version that can be used to define a package version’s configuration.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

The package version description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

Error reason for a package version failure during creation or update.

*/ @property (nonatomic, strong) NSString * _Nullable errorReason; /**

The name of the associated package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

The Amazon Resource Name (ARN) for the package.

*/ @property (nonatomic, strong) NSString * _Nullable packageVersionArn; /**

The status of the package version. For more information, see Package version lifecycle.

*/ @property (nonatomic, assign) AWSIoTPackageVersionStatus status; /**

The name of the new package version.

*/ @property (nonatomic, strong) NSString * _Nullable versionName; @end /**

The input for the CreatePolicy operation.

Required parameters: [policyName, policyDocument] */ @interface AWSIoTCreatePolicyRequest : AWSRequest /**

The JSON document that describes the policy. policyDocument must have a minimum length of 1, with a maximum length of 2048, excluding whitespace.

*/ @property (nonatomic, strong) NSString * _Nullable policyDocument; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

Metadata which can be used to manage the policy.

For URI Request parameters use format: ...key1=value1&key2=value2...

For the CLI command-line parameter use format: &&tags "key1=value1&key2=value2..."

For the cli-input-json file use format: "tags": "key1=value1&key2=value2..."

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /**

The output from the CreatePolicy operation.

*/ @interface AWSIoTCreatePolicyResponse : AWSModel /**

The policy ARN.

*/ @property (nonatomic, strong) NSString * _Nullable policyArn; /**

The JSON document that describes the policy.

*/ @property (nonatomic, strong) NSString * _Nullable policyDocument; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The policy version ID.

*/ @property (nonatomic, strong) NSString * _Nullable policyVersionId; @end /**

The input for the CreatePolicyVersion operation.

Required parameters: [policyName, policyDocument] */ @interface AWSIoTCreatePolicyVersionRequest : AWSRequest /**

The JSON document that describes the policy. Minimum length of 1. Maximum length of 2048, excluding whitespace.

*/ @property (nonatomic, strong) NSString * _Nullable policyDocument; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

Specifies whether the policy version is set as the default. When this parameter is true, the new policy version becomes the operative version (that is, the version that is in effect for the certificates to which the policy is attached).

*/ @property (nonatomic, strong) NSNumber * _Nullable setAsDefault; @end /**

The output of the CreatePolicyVersion operation.

*/ @interface AWSIoTCreatePolicyVersionResponse : AWSModel /**

Specifies whether the policy version is the default.

*/ @property (nonatomic, strong) NSNumber * _Nullable isDefaultVersion; /**

The policy ARN.

*/ @property (nonatomic, strong) NSString * _Nullable policyArn; /**

The JSON document that describes the policy.

*/ @property (nonatomic, strong) NSString * _Nullable policyDocument; /**

The policy version ID.

*/ @property (nonatomic, strong) NSString * _Nullable policyVersionId; @end /** */ @interface AWSIoTCreateProvisioningClaimRequest : AWSRequest /**

The name of the provisioning template to use.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /** */ @interface AWSIoTCreateProvisioningClaimResponse : AWSModel /**

The ID of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The provisioning claim certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePem; /**

The provisioning claim expiration time.

*/ @property (nonatomic, strong) NSDate * _Nullable expiration; /**

The provisioning claim key pair.

*/ @property (nonatomic, strong) AWSIoTKeyPair * _Nullable keyPair; @end /** */ @interface AWSIoTCreateProvisioningTemplateRequest : AWSRequest /**

The description of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

True to enable the provisioning template, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable enabled; /**

Creates a pre-provisioning hook template. Only supports template of type FLEET_PROVISIONING. For more information about provisioning template types, see type.

*/ @property (nonatomic, strong) AWSIoTProvisioningHook * _Nullable preProvisioningHook; /**

The role ARN for the role associated with the provisioning template. This IoT role grants permission to provision a device.

*/ @property (nonatomic, strong) NSString * _Nullable provisioningRoleArn; /**

Metadata which can be used to manage the provisioning template.

For URI Request parameters use format: ...key1=value1&key2=value2...

For the CLI command-line parameter use format: &&tags "key1=value1&key2=value2..."

For the cli-input-json file use format: "tags": "key1=value1&key2=value2..."

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

The JSON formatted contents of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateBody; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

The type you define in a provisioning template. You can create a template with only one type. You can't change the template type after its creation. The default value is FLEET_PROVISIONING. For more information about provisioning template, see: Provisioning template.

*/ @property (nonatomic, assign) AWSIoTTemplateType types; @end /** */ @interface AWSIoTCreateProvisioningTemplateResponse : AWSModel /**

The default version of the provisioning template.

*/ @property (nonatomic, strong) NSNumber * _Nullable defaultVersionId; /**

The ARN that identifies the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateArn; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /** */ @interface AWSIoTCreateProvisioningTemplateVersionRequest : AWSRequest /**

Sets a fleet provision template version as the default version.

*/ @property (nonatomic, strong) NSNumber * _Nullable setAsDefault; /**

The JSON formatted contents of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateBody; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /** */ @interface AWSIoTCreateProvisioningTemplateVersionResponse : AWSModel /**

True if the provisioning template version is the default version, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable isDefaultVersion; /**

The ARN that identifies the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateArn; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

The version of the provisioning template.

*/ @property (nonatomic, strong) NSNumber * _Nullable versionId; @end /** */ @interface AWSIoTCreateRoleAliasRequest : AWSRequest /**

How long (in seconds) the credentials will be valid. The default value is 3,600 seconds.

This value must be less than or equal to the maximum session duration of the IAM role that the role alias references.

*/ @property (nonatomic, strong) NSNumber * _Nullable credentialDurationSeconds; /**

The role alias that points to a role ARN. This allows you to change the role without having to update the device.

*/ @property (nonatomic, strong) NSString * _Nullable roleAlias; /**

The role ARN.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

Metadata which can be used to manage the role alias.

For URI Request parameters use format: ...key1=value1&key2=value2...

For the CLI command-line parameter use format: &&tags "key1=value1&key2=value2..."

For the cli-input-json file use format: "tags": "key1=value1&key2=value2..."

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /** */ @interface AWSIoTCreateRoleAliasResponse : AWSModel /**

The role alias.

*/ @property (nonatomic, strong) NSString * _Nullable roleAlias; /**

The role alias ARN.

*/ @property (nonatomic, strong) NSString * _Nullable roleAliasArn; @end /** */ @interface AWSIoTCreateScheduledAuditRequest : AWSRequest /**

The day of the month on which the scheduled audit takes place. This can be "1" through "31" or "LAST". This field is required if the "frequency" parameter is set to MONTHLY. If days 29 to 31 are specified, and the month doesn't have that many days, the audit takes place on the LAST day of the month.

*/ @property (nonatomic, strong) NSString * _Nullable dayOfMonth; /**

The day of the week on which the scheduled audit takes place, either SUN, MON, TUE, WED, THU, FRI, or SAT. This field is required if the frequency parameter is set to WEEKLY or BIWEEKLY.

*/ @property (nonatomic, assign) AWSIoTDayOfWeek dayOfWeek; /**

How often the scheduled audit takes place, either DAILY, WEEKLY, BIWEEKLY or MONTHLY. The start time of each audit is determined by the system.

*/ @property (nonatomic, assign) AWSIoTAuditFrequency frequency; /**

The name you want to give to the scheduled audit. (Max. 128 chars)

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditName; /**

Metadata that can be used to manage the scheduled audit.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

Which checks are performed during the scheduled audit. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSArray * _Nullable targetCheckNames; @end /** */ @interface AWSIoTCreateScheduledAuditResponse : AWSModel /**

The ARN of the scheduled audit.

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditArn; @end /** */ @interface AWSIoTCreateSecurityProfileRequest : AWSRequest /**

Please use CreateSecurityProfileRequest$additionalMetricsToRetainV2 instead.

A list of metrics whose data is retained (stored). By default, data is retained for any metric used in the profile's behaviors, but it is also retained for any metric specified here. Can be used with custom metrics; cannot be used with dimensions.

*/ @property (nonatomic, strong) NSArray * _Nullable additionalMetricsToRetain; /**

A list of metrics whose data is retained (stored). By default, data is retained for any metric used in the profile's behaviors, but it is also retained for any metric specified here. Can be used with custom metrics; cannot be used with dimensions.

*/ @property (nonatomic, strong) NSArray * _Nullable additionalMetricsToRetainV2; /**

Specifies the destinations to which alerts are sent. (Alerts are always sent to the console.) Alerts are generated when a device (thing) violates a behavior.

*/ @property (nonatomic, strong) NSDictionary * _Nullable alertTargets; /**

Specifies the behaviors that, when violated by a device (thing), cause an alert.

*/ @property (nonatomic, strong) NSArray * _Nullable behaviors; /**

A description of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileDescription; /**

The name you are giving to the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

Metadata that can be used to manage the security profile.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /** */ @interface AWSIoTCreateSecurityProfileResponse : AWSModel /**

The ARN of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileArn; /**

The name you gave to the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; @end /** */ @interface AWSIoTCreateStreamRequest : AWSRequest /**

A description of the stream.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The files to stream.

*/ @property (nonatomic, strong) NSArray * _Nullable files; /**

An IAM role that allows the IoT service principal to access your S3 files.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; /**

Metadata which can be used to manage streams.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /** */ @interface AWSIoTCreateStreamResponse : AWSModel /**

A description of the stream.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The stream ARN.

*/ @property (nonatomic, strong) NSString * _Nullable streamArn; /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; /**

The version of the stream.

*/ @property (nonatomic, strong) NSNumber * _Nullable streamVersion; @end /** */ @interface AWSIoTCreateThingGroupRequest : AWSRequest /**

The name of the parent thing group.

*/ @property (nonatomic, strong) NSString * _Nullable parentGroupName; /**

Metadata which can be used to manage the thing group.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

The thing group name to create.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; /**

The thing group properties.

*/ @property (nonatomic, strong) AWSIoTThingGroupProperties * _Nullable thingGroupProperties; @end /** */ @interface AWSIoTCreateThingGroupResponse : AWSModel /**

The thing group ARN.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupArn; /**

The thing group ID.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupId; /**

The thing group name.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; @end /**

The input for the CreateThing operation.

Required parameters: [thingName] */ @interface AWSIoTCreateThingRequest : AWSRequest /**

The attribute payload, which consists of up to three name/value pairs in a JSON document. For example:

{\"attributes\":{\"string1\":\"string2\"}}

*/ @property (nonatomic, strong) AWSIoTAttributePayload * _Nullable attributePayload; /**

The name of the billing group the thing will be added to.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The name of the thing to create.

You can't change a thing's name after you create it. To change a thing's name, you must create a new thing, give it the new name, and then delete the old thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The name of the thing type associated with the new thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; @end /**

The output of the CreateThing operation.

*/ @interface AWSIoTCreateThingResponse : AWSModel /**

The ARN of the new thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; /**

The thing ID.

*/ @property (nonatomic, strong) NSString * _Nullable thingId; /**

The name of the new thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /**

The input for the CreateThingType operation.

Required parameters: [thingTypeName] */ @interface AWSIoTCreateThingTypeRequest : AWSRequest /**

Metadata which can be used to manage the thing type.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

The name of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; /**

The ThingTypeProperties for the thing type to create. It contains information about the new thing type including a description, and a list of searchable thing attribute names.

*/ @property (nonatomic, strong) AWSIoTThingTypeProperties * _Nullable thingTypeProperties; @end /**

The output of the CreateThingType operation.

*/ @interface AWSIoTCreateThingTypeResponse : AWSModel /**

The Amazon Resource Name (ARN) of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeArn; /**

The thing type ID.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeId; /**

The name of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; @end /** */ @interface AWSIoTCreateTopicRuleDestinationRequest : AWSRequest /**

The topic rule destination configuration.

*/ @property (nonatomic, strong) AWSIoTTopicRuleDestinationConfiguration * _Nullable destinationConfiguration; @end /** */ @interface AWSIoTCreateTopicRuleDestinationResponse : AWSModel /**

The topic rule destination.

*/ @property (nonatomic, strong) AWSIoTTopicRuleDestination * _Nullable topicRuleDestination; @end /**

The input for the CreateTopicRule operation.

Required parameters: [ruleName, topicRulePayload] */ @interface AWSIoTCreateTopicRuleRequest : AWSRequest /**

The name of the rule.

*/ @property (nonatomic, strong) NSString * _Nullable ruleName; /**

Metadata which can be used to manage the topic rule.

For URI Request parameters use format: ...key1=value1&key2=value2...

For the CLI command-line parameter use format: --tags "key1=value1&key2=value2..."

For the cli-input-json file use format: "tags": "key1=value1&key2=value2..."

*/ @property (nonatomic, strong) NSString * _Nullable tags; /**

The rule payload.

*/ @property (nonatomic, strong) AWSIoTTopicRulePayload * _Nullable topicRulePayload; @end /**

Describes a custom method used to code sign a file.

*/ @interface AWSIoTCustomCodeSigning : AWSModel /**

The certificate chain.

*/ @property (nonatomic, strong) AWSIoTCodeSigningCertificateChain * _Nullable certificateChain; /**

The hash algorithm used to code sign the file. You can use a string as the algorithm name if the target over-the-air (OTA) update devices are able to verify the signature that was generated using the same signature algorithm. For example, FreeRTOS uses SHA256 or SHA1, so you can pass either of them based on which was used for generating the signature.

*/ @property (nonatomic, strong) NSString * _Nullable hashAlgorithm; /**

The signature for the file.

*/ @property (nonatomic, strong) AWSIoTCodeSigningSignature * _Nullable signature; /**

The signature algorithm used to code sign the file. You can use a string as the algorithm name if the target over-the-air (OTA) update devices are able to verify the signature that was generated using the same signature algorithm. For example, FreeRTOS uses ECDSA or RSA, so you can pass either of them based on which was used for generating the signature.

*/ @property (nonatomic, strong) NSString * _Nullable signatureAlgorithm; @end /** */ @interface AWSIoTDeleteAccountAuditConfigurationRequest : AWSRequest /**

If true, all scheduled audits are deleted.

*/ @property (nonatomic, strong) NSNumber * _Nullable deleteScheduledAudits; @end /** */ @interface AWSIoTDeleteAccountAuditConfigurationResponse : AWSModel @end /** */ @interface AWSIoTDeleteAuditSuppressionRequest : AWSRequest /**

An audit check name. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

Information that identifies the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; @end /** */ @interface AWSIoTDeleteAuditSuppressionResponse : AWSModel @end /** */ @interface AWSIoTDeleteAuthorizerRequest : AWSRequest /**

The name of the authorizer to delete.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; @end /** */ @interface AWSIoTDeleteAuthorizerResponse : AWSModel @end /** */ @interface AWSIoTDeleteBillingGroupRequest : AWSRequest /**

The name of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The expected version of the billing group. If the version of the billing group does not match the expected version specified in the request, the DeleteBillingGroup request is rejected with a VersionConflictException.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; @end /** */ @interface AWSIoTDeleteBillingGroupResponse : AWSModel @end /**

Input for the DeleteCACertificate operation.

Required parameters: [certificateId] */ @interface AWSIoTDeleteCACertificateRequest : AWSRequest /**

The ID of the certificate to delete. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; @end /**

The output for the DeleteCACertificate operation.

*/ @interface AWSIoTDeleteCACertificateResponse : AWSModel @end /**

The input for the DeleteCertificate operation.

Required parameters: [certificateId] */ @interface AWSIoTDeleteCertificateRequest : AWSRequest /**

The ID of the certificate. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

Forces the deletion of a certificate if it is inactive and is not attached to an IoT thing.

*/ @property (nonatomic, strong) NSNumber * _Nullable forceDelete; @end /** */ @interface AWSIoTDeleteCustomMetricRequest : AWSRequest /**

The name of the custom metric.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; @end /** */ @interface AWSIoTDeleteCustomMetricResponse : AWSModel @end /** */ @interface AWSIoTDeleteDimensionRequest : AWSRequest /**

The unique identifier for the dimension that you want to delete.

*/ @property (nonatomic, strong) NSString * _Nullable name; @end /** */ @interface AWSIoTDeleteDimensionResponse : AWSModel @end /** */ @interface AWSIoTDeleteDomainConfigurationRequest : AWSRequest /**

The name of the domain configuration to be deleted.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationName; @end /** */ @interface AWSIoTDeleteDomainConfigurationResponse : AWSModel @end /** */ @interface AWSIoTDeleteDynamicThingGroupRequest : AWSRequest /**

The expected version of the dynamic thing group to delete.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

The name of the dynamic thing group to delete.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; @end /** */ @interface AWSIoTDeleteDynamicThingGroupResponse : AWSModel @end /** */ @interface AWSIoTDeleteFleetMetricRequest : AWSRequest /**

The expected version of the fleet metric to delete.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

The name of the fleet metric to delete.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; @end /** */ @interface AWSIoTDeleteJobExecutionRequest : AWSRequest /**

The ID of the job execution to be deleted. The executionNumber refers to the execution of a particular job on a particular device.

Note that once a job execution is deleted, the executionNumber may be reused by IoT, so be sure you get and use the correct value here.

*/ @property (nonatomic, strong) NSNumber * _Nullable executionNumber; /**

(Optional) When true, you can delete a job execution which is "IN_PROGRESS". Otherwise, you can only delete a job execution which is in a terminal state ("SUCCEEDED", "FAILED", "REJECTED", "REMOVED" or "CANCELED") or an exception will occur. The default is false.

Deleting a job execution which is "IN_PROGRESS", will cause the device to be unable to access job information or update the job execution status. Use caution and ensure that the device is able to recover to a valid state.

*/ @property (nonatomic, strong) NSNumber * _Nullable force; /**

The ID of the job whose execution on a particular device will be deleted.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The namespace used to indicate that a job is a customer-managed job.

When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.

$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/

The namespaceId feature is in public preview.

*/ @property (nonatomic, strong) NSString * _Nullable namespaceId; /**

The name of the thing whose job execution will be deleted.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTDeleteJobRequest : AWSRequest /**

(Optional) When true, you can delete a job which is "IN_PROGRESS". Otherwise, you can only delete a job which is in a terminal state ("COMPLETED" or "CANCELED") or an exception will occur. The default is false.

Deleting a job which is "IN_PROGRESS", will cause a device which is executing the job to be unable to access job information or update the job execution status. Use caution and ensure that each device executing a job which is deleted is able to recover to a valid state.

*/ @property (nonatomic, strong) NSNumber * _Nullable force; /**

The ID of the job to be deleted.

After a job deletion is completed, you may reuse this jobId when you create a new job. However, this is not recommended, and you must ensure that your devices are not using the jobId to refer to the deleted job.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The namespace used to indicate that a job is a customer-managed job.

When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.

$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/

The namespaceId feature is in public preview.

*/ @property (nonatomic, strong) NSString * _Nullable namespaceId; @end /** */ @interface AWSIoTDeleteJobTemplateRequest : AWSRequest /**

The unique identifier of the job template to delete.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateId; @end /** */ @interface AWSIoTDeleteMitigationActionRequest : AWSRequest /**

The name of the mitigation action that you want to delete.

*/ @property (nonatomic, strong) NSString * _Nullable actionName; @end /** */ @interface AWSIoTDeleteMitigationActionResponse : AWSModel @end /** */ @interface AWSIoTDeleteOTAUpdateRequest : AWSRequest /**

When true, the stream created by the OTAUpdate process is deleted when the OTA update is deleted. Ignored if the stream specified in the OTAUpdate is supplied by the user.

*/ @property (nonatomic, strong) NSNumber * _Nullable deleteStream; /**

When true, deletes the IoT job created by the OTAUpdate process even if it is "IN_PROGRESS". Otherwise, if the job is not in a terminal state ("COMPLETED" or "CANCELED") an exception will occur. The default is false.

*/ @property (nonatomic, strong) NSNumber * _Nullable forceDeleteAWSJob; /**

The ID of the OTA update to delete.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateId; @end /** */ @interface AWSIoTDeleteOTAUpdateResponse : AWSModel @end /** */ @interface AWSIoTDeletePackageRequest : AWSRequest /**

A unique case-sensitive identifier that you can provide to ensure the idempotency of the request. Don't reuse this client token if a new idempotent request is required.

*/ @property (nonatomic, strong) NSString * _Nullable clientToken; /**

The name of the target package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; @end /** */ @interface AWSIoTDeletePackageResponse : AWSModel @end /** */ @interface AWSIoTDeletePackageVersionRequest : AWSRequest /**

A unique case-sensitive identifier that you can provide to ensure the idempotency of the request. Don't reuse this client token if a new idempotent request is required.

*/ @property (nonatomic, strong) NSString * _Nullable clientToken; /**

The name of the associated package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

The name of the target package version.

*/ @property (nonatomic, strong) NSString * _Nullable versionName; @end /** */ @interface AWSIoTDeletePackageVersionResponse : AWSModel @end /**

The input for the DeletePolicy operation.

Required parameters: [policyName] */ @interface AWSIoTDeletePolicyRequest : AWSRequest /**

The name of the policy to delete.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; @end /**

The input for the DeletePolicyVersion operation.

Required parameters: [policyName, policyVersionId] */ @interface AWSIoTDeletePolicyVersionRequest : AWSRequest /**

The name of the policy.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The policy version ID.

*/ @property (nonatomic, strong) NSString * _Nullable policyVersionId; @end /** */ @interface AWSIoTDeleteProvisioningTemplateRequest : AWSRequest /**

The name of the fleet provision template to delete.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /** */ @interface AWSIoTDeleteProvisioningTemplateResponse : AWSModel @end /** */ @interface AWSIoTDeleteProvisioningTemplateVersionRequest : AWSRequest /**

The name of the provisioning template version to delete.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

The provisioning template version ID to delete.

*/ @property (nonatomic, strong) NSNumber * _Nullable versionId; @end /** */ @interface AWSIoTDeleteProvisioningTemplateVersionResponse : AWSModel @end /**

The input for the DeleteRegistrationCode operation.

*/ @interface AWSIoTDeleteRegistrationCodeRequest : AWSRequest @end /**

The output for the DeleteRegistrationCode operation.

*/ @interface AWSIoTDeleteRegistrationCodeResponse : AWSModel @end /** */ @interface AWSIoTDeleteRoleAliasRequest : AWSRequest /**

The role alias to delete.

*/ @property (nonatomic, strong) NSString * _Nullable roleAlias; @end /** */ @interface AWSIoTDeleteRoleAliasResponse : AWSModel @end /** */ @interface AWSIoTDeleteScheduledAuditRequest : AWSRequest /**

The name of the scheduled audit you want to delete.

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditName; @end /** */ @interface AWSIoTDeleteScheduledAuditResponse : AWSModel @end /** */ @interface AWSIoTDeleteSecurityProfileRequest : AWSRequest /**

The expected version of the security profile. A new version is generated whenever the security profile is updated. If you specify a value that is different from the actual version, a VersionConflictException is thrown.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

The name of the security profile to be deleted.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; @end /** */ @interface AWSIoTDeleteSecurityProfileResponse : AWSModel @end /** */ @interface AWSIoTDeleteStreamRequest : AWSRequest /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; @end /** */ @interface AWSIoTDeleteStreamResponse : AWSModel @end /** */ @interface AWSIoTDeleteThingGroupRequest : AWSRequest /**

The expected version of the thing group to delete.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

The name of the thing group to delete.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; @end /** */ @interface AWSIoTDeleteThingGroupResponse : AWSModel @end /**

The input for the DeleteThing operation.

Required parameters: [thingName] */ @interface AWSIoTDeleteThingRequest : AWSRequest /**

The expected version of the thing record in the registry. If the version of the record in the registry does not match the expected version specified in the request, the DeleteThing request is rejected with a VersionConflictException.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

The name of the thing to delete.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /**

The output of the DeleteThing operation.

*/ @interface AWSIoTDeleteThingResponse : AWSModel @end /**

The input for the DeleteThingType operation.

Required parameters: [thingTypeName] */ @interface AWSIoTDeleteThingTypeRequest : AWSRequest /**

The name of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; @end /**

The output for the DeleteThingType operation.

*/ @interface AWSIoTDeleteThingTypeResponse : AWSModel @end /** */ @interface AWSIoTDeleteTopicRuleDestinationRequest : AWSRequest /**

The ARN of the topic rule destination to delete.

*/ @property (nonatomic, strong) NSString * _Nullable arn; @end /** */ @interface AWSIoTDeleteTopicRuleDestinationResponse : AWSModel @end /**

The input for the DeleteTopicRule operation.

Required parameters: [ruleName] */ @interface AWSIoTDeleteTopicRuleRequest : AWSRequest /**

The name of the rule.

*/ @property (nonatomic, strong) NSString * _Nullable ruleName; @end /** */ @interface AWSIoTDeleteV2LoggingLevelRequest : AWSRequest /**

The name of the resource for which you are configuring logging.

*/ @property (nonatomic, strong) NSString * _Nullable targetName; /**

The type of resource for which you are configuring logging. Must be THING_Group.

*/ @property (nonatomic, assign) AWSIoTLogTargetType targetType; @end /**

Contains information that denied the authorization.

*/ @interface AWSIoTDenied : AWSModel /**

Information that explicitly denies the authorization.

*/ @property (nonatomic, strong) AWSIoTExplicitDeny * _Nullable explicitDeny; /**

Information that implicitly denies the authorization. When a policy doesn't explicitly deny or allow an action on a resource it is considered an implicit deny.

*/ @property (nonatomic, strong) AWSIoTImplicitDeny * _Nullable implicitDeny; @end /**

The input for the DeprecateThingType operation.

Required parameters: [thingTypeName] */ @interface AWSIoTDeprecateThingTypeRequest : AWSRequest /**

The name of the thing type to deprecate.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; /**

Whether to undeprecate a deprecated thing type. If true, the thing type will not be deprecated anymore and you can associate it with things.

*/ @property (nonatomic, strong) NSNumber * _Nullable undoDeprecate; @end /**

The output for the DeprecateThingType operation.

*/ @interface AWSIoTDeprecateThingTypeResponse : AWSModel @end /** */ @interface AWSIoTDescribeAccountAuditConfigurationRequest : AWSRequest @end /** */ @interface AWSIoTDescribeAccountAuditConfigurationResponse : AWSModel /**

Which audit checks are enabled and disabled for this account.

*/ @property (nonatomic, strong) NSDictionary * _Nullable auditCheckConfigurations; /**

Information about the targets to which audit notifications are sent for this account.

*/ @property (nonatomic, strong) NSDictionary * _Nullable auditNotificationTargetConfigurations; /**

The ARN of the role that grants permission to IoT to access information about your devices, policies, certificates, and other items as required when performing an audit.

On the first call to UpdateAccountAuditConfiguration, this parameter is required.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /** */ @interface AWSIoTDescribeAuditFindingRequest : AWSRequest /**

A unique identifier for a single audit finding. You can use this identifier to apply mitigation actions to the finding.

*/ @property (nonatomic, strong) NSString * _Nullable findingId; @end /** */ @interface AWSIoTDescribeAuditFindingResponse : AWSModel /**

The findings (results) of the audit.

*/ @property (nonatomic, strong) AWSIoTAuditFinding * _Nullable finding; @end /** */ @interface AWSIoTDescribeAuditMitigationActionsTaskRequest : AWSRequest /**

The unique identifier for the audit mitigation task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTDescribeAuditMitigationActionsTaskResponse : AWSModel /**

Specifies the mitigation actions and their parameters that are applied as part of this task.

*/ @property (nonatomic, strong) NSArray * _Nullable actionsDefinition; /**

Specifies the mitigation actions that should be applied to specific audit checks.

*/ @property (nonatomic, strong) NSDictionary *> * _Nullable auditCheckToActionsMapping; /**

The date and time when the task was completed or canceled.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

The date and time when the task was started.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

Identifies the findings to which the mitigation actions are applied. This can be by audit checks, by audit task, or a set of findings.

*/ @property (nonatomic, strong) AWSIoTAuditMitigationActionsTaskTarget * _Nullable target; /**

Aggregate counts of the results when the mitigation tasks were applied to the findings for this audit mitigation actions task.

*/ @property (nonatomic, strong) NSDictionary * _Nullable taskStatistics; /**

The current status of the task.

*/ @property (nonatomic, assign) AWSIoTAuditMitigationActionsTaskStatus taskStatus; @end /** */ @interface AWSIoTDescribeAuditSuppressionRequest : AWSRequest /**

An audit check name. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

Information that identifies the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; @end /** */ @interface AWSIoTDescribeAuditSuppressionResponse : AWSModel /**

An audit check name. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

The description of the audit suppression.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The epoch timestamp in seconds at which this suppression expires.

*/ @property (nonatomic, strong) NSDate * _Nullable expirationDate; /**

Information that identifies the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; /**

Indicates whether a suppression should exist indefinitely or not.

*/ @property (nonatomic, strong) NSNumber * _Nullable suppressIndefinitely; @end /** */ @interface AWSIoTDescribeAuditTaskRequest : AWSRequest /**

The ID of the audit whose information you want to get.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTDescribeAuditTaskResponse : AWSModel /**

Detailed information about each check performed during this audit.

*/ @property (nonatomic, strong) NSDictionary * _Nullable auditDetails; /**

The name of the scheduled audit (only if the audit was a scheduled audit).

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditName; /**

The time the audit started.

*/ @property (nonatomic, strong) NSDate * _Nullable taskStartTime; /**

Statistical information about the audit.

*/ @property (nonatomic, strong) AWSIoTTaskStatistics * _Nullable taskStatistics; /**

The status of the audit: one of "IN_PROGRESS", "COMPLETED", "FAILED", or "CANCELED".

*/ @property (nonatomic, assign) AWSIoTAuditTaskStatus taskStatus; /**

The type of audit: "ON_DEMAND_AUDIT_TASK" or "SCHEDULED_AUDIT_TASK".

*/ @property (nonatomic, assign) AWSIoTAuditTaskType taskType; @end /** */ @interface AWSIoTDescribeAuthorizerRequest : AWSRequest /**

The name of the authorizer to describe.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; @end /** */ @interface AWSIoTDescribeAuthorizerResponse : AWSModel /**

The authorizer description.

*/ @property (nonatomic, strong) AWSIoTAuthorizerDescription * _Nullable authorizerDescription; @end /** */ @interface AWSIoTDescribeBillingGroupRequest : AWSRequest /**

The name of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; @end /** */ @interface AWSIoTDescribeBillingGroupResponse : AWSModel /**

The ARN of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupArn; /**

The ID of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupId; /**

Additional information about the billing group.

*/ @property (nonatomic, strong) AWSIoTBillingGroupMetadata * _Nullable billingGroupMetadata; /**

The name of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The properties of the billing group.

*/ @property (nonatomic, strong) AWSIoTBillingGroupProperties * _Nullable billingGroupProperties; /**

The version of the billing group.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /**

The input for the DescribeCACertificate operation.

Required parameters: [certificateId] */ @interface AWSIoTDescribeCACertificateRequest : AWSRequest /**

The CA certificate identifier.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; @end /**

The output from the DescribeCACertificate operation.

*/ @interface AWSIoTDescribeCACertificateResponse : AWSModel /**

The CA certificate description.

*/ @property (nonatomic, strong) AWSIoTCACertificateDescription * _Nullable certificateDescription; /**

Information about the registration configuration.

*/ @property (nonatomic, strong) AWSIoTRegistrationConfig * _Nullable registrationConfig; @end /**

The input for the DescribeCertificate operation.

Required parameters: [certificateId] */ @interface AWSIoTDescribeCertificateRequest : AWSRequest /**

The ID of the certificate. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; @end /**

The output of the DescribeCertificate operation.

*/ @interface AWSIoTDescribeCertificateResponse : AWSModel /**

The description of the certificate.

*/ @property (nonatomic, strong) AWSIoTCertificateDescription * _Nullable certificateDescription; @end /** */ @interface AWSIoTDescribeCustomMetricRequest : AWSRequest /**

The name of the custom metric.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; @end /** */ @interface AWSIoTDescribeCustomMetricResponse : AWSModel /**

The creation date of the custom metric in milliseconds since epoch.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

Field represents a friendly name in the console for the custom metric; doesn't have to be unique. Don't use this name as the metric identifier in the device metric report. Can be updated.

*/ @property (nonatomic, strong) NSString * _Nullable displayName; /**

The time the custom metric was last modified in milliseconds since epoch.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The Amazon Resource Number (ARN) of the custom metric.

*/ @property (nonatomic, strong) NSString * _Nullable metricArn; /**

The name of the custom metric.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The type of the custom metric.

The type number only takes a single metric value as an input, but while submitting the metrics value in the DeviceMetrics report, it must be passed as an array with a single value.

*/ @property (nonatomic, assign) AWSIoTCustomMetricType metricType; @end /** */ @interface AWSIoTDescribeDefaultAuthorizerRequest : AWSRequest @end /** */ @interface AWSIoTDescribeDefaultAuthorizerResponse : AWSModel /**

The default authorizer's description.

*/ @property (nonatomic, strong) AWSIoTAuthorizerDescription * _Nullable authorizerDescription; @end /** */ @interface AWSIoTDescribeDetectMitigationActionsTaskRequest : AWSRequest /**

The unique identifier of the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTDescribeDetectMitigationActionsTaskResponse : AWSModel /**

The description of a task.

*/ @property (nonatomic, strong) AWSIoTDetectMitigationActionsTaskSummary * _Nullable taskSummary; @end /** */ @interface AWSIoTDescribeDimensionRequest : AWSRequest /**

The unique identifier for the dimension.

*/ @property (nonatomic, strong) NSString * _Nullable name; @end /** */ @interface AWSIoTDescribeDimensionResponse : AWSModel /**

The Amazon Resource Name (ARN) for the dimension.

*/ @property (nonatomic, strong) NSString * _Nullable arn; /**

The date the dimension was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The date the dimension was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The unique identifier for the dimension.

*/ @property (nonatomic, strong) NSString * _Nullable name; /**

The value or list of values used to scope the dimension. For example, for topic filters, this is the pattern used to match the MQTT topic name.

*/ @property (nonatomic, strong) NSArray * _Nullable stringValues; /**

The type of the dimension.

*/ @property (nonatomic, assign) AWSIoTDimensionType types; @end /** */ @interface AWSIoTDescribeDomainConfigurationRequest : AWSRequest /**

The name of the domain configuration.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationName; @end /** */ @interface AWSIoTDescribeDomainConfigurationResponse : AWSModel /**

An object that specifies the authorization service for a domain.

*/ @property (nonatomic, strong) AWSIoTAuthorizerConfig * _Nullable authorizerConfig; /**

The ARN of the domain configuration.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationArn; /**

The name of the domain configuration.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationName; /**

A Boolean value that specifies the current state of the domain configuration.

*/ @property (nonatomic, assign) AWSIoTDomainConfigurationStatus domainConfigurationStatus; /**

The name of the domain.

*/ @property (nonatomic, strong) NSString * _Nullable domainName; /**

The type of the domain.

*/ @property (nonatomic, assign) AWSIoTDomainType domainType; /**

The date and time the domain configuration's status was last changed.

*/ @property (nonatomic, strong) NSDate * _Nullable lastStatusChangeDate; /**

A list containing summary information about the server certificate included in the domain configuration.

*/ @property (nonatomic, strong) NSArray * _Nullable serverCertificates; /**

The type of service delivered by the endpoint.

*/ @property (nonatomic, assign) AWSIoTServiceType serviceType; /**

An object that specifies the TLS configuration for a domain.

*/ @property (nonatomic, strong) AWSIoTTlsConfig * _Nullable tlsConfig; @end /**

The input for the DescribeEndpoint operation.

*/ @interface AWSIoTDescribeEndpointRequest : AWSRequest /**

The endpoint type. Valid endpoint types include:

  • iot:Data - Returns a VeriSign signed data endpoint.

  • iot:Data-ATS - Returns an ATS signed data endpoint.

  • iot:CredentialProvider - Returns an IoT credentials provider API endpoint.

  • iot:Jobs - Returns an IoT device management Jobs API endpoint.

We strongly recommend that customers use the newer iot:Data-ATS endpoint type to avoid issues related to the widespread distrust of Symantec certificate authorities.

*/ @property (nonatomic, strong) NSString * _Nullable endpointType; @end /**

The output from the DescribeEndpoint operation.

*/ @interface AWSIoTDescribeEndpointResponse : AWSModel /**

The endpoint. The format of the endpoint is as follows: identifier.iot.region.amazonaws.com.

*/ @property (nonatomic, strong) NSString * _Nullable endpointAddress; @end /** */ @interface AWSIoTDescribeEventConfigurationsRequest : AWSRequest @end /** */ @interface AWSIoTDescribeEventConfigurationsResponse : AWSModel /**

The creation date of the event configuration.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The event configurations.

*/ @property (nonatomic, strong) NSDictionary * _Nullable eventConfigurations; /**

The date the event configurations were last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; @end /** */ @interface AWSIoTDescribeFleetMetricRequest : AWSRequest /**

The name of the fleet metric to describe.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; @end /** */ @interface AWSIoTDescribeFleetMetricResponse : AWSModel /**

The field to aggregate.

*/ @property (nonatomic, strong) NSString * _Nullable aggregationField; /**

The type of the aggregation query.

*/ @property (nonatomic, strong) AWSIoTAggregationType * _Nullable aggregationType; /**

The date when the fleet metric is created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The fleet metric description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The name of the index to search.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The date when the fleet metric is last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The ARN of the fleet metric to describe.

*/ @property (nonatomic, strong) NSString * _Nullable metricArn; /**

The name of the fleet metric to describe.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The time in seconds between fleet metric emissions. Range [60(1 min), 86400(1 day)] and must be multiple of 60.

*/ @property (nonatomic, strong) NSNumber * _Nullable period; /**

The search query string.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The query version.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; /**

Used to support unit transformation such as milliseconds to seconds. The unit must be supported by CW metric.

*/ @property (nonatomic, assign) AWSIoTFleetMetricUnit unit; /**

The version of the fleet metric.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /** */ @interface AWSIoTDescribeIndexRequest : AWSRequest /**

The index name.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; @end /** */ @interface AWSIoTDescribeIndexResponse : AWSModel /**

The index name.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The index status.

*/ @property (nonatomic, assign) AWSIoTIndexStatus indexStatus; /**

Contains a value that specifies the type of indexing performed. Valid values are:

  • REGISTRY – Your thing index contains only registry data.

  • REGISTRY_AND_SHADOW - Your thing index contains registry data and shadow data.

  • REGISTRY_AND_CONNECTIVITY_STATUS - Your thing index contains registry data and thing connectivity status data.

  • REGISTRY_AND_SHADOW_AND_CONNECTIVITY_STATUS - Your thing index contains registry data, shadow data, and thing connectivity status data.

  • MULTI_INDEXING_MODE - Your thing index contains multiple data sources. For more information, see GetIndexingConfiguration.

*/ @property (nonatomic, strong) NSString * _Nullable schema; @end /** */ @interface AWSIoTDescribeJobExecutionRequest : AWSRequest /**

A string (consisting of the digits "0" through "9" which is used to specify a particular job execution on a particular device.

*/ @property (nonatomic, strong) NSNumber * _Nullable executionNumber; /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The name of the thing on which the job execution is running.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTDescribeJobExecutionResponse : AWSModel /**

Information about the job execution.

*/ @property (nonatomic, strong) AWSIoTJobExecution * _Nullable execution; @end /** */ @interface AWSIoTDescribeJobRequest : AWSRequest /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; @end /** */ @interface AWSIoTDescribeJobResponse : AWSModel /**

An S3 link to the job document.

*/ @property (nonatomic, strong) NSString * _Nullable documentSource; /**

Information about the job.

*/ @property (nonatomic, strong) AWSIoTJob * _Nullable job; @end /** */ @interface AWSIoTDescribeJobTemplateRequest : AWSRequest /**

The unique identifier of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateId; @end /** */ @interface AWSIoTDescribeJobTemplateResponse : AWSModel /**

The criteria that determine when and how a job abort takes place.

*/ @property (nonatomic, strong) AWSIoTAbortConfig * _Nullable abortConfig; /**

The time, in seconds since the epoch, when the job template was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

A description of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The package version Amazon Resource Names (ARNs) that are installed on the device when the job successfully completes.

Note:The following Length Constraints relates to a single string. Up to five strings are allowed.

*/ @property (nonatomic, strong) NSArray * _Nullable destinationPackageVersions; /**

The job document.

*/ @property (nonatomic, strong) NSString * _Nullable document; /**

An S3 link to the job document.

*/ @property (nonatomic, strong) NSString * _Nullable documentSource; /**

The configuration that determines how many retries are allowed for each failure type for a job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRetryConfig * _Nullable jobExecutionsRetryConfig; /**

Allows you to create a staged rollout of a job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRolloutConfig * _Nullable jobExecutionsRolloutConfig; /**

The ARN of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateArn; /**

The unique identifier of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateId; /**

Allows you to configure an optional maintenance window for the rollout of a job document to all devices in the target group for a job.

*/ @property (nonatomic, strong) NSArray * _Nullable maintenanceWindows; /**

Configuration for pre-signed S3 URLs.

*/ @property (nonatomic, strong) AWSIoTPresignedUrlConfig * _Nullable presignedUrlConfig; /**

Specifies the amount of time each device has to finish its execution of the job. A timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the timer expires, it will be automatically set to TIMED_OUT.

*/ @property (nonatomic, strong) AWSIoTTimeoutConfig * _Nullable timeoutConfig; @end /** */ @interface AWSIoTDescribeManagedJobTemplateRequest : AWSRequest /**

The unique name of a managed job template, which is required.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

An optional parameter to specify version of a managed template. If not specified, the pre-defined default version is returned.

*/ @property (nonatomic, strong) NSString * _Nullable templateVersion; @end /** */ @interface AWSIoTDescribeManagedJobTemplateResponse : AWSModel /**

The unique description of a managed template.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The document schema for a managed job template.

*/ @property (nonatomic, strong) NSString * _Nullable document; /**

A map of key-value pairs that you can use as guidance to specify the inputs for creating a job from a managed template.

documentParameters can only be used when creating jobs from Amazon Web Services managed templates. This parameter can't be used with custom job templates or to create jobs from them.

*/ @property (nonatomic, strong) NSArray * _Nullable documentParameters; /**

A list of environments that are supported with the managed job template.

*/ @property (nonatomic, strong) NSArray * _Nullable environments; /**

The unique Amazon Resource Name (ARN) of the managed template.

*/ @property (nonatomic, strong) NSString * _Nullable templateArn; /**

The unique name of a managed template, such as AWS-Reboot.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

The version for a managed template.

*/ @property (nonatomic, strong) NSString * _Nullable templateVersion; @end /** */ @interface AWSIoTDescribeMitigationActionRequest : AWSRequest /**

The friendly name that uniquely identifies the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionName; @end /** */ @interface AWSIoTDescribeMitigationActionResponse : AWSModel /**

The ARN that identifies this migration action.

*/ @property (nonatomic, strong) NSString * _Nullable actionArn; /**

A unique identifier for this action.

*/ @property (nonatomic, strong) NSString * _Nullable actionId; /**

The friendly name that uniquely identifies the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionName; /**

Parameters that control how the mitigation action is applied, specific to the type of mitigation action.

*/ @property (nonatomic, strong) AWSIoTMitigationActionParams * _Nullable actionParams; /**

The type of mitigation action.

*/ @property (nonatomic, assign) AWSIoTMitigationActionType actionType; /**

The date and time when the mitigation action was added to your Amazon Web Services accounts.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The date and time when the mitigation action was last changed.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The ARN of the IAM role used to apply this action.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /** */ @interface AWSIoTDescribeProvisioningTemplateRequest : AWSRequest /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /** */ @interface AWSIoTDescribeProvisioningTemplateResponse : AWSModel /**

The date when the provisioning template was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The default fleet template version ID.

*/ @property (nonatomic, strong) NSNumber * _Nullable defaultVersionId; /**

The description of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

True if the provisioning template is enabled, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable enabled; /**

The date when the provisioning template was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

Gets information about a pre-provisioned hook.

*/ @property (nonatomic, strong) AWSIoTProvisioningHook * _Nullable preProvisioningHook; /**

The ARN of the role associated with the provisioning template. This IoT role grants permission to provision a device.

*/ @property (nonatomic, strong) NSString * _Nullable provisioningRoleArn; /**

The ARN of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateArn; /**

The JSON formatted contents of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateBody; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

The type you define in a provisioning template. You can create a template with only one type. You can't change the template type after its creation. The default value is FLEET_PROVISIONING. For more information about provisioning template, see: Provisioning template.

*/ @property (nonatomic, assign) AWSIoTTemplateType types; @end /** */ @interface AWSIoTDescribeProvisioningTemplateVersionRequest : AWSRequest /**

The template name.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

The provisioning template version ID.

*/ @property (nonatomic, strong) NSNumber * _Nullable versionId; @end /** */ @interface AWSIoTDescribeProvisioningTemplateVersionResponse : AWSModel /**

The date when the provisioning template version was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

True if the provisioning template version is the default version.

*/ @property (nonatomic, strong) NSNumber * _Nullable isDefaultVersion; /**

The JSON formatted contents of the provisioning template version.

*/ @property (nonatomic, strong) NSString * _Nullable templateBody; /**

The provisioning template version ID.

*/ @property (nonatomic, strong) NSNumber * _Nullable versionId; @end /** */ @interface AWSIoTDescribeRoleAliasRequest : AWSRequest /**

The role alias to describe.

*/ @property (nonatomic, strong) NSString * _Nullable roleAlias; @end /** */ @interface AWSIoTDescribeRoleAliasResponse : AWSModel /**

The role alias description.

*/ @property (nonatomic, strong) AWSIoTRoleAliasDescription * _Nullable roleAliasDescription; @end /** */ @interface AWSIoTDescribeScheduledAuditRequest : AWSRequest /**

The name of the scheduled audit whose information you want to get.

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditName; @end /** */ @interface AWSIoTDescribeScheduledAuditResponse : AWSModel /**

The day of the month on which the scheduled audit takes place. This is will be 1 through 31 or LAST. If days 29-31 are specified, and the month does not have that many days, the audit takes place on the LAST day of the month.

*/ @property (nonatomic, strong) NSString * _Nullable dayOfMonth; /**

The day of the week on which the scheduled audit takes place, either one of SUN, MON, TUE, WED, THU, FRI, or SAT.

*/ @property (nonatomic, assign) AWSIoTDayOfWeek dayOfWeek; /**

How often the scheduled audit takes place, either one of DAILY, WEEKLY, BIWEEKLY, or MONTHLY. The start time of each audit is determined by the system.

*/ @property (nonatomic, assign) AWSIoTAuditFrequency frequency; /**

The ARN of the scheduled audit.

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditArn; /**

The name of the scheduled audit.

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditName; /**

Which checks are performed during the scheduled audit. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSArray * _Nullable targetCheckNames; @end /** */ @interface AWSIoTDescribeSecurityProfileRequest : AWSRequest /**

The name of the security profile whose information you want to get.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; @end /** */ @interface AWSIoTDescribeSecurityProfileResponse : AWSModel /**

Please use DescribeSecurityProfileResponse$additionalMetricsToRetainV2 instead.

A list of metrics whose data is retained (stored). By default, data is retained for any metric used in the profile's behaviors, but it is also retained for any metric specified here.

*/ @property (nonatomic, strong) NSArray * _Nullable additionalMetricsToRetain; /**

A list of metrics whose data is retained (stored). By default, data is retained for any metric used in the profile's behaviors, but it is also retained for any metric specified here.

*/ @property (nonatomic, strong) NSArray * _Nullable additionalMetricsToRetainV2; /**

Where the alerts are sent. (Alerts are always sent to the console.)

*/ @property (nonatomic, strong) NSDictionary * _Nullable alertTargets; /**

Specifies the behaviors that, when violated by a device (thing), cause an alert.

*/ @property (nonatomic, strong) NSArray * _Nullable behaviors; /**

The time the security profile was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The time the security profile was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The ARN of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileArn; /**

A description of the security profile (associated with the security profile when it was created or updated).

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileDescription; /**

The name of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The version of the security profile. A new version is generated whenever the security profile is updated.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /** */ @interface AWSIoTDescribeStreamRequest : AWSRequest /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; @end /** */ @interface AWSIoTDescribeStreamResponse : AWSModel /**

Information about the stream.

*/ @property (nonatomic, strong) AWSIoTStreamInfo * _Nullable streamInfo; @end /** */ @interface AWSIoTDescribeThingGroupRequest : AWSRequest /**

The name of the thing group.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; @end /** */ @interface AWSIoTDescribeThingGroupResponse : AWSModel /**

The dynamic thing group index name.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The dynamic thing group search query string.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The dynamic thing group query version.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; /**

The dynamic thing group status.

*/ @property (nonatomic, assign) AWSIoTDynamicGroupStatus status; /**

The thing group ARN.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupArn; /**

The thing group ID.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupId; /**

Thing group metadata.

*/ @property (nonatomic, strong) AWSIoTThingGroupMetadata * _Nullable thingGroupMetadata; /**

The name of the thing group.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; /**

The thing group properties.

*/ @property (nonatomic, strong) AWSIoTThingGroupProperties * _Nullable thingGroupProperties; /**

The version of the thing group.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /** */ @interface AWSIoTDescribeThingRegistrationTaskRequest : AWSRequest /**

The task ID.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTDescribeThingRegistrationTaskResponse : AWSModel /**

The task creation date.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The number of things that failed to be provisioned.

*/ @property (nonatomic, strong) NSNumber * _Nullable failureCount; /**

The S3 bucket that contains the input file.

*/ @property (nonatomic, strong) NSString * _Nullable inputFileBucket; /**

The input file key.

*/ @property (nonatomic, strong) NSString * _Nullable inputFileKey; /**

The date when the task was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The message.

*/ @property (nonatomic, strong) NSString * _Nullable message; /**

The progress of the bulk provisioning task expressed as a percentage.

*/ @property (nonatomic, strong) NSNumber * _Nullable percentageProgress; /**

The role ARN that grants access to the input file bucket.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The status of the bulk thing provisioning task.

*/ @property (nonatomic, assign) AWSIoTStatus status; /**

The number of things successfully provisioned.

*/ @property (nonatomic, strong) NSNumber * _Nullable successCount; /**

The task ID.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; /**

The task's template.

*/ @property (nonatomic, strong) NSString * _Nullable templateBody; @end /**

The input for the DescribeThing operation.

Required parameters: [thingName] */ @interface AWSIoTDescribeThingRequest : AWSRequest /**

The name of the thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /**

The output from the DescribeThing operation.

*/ @interface AWSIoTDescribeThingResponse : AWSModel /**

The thing attributes.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

The name of the billing group the thing belongs to.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The default MQTT client ID. For a typical device, the thing name is also used as the default MQTT client ID. Although we don’t require a mapping between a thing's registry name and its use of MQTT client IDs, certificates, or shadow state, we recommend that you choose a thing name and use it as the MQTT client ID for the registry and the Device Shadow service.

This lets you better organize your IoT fleet without removing the flexibility of the underlying device certificate model or shadows.

*/ @property (nonatomic, strong) NSString * _Nullable defaultClientId; /**

The ARN of the thing to describe.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; /**

The ID of the thing to describe.

*/ @property (nonatomic, strong) NSString * _Nullable thingId; /**

The name of the thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The thing type name.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; /**

The current version of the thing record in the registry.

To avoid unintentional changes to the information in the registry, you can pass the version information in the expectedVersion parameter of the UpdateThing and DeleteThing calls.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /**

The input for the DescribeThingType operation.

Required parameters: [thingTypeName] */ @interface AWSIoTDescribeThingTypeRequest : AWSRequest /**

The name of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; @end /**

The output for the DescribeThingType operation.

*/ @interface AWSIoTDescribeThingTypeResponse : AWSModel /**

The thing type ARN.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeArn; /**

The thing type ID.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeId; /**

The ThingTypeMetadata contains additional information about the thing type including: creation date and time, a value indicating whether the thing type is deprecated, and a date and time when it was deprecated.

*/ @property (nonatomic, strong) AWSIoTThingTypeMetadata * _Nullable thingTypeMetadata; /**

The name of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; /**

The ThingTypeProperties contains information about the thing type including description, and a list of searchable thing attribute names.

*/ @property (nonatomic, strong) AWSIoTThingTypeProperties * _Nullable thingTypeProperties; @end /**

Describes the location of the updated firmware.

*/ @interface AWSIoTDestination : AWSModel /**

Describes the location in S3 of the updated firmware.

*/ @property (nonatomic, strong) AWSIoTS3Destination * _Nullable s3Destination; @end /** */ @interface AWSIoTDetachPolicyRequest : AWSRequest /**

The policy to detach.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The target from which the policy will be detached.

*/ @property (nonatomic, strong) NSString * _Nullable target; @end /**

The input for the DetachPrincipalPolicy operation.

Required parameters: [policyName, principal] */ @interface AWSIoTDetachPrincipalPolicyRequest : AWSRequest /**

The name of the policy to detach.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The principal.

Valid principals are CertificateArn (arn:aws:iot:region:accountId:cert/certificateId), thingGroupArn (arn:aws:iot:region:accountId:thinggroup/groupName) and CognitoId (region:id).

*/ @property (nonatomic, strong) NSString * _Nullable principal; @end /** */ @interface AWSIoTDetachSecurityProfileRequest : AWSRequest /**

The security profile that is detached.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The ARN of the thing group from which the security profile is detached.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileTargetArn; @end /** */ @interface AWSIoTDetachSecurityProfileResponse : AWSModel @end /**

The input for the DetachThingPrincipal operation.

Required parameters: [thingName, principal] */ @interface AWSIoTDetachThingPrincipalRequest : AWSRequest /**

If the principal is a certificate, this value must be ARN of the certificate. If the principal is an Amazon Cognito identity, this value must be the ID of the Amazon Cognito identity.

*/ @property (nonatomic, strong) NSString * _Nullable principal; /**

The name of the thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /**

The output from the DetachThingPrincipal operation.

*/ @interface AWSIoTDetachThingPrincipalResponse : AWSModel @end /**

Describes which mitigation actions should be executed.

*/ @interface AWSIoTDetectMitigationActionExecution : AWSModel /**

The friendly name that uniquely identifies the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionName; /**

The error code of a mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable errorCode; /**

The date a mitigation action ended.

*/ @property (nonatomic, strong) NSDate * _Nullable executionEndDate; /**

The date a mitigation action was started.

*/ @property (nonatomic, strong) NSDate * _Nullable executionStartDate; /**

The message of a mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable message; /**

The status of a mitigation action.

*/ @property (nonatomic, assign) AWSIoTDetectMitigationActionExecutionStatus status; /**

The unique identifier of the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; /**

The name of the thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The unique identifier of the violation.

*/ @property (nonatomic, strong) NSString * _Nullable violationId; @end /**

The statistics of a mitigation action task.

*/ @interface AWSIoTDetectMitigationActionsTaskStatistics : AWSModel /**

The actions that were performed.

*/ @property (nonatomic, strong) NSNumber * _Nullable actionsExecuted; /**

The actions that failed.

*/ @property (nonatomic, strong) NSNumber * _Nullable actionsFailed; /**

The actions that were skipped.

*/ @property (nonatomic, strong) NSNumber * _Nullable actionsSkipped; @end /**

The summary of the mitigation action tasks.

*/ @interface AWSIoTDetectMitigationActionsTaskSummary : AWSModel /**

The definition of the actions.

*/ @property (nonatomic, strong) NSArray * _Nullable actionsDefinition; /**

Includes only active violations.

*/ @property (nonatomic, strong) NSNumber * _Nullable onlyActiveViolationsIncluded; /**

Includes suppressed alerts.

*/ @property (nonatomic, strong) NSNumber * _Nullable suppressedAlertsIncluded; /**

Specifies the ML Detect findings to which the mitigation actions are applied.

*/ @property (nonatomic, strong) AWSIoTDetectMitigationActionsTaskTarget * _Nullable target; /**

The date the task ended.

*/ @property (nonatomic, strong) NSDate * _Nullable taskEndTime; /**

The unique identifier of the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; /**

The date the task started.

*/ @property (nonatomic, strong) NSDate * _Nullable taskStartTime; /**

The statistics of a mitigation action task.

*/ @property (nonatomic, strong) AWSIoTDetectMitigationActionsTaskStatistics * _Nullable taskStatistics; /**

The status of the task.

*/ @property (nonatomic, assign) AWSIoTDetectMitigationActionsTaskStatus taskStatus; /**

Specifies the time period of which violation events occurred between.

*/ @property (nonatomic, strong) AWSIoTViolationEventOccurrenceRange * _Nullable violationEventOccurrenceRange; @end /**

The target of a mitigation action task.

*/ @interface AWSIoTDetectMitigationActionsTaskTarget : AWSModel /**

The name of the behavior.

*/ @property (nonatomic, strong) NSString * _Nullable behaviorName; /**

The name of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The unique identifiers of the violations.

*/ @property (nonatomic, strong) NSArray * _Nullable violationIds; @end /**

The input for the DisableTopicRuleRequest operation.

Required parameters: [ruleName] */ @interface AWSIoTDisableTopicRuleRequest : AWSRequest /**

The name of the rule to disable.

*/ @property (nonatomic, strong) NSString * _Nullable ruleName; @end /**

A map of key-value pairs containing the patterns that need to be replaced in a managed template job document schema. You can use the description of each key as a guidance to specify the inputs during runtime when creating a job.

documentParameters can only be used when creating jobs from Amazon Web Services managed templates. This parameter can't be used with custom job templates or to create jobs from them.

*/ @interface AWSIoTDocumentParameter : AWSModel /**

Description of the map field containing the patterns that need to be replaced in a managed template job document schema.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

An example illustrating a pattern that need to be replaced in a managed template job document schema.

*/ @property (nonatomic, strong) NSString * _Nullable example; /**

Key of the map field containing the patterns that need to be replaced in a managed template job document schema.

*/ @property (nonatomic, strong) NSString * _Nullable key; /**

Specifies whether a pattern that needs to be replaced in a managed template job document schema is optional or required.

*/ @property (nonatomic, strong) NSNumber * _Nullable optionalValue; /**

A regular expression of the patterns that need to be replaced in a managed template job document schema.

*/ @property (nonatomic, strong) NSString * _Nullable regex; @end /**

The summary of a domain configuration. A domain configuration specifies custom IoT-specific information about a domain. A domain configuration can be associated with an Amazon Web Services-managed domain (for example, dbc123defghijk.iot.us-west-2.amazonaws.com), a customer managed domain, or a default endpoint.

  • Data

  • Jobs

  • CredentialProvider

*/ @interface AWSIoTDomainConfigurationSummary : AWSModel /**

The ARN of the domain configuration.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationArn; /**

The name of the domain configuration. This value must be unique to a region.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationName; /**

The type of service delivered by the endpoint.

*/ @property (nonatomic, assign) AWSIoTServiceType serviceType; @end /**

Describes an action to write to a DynamoDB table.

The tableName, hashKeyField, and rangeKeyField values must match the values used when you created the table.

The hashKeyValue and rangeKeyvalue fields use a substitution template syntax. These templates provide data at runtime. The syntax is as follows: ${sql-expression}.

You can specify any valid expression in a WHERE or SELECT clause, including JSON properties, comparisons, calculations, and functions. For example, the following field uses the third level of the topic:

"hashKeyValue": "${topic(3)}"

The following field uses the timestamp:

"rangeKeyValue": "${timestamp()}"

Required parameters: [tableName, roleArn, hashKeyField, hashKeyValue] */ @interface AWSIoTDynamoDBAction : AWSModel /**

The hash key name.

*/ @property (nonatomic, strong) NSString * _Nullable hashKeyField; /**

The hash key type. Valid values are "STRING" or "NUMBER"

*/ @property (nonatomic, assign) AWSIoTDynamoKeyType hashKeyType; /**

The hash key value.

*/ @property (nonatomic, strong) NSString * _Nullable hashKeyValue; /**

The type of operation to be performed. This follows the substitution template, so it can be ${operation}, but the substitution must result in one of the following: INSERT, UPDATE, or DELETE.

*/ @property (nonatomic, strong) NSString * _Nullable operation; /**

The action payload. This name can be customized.

*/ @property (nonatomic, strong) NSString * _Nullable payloadField; /**

The range key name.

*/ @property (nonatomic, strong) NSString * _Nullable rangeKeyField; /**

The range key type. Valid values are "STRING" or "NUMBER"

*/ @property (nonatomic, assign) AWSIoTDynamoKeyType rangeKeyType; /**

The range key value.

*/ @property (nonatomic, strong) NSString * _Nullable rangeKeyValue; /**

The ARN of the IAM role that grants access to the DynamoDB table.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The name of the DynamoDB table.

*/ @property (nonatomic, strong) NSString * _Nullable tableName; @end /**

Describes an action to write to a DynamoDB table.

This DynamoDB action writes each attribute in the message payload into it's own column in the DynamoDB table.

Required parameters: [roleArn, putItem] */ @interface AWSIoTDynamoDBv2Action : AWSModel /**

Specifies the DynamoDB table to which the message data will be written. For example:

{ "dynamoDBv2": { "roleArn": "aws:iam:12341251:my-role" "putItem": { "tableName": "my-table" } } }

Each attribute in the message payload will be written to a separate column in the DynamoDB database.

*/ @property (nonatomic, strong) AWSIoTPutItemInput * _Nullable putItem; /**

The ARN of the IAM role that grants access to the DynamoDB table.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

The policy that has the effect on the authorization results.

*/ @interface AWSIoTEffectivePolicy : AWSModel /**

The policy ARN.

*/ @property (nonatomic, strong) NSString * _Nullable policyArn; /**

The IAM policy document.

*/ @property (nonatomic, strong) NSString * _Nullable policyDocument; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; @end /**

Describes an action that writes data to an Amazon OpenSearch Service domain.

The Elasticsearch action can only be used by existing rule actions. To create a new rule action or to update an existing rule action, use the OpenSearch rule action instead. For more information, see OpenSearchAction.

Required parameters: [roleArn, endpoint, index, type, id] */ @interface AWSIoTElasticsearchAction : AWSModel /**

The endpoint of your OpenSearch domain.

*/ @property (nonatomic, strong) NSString * _Nullable endpoint; /**

The unique identifier for the document you are storing.

*/ @property (nonatomic, strong) NSString * _Nullable identifier; /**

The index where you want to store your data.

*/ @property (nonatomic, strong) NSString * _Nullable index; /**

The IAM role ARN that has access to OpenSearch.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The type of document you are storing.

*/ @property (nonatomic, strong) NSString * _Nullable types; @end /**

Parameters used when defining a mitigation action that enable Amazon Web Services IoT Core logging.

Required parameters: [roleArnForLogging, logLevel] */ @interface AWSIoTEnableIoTLoggingParams : AWSModel /**

Specifies the type of information to be logged.

*/ @property (nonatomic, assign) AWSIoTLogLevel logLevel; /**

The Amazon Resource Name (ARN) of the IAM role used for logging.

*/ @property (nonatomic, strong) NSString * _Nullable roleArnForLogging; @end /**

The input for the EnableTopicRuleRequest operation.

Required parameters: [ruleName] */ @interface AWSIoTEnableTopicRuleRequest : AWSRequest /**

The name of the topic rule to enable.

*/ @property (nonatomic, strong) NSString * _Nullable ruleName; @end /**

Error information.

*/ @interface AWSIoTErrorInfo : AWSModel /**

The error code.

*/ @property (nonatomic, strong) NSString * _Nullable code; /**

The error message.

*/ @property (nonatomic, strong) NSString * _Nullable message; @end /**

Information that explicitly denies authorization.

*/ @interface AWSIoTExplicitDeny : AWSModel /**

The policies that denied the authorization.

*/ @property (nonatomic, strong) NSArray * _Nullable policies; @end /**

Allows you to create an exponential rate of rollout for a job.

Required parameters: [baseRatePerMinute, incrementFactor, rateIncreaseCriteria] */ @interface AWSIoTExponentialRolloutRate : AWSModel /**

The minimum number of things that will be notified of a pending job, per minute at the start of job rollout. This parameter allows you to define the initial rate of rollout.

*/ @property (nonatomic, strong) NSNumber * _Nullable baseRatePerMinute; /**

The exponential factor to increase the rate of rollout for a job.

Amazon Web Services IoT Core supports up to one digit after the decimal (for example, 1.5, but not 1.55).

*/ @property (nonatomic, strong) NSNumber * _Nullable incrementFactor; /**

The criteria to initiate the increase in rate of rollout for a job.

*/ @property (nonatomic, strong) AWSIoTRateIncreaseCriteria * _Nullable rateIncreaseCriteria; @end /**

Describes the name and data type at a field.

*/ @interface AWSIoTField : AWSModel /**

The name of the field.

*/ @property (nonatomic, strong) NSString * _Nullable name; /**

The data type of the field.

*/ @property (nonatomic, assign) AWSIoTFieldType types; @end /**

The location of the OTA update.

*/ @interface AWSIoTFileLocation : AWSModel /**

The location of the updated firmware in S3.

*/ @property (nonatomic, strong) AWSIoTS3Location * _Nullable s3Location; /**

The stream that contains the OTA update.

*/ @property (nonatomic, strong) AWSIoTStream * _Nullable stream; @end /**

Describes an action that writes data to an Amazon Kinesis Firehose stream.

Required parameters: [roleArn, deliveryStreamName] */ @interface AWSIoTFirehoseAction : AWSModel /**

Whether to deliver the Kinesis Data Firehose stream as a batch by using PutRecordBatch. The default value is false.

When batchMode is true and the rule's SQL statement evaluates to an Array, each Array element forms one record in the PutRecordBatch request. The resulting array can't have more than 500 records.

*/ @property (nonatomic, strong) NSNumber * _Nullable batchMode; /**

The delivery stream name.

*/ @property (nonatomic, strong) NSString * _Nullable deliveryStreamName; /**

The IAM role that grants access to the Amazon Kinesis Firehose stream.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

A character separator that will be used to separate records written to the Firehose stream. Valid values are: '\n' (newline), '\t' (tab), '\r\n' (Windows newline), ',' (comma).

*/ @property (nonatomic, strong) NSString * _Nullable separator; @end /**

The name and ARN of a fleet metric.

*/ @interface AWSIoTFleetMetricNameAndArn : AWSModel /**

The fleet metric ARN.

*/ @property (nonatomic, strong) NSString * _Nullable metricArn; /**

The fleet metric name.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; @end /** */ @interface AWSIoTGetBehaviorModelTrainingSummariesRequest : AWSRequest /**

The maximum number of results to return at one time. The default is 10.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The name of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; @end /** */ @interface AWSIoTGetBehaviorModelTrainingSummariesResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A list of all ML Detect behaviors and their model status for a given Security Profile.

*/ @property (nonatomic, strong) NSArray * _Nullable summaries; @end /** */ @interface AWSIoTGetBucketsAggregationRequest : AWSRequest /**

The aggregation field.

*/ @property (nonatomic, strong) NSString * _Nullable aggregationField; /**

The basic control of the response shape and the bucket aggregation type to perform.

*/ @property (nonatomic, strong) AWSIoTBucketsAggregationType * _Nullable bucketsAggregationType; /**

The name of the index to search.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The search query string.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The version of the query.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; @end /** */ @interface AWSIoTGetBucketsAggregationResponse : AWSModel /**

The main part of the response with a list of buckets. Each bucket contains a keyValue and a count.

keyValue: The aggregation field value counted for the particular bucket.

count: The number of documents that have that value.

*/ @property (nonatomic, strong) NSArray * _Nullable buckets; /**

The total number of things that fit the query string criteria.

*/ @property (nonatomic, strong) NSNumber * _Nullable totalCount; @end /** */ @interface AWSIoTGetCardinalityRequest : AWSRequest /**

The field to aggregate.

*/ @property (nonatomic, strong) NSString * _Nullable aggregationField; /**

The name of the index to search.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The search query string.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The query version.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; @end /** */ @interface AWSIoTGetCardinalityResponse : AWSModel /**

The approximate count of unique values that match the query.

*/ @property (nonatomic, strong) NSNumber * _Nullable cardinality; @end /** */ @interface AWSIoTGetEffectivePoliciesRequest : AWSRequest /**

The Cognito identity pool ID.

*/ @property (nonatomic, strong) NSString * _Nullable cognitoIdentityPoolId; /**

The principal. Valid principals are CertificateArn (arn:aws:iot:region:accountId:cert/certificateId), thingGroupArn (arn:aws:iot:region:accountId:thinggroup/groupName) and CognitoId (region:id).

*/ @property (nonatomic, strong) NSString * _Nullable principal; /**

The thing name.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTGetEffectivePoliciesResponse : AWSModel /**

The effective policies.

*/ @property (nonatomic, strong) NSArray * _Nullable effectivePolicies; @end /** */ @interface AWSIoTGetIndexingConfigurationRequest : AWSRequest @end /** */ @interface AWSIoTGetIndexingConfigurationResponse : AWSModel /**

The index configuration.

*/ @property (nonatomic, strong) AWSIoTThingGroupIndexingConfiguration * _Nullable thingGroupIndexingConfiguration; /**

Thing indexing configuration.

*/ @property (nonatomic, strong) AWSIoTThingIndexingConfiguration * _Nullable thingIndexingConfiguration; @end /** */ @interface AWSIoTGetJobDocumentRequest : AWSRequest /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; @end /** */ @interface AWSIoTGetJobDocumentResponse : AWSModel /**

The job document content.

*/ @property (nonatomic, strong) NSString * _Nullable document; @end /**

The input for the GetLoggingOptions operation.

*/ @interface AWSIoTGetLoggingOptionsRequest : AWSRequest @end /**

The output from the GetLoggingOptions operation.

*/ @interface AWSIoTGetLoggingOptionsResponse : AWSModel /**

The logging level.

*/ @property (nonatomic, assign) AWSIoTLogLevel logLevel; /**

The ARN of the IAM role that grants access.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /** */ @interface AWSIoTGetOTAUpdateRequest : AWSRequest /**

The OTA update ID.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateId; @end /** */ @interface AWSIoTGetOTAUpdateResponse : AWSModel /**

The OTA update info.

*/ @property (nonatomic, strong) AWSIoTOTAUpdateInfo * _Nullable otaUpdateInfo; @end /** */ @interface AWSIoTGetPackageConfigurationRequest : AWSRequest @end /** */ @interface AWSIoTGetPackageConfigurationResponse : AWSModel /**

The version that is associated to a specific job.

*/ @property (nonatomic, strong) AWSIoTVersionUpdateByJobsConfig * _Nullable versionUpdateByJobsConfig; @end /** */ @interface AWSIoTGetPackageRequest : AWSRequest /**

The name of the target package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; @end /** */ @interface AWSIoTGetPackageResponse : AWSModel /**

The date the package was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The name of the default package version.

*/ @property (nonatomic, strong) NSString * _Nullable defaultVersionName; /**

The package description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The date when the package was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The ARN for the package.

*/ @property (nonatomic, strong) NSString * _Nullable packageArn; /**

The name of the package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; @end /** */ @interface AWSIoTGetPackageVersionRequest : AWSRequest /**

The name of the associated package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

The name of the target package version.

*/ @property (nonatomic, strong) NSString * _Nullable versionName; @end /** */ @interface AWSIoTGetPackageVersionResponse : AWSModel /**

Metadata that were added to the package version that can be used to define a package version’s configuration.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

The date when the package version was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The package version description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

Error reason for a package version failure during creation or update.

*/ @property (nonatomic, strong) NSString * _Nullable errorReason; /**

The date when the package version was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The name of the package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

The ARN for the package version.

*/ @property (nonatomic, strong) NSString * _Nullable packageVersionArn; /**

The status associated to the package version. For more information, see Package version lifecycle.

*/ @property (nonatomic, assign) AWSIoTPackageVersionStatus status; /**

The name of the package version.

*/ @property (nonatomic, strong) NSString * _Nullable versionName; @end /** */ @interface AWSIoTGetPercentilesRequest : AWSRequest /**

The field to aggregate.

*/ @property (nonatomic, strong) NSString * _Nullable aggregationField; /**

The name of the index to search.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The percentile groups returned.

*/ @property (nonatomic, strong) NSArray * _Nullable percents; /**

The search query string.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The query version.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; @end /** */ @interface AWSIoTGetPercentilesResponse : AWSModel /**

The percentile values of the aggregated fields.

*/ @property (nonatomic, strong) NSArray * _Nullable percentiles; @end /**

The input for the GetPolicy operation.

Required parameters: [policyName] */ @interface AWSIoTGetPolicyRequest : AWSRequest /**

The name of the policy.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; @end /**

The output from the GetPolicy operation.

*/ @interface AWSIoTGetPolicyResponse : AWSModel /**

The date the policy was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The default policy version ID.

*/ @property (nonatomic, strong) NSString * _Nullable defaultVersionId; /**

The generation ID of the policy.

*/ @property (nonatomic, strong) NSString * _Nullable generationId; /**

The date the policy was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The policy ARN.

*/ @property (nonatomic, strong) NSString * _Nullable policyArn; /**

The JSON document that describes the policy.

*/ @property (nonatomic, strong) NSString * _Nullable policyDocument; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; @end /**

The input for the GetPolicyVersion operation.

Required parameters: [policyName, policyVersionId] */ @interface AWSIoTGetPolicyVersionRequest : AWSRequest /**

The name of the policy.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The policy version ID.

*/ @property (nonatomic, strong) NSString * _Nullable policyVersionId; @end /**

The output from the GetPolicyVersion operation.

*/ @interface AWSIoTGetPolicyVersionResponse : AWSModel /**

The date the policy was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The generation ID of the policy version.

*/ @property (nonatomic, strong) NSString * _Nullable generationId; /**

Specifies whether the policy version is the default.

*/ @property (nonatomic, strong) NSNumber * _Nullable isDefaultVersion; /**

The date the policy was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The policy ARN.

*/ @property (nonatomic, strong) NSString * _Nullable policyArn; /**

The JSON document that describes the policy.

*/ @property (nonatomic, strong) NSString * _Nullable policyDocument; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The policy version ID.

*/ @property (nonatomic, strong) NSString * _Nullable policyVersionId; @end /**

The input to the GetRegistrationCode operation.

*/ @interface AWSIoTGetRegistrationCodeRequest : AWSRequest @end /**

The output from the GetRegistrationCode operation.

*/ @interface AWSIoTGetRegistrationCodeResponse : AWSModel /**

The CA certificate registration code.

*/ @property (nonatomic, strong) NSString * _Nullable registrationCode; @end /** */ @interface AWSIoTGetStatisticsRequest : AWSRequest /**

The aggregation field name.

*/ @property (nonatomic, strong) NSString * _Nullable aggregationField; /**

The name of the index to search. The default value is AWS_Things.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The query used to search. You can specify "*" for the query string to get the count of all indexed things in your Amazon Web Services account.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The version of the query used to search.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; @end /** */ @interface AWSIoTGetStatisticsResponse : AWSModel /**

The statistics returned by the Fleet Indexing service based on the query and aggregation field.

*/ @property (nonatomic, strong) AWSIoTStatistics * _Nullable statistics; @end /** */ @interface AWSIoTGetTopicRuleDestinationRequest : AWSRequest /**

The ARN of the topic rule destination.

*/ @property (nonatomic, strong) NSString * _Nullable arn; @end /** */ @interface AWSIoTGetTopicRuleDestinationResponse : AWSModel /**

The topic rule destination.

*/ @property (nonatomic, strong) AWSIoTTopicRuleDestination * _Nullable topicRuleDestination; @end /**

The input for the GetTopicRule operation.

Required parameters: [ruleName] */ @interface AWSIoTGetTopicRuleRequest : AWSRequest /**

The name of the rule.

*/ @property (nonatomic, strong) NSString * _Nullable ruleName; @end /**

The output from the GetTopicRule operation.

*/ @interface AWSIoTGetTopicRuleResponse : AWSModel /**

The rule.

*/ @property (nonatomic, strong) AWSIoTTopicRule * _Nullable rule; /**

The rule ARN.

*/ @property (nonatomic, strong) NSString * _Nullable ruleArn; @end /** */ @interface AWSIoTGetV2LoggingOptionsRequest : AWSRequest @end /** */ @interface AWSIoTGetV2LoggingOptionsResponse : AWSModel /**

The default log level.

*/ @property (nonatomic, assign) AWSIoTLogLevel defaultLogLevel; /**

Disables all logs.

*/ @property (nonatomic, strong) NSNumber * _Nullable disableAllLogs; /**

The IAM role ARN IoT uses to write to your CloudWatch logs.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

The name and ARN of a group.

*/ @interface AWSIoTGroupNameAndArn : AWSModel /**

The group ARN.

*/ @property (nonatomic, strong) NSString * _Nullable groupArn; /**

The group name.

*/ @property (nonatomic, strong) NSString * _Nullable groupName; @end /**

Send data to an HTTPS endpoint.

Required parameters: [url] */ @interface AWSIoTHttpAction : AWSModel /**

The authentication method to use when sending data to an HTTPS endpoint.

*/ @property (nonatomic, strong) AWSIoTHttpAuthorization * _Nullable auth; /**

The URL to which IoT sends a confirmation message. The value of the confirmation URL must be a prefix of the endpoint URL. If you do not specify a confirmation URL IoT uses the endpoint URL as the confirmation URL. If you use substitution templates in the confirmationUrl, you must create and enable topic rule destinations that match each possible value of the substitution template before traffic is allowed to your endpoint URL.

*/ @property (nonatomic, strong) NSString * _Nullable confirmationUrl; /**

The HTTP headers to send with the message data.

*/ @property (nonatomic, strong) NSArray * _Nullable headers; /**

The endpoint URL. If substitution templates are used in the URL, you must also specify a confirmationUrl. If this is a new destination, a new TopicRuleDestination is created if possible.

*/ @property (nonatomic, strong) NSString * _Nullable url; @end /**

The HTTP action header.

Required parameters: [key, value] */ @interface AWSIoTHttpActionHeader : AWSModel /**

The HTTP header key.

*/ @property (nonatomic, strong) NSString * _Nullable key; /**

The HTTP header value. Substitution templates are supported.

*/ @property (nonatomic, strong) NSString * _Nullable value; @end /**

The authorization method used to send messages.

*/ @interface AWSIoTHttpAuthorization : AWSModel /**

Use Sig V4 authorization. For more information, see Signature Version 4 Signing Process.

*/ @property (nonatomic, strong) AWSIoTSigV4Authorization * _Nullable sigv4; @end /**

Specifies the HTTP context to use for the test authorizer request.

*/ @interface AWSIoTHttpContext : AWSModel /**

The header keys and values in an HTTP authorization request.

*/ @property (nonatomic, strong) NSDictionary * _Nullable headers; /**

The query string keys and values in an HTTP authorization request.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; @end /**

HTTP URL destination configuration used by the topic rule's HTTP action.

Required parameters: [confirmationUrl] */ @interface AWSIoTHttpUrlDestinationConfiguration : AWSModel /**

The URL IoT uses to confirm ownership of or access to the topic rule destination URL.

*/ @property (nonatomic, strong) NSString * _Nullable confirmationUrl; @end /**

HTTP URL destination properties.

*/ @interface AWSIoTHttpUrlDestinationProperties : AWSModel /**

The URL used to confirm the HTTP topic rule destination URL.

*/ @property (nonatomic, strong) NSString * _Nullable confirmationUrl; @end /**

Information about an HTTP URL destination.

*/ @interface AWSIoTHttpUrlDestinationSummary : AWSModel /**

The URL used to confirm ownership of or access to the HTTP topic rule destination URL.

*/ @property (nonatomic, strong) NSString * _Nullable confirmationUrl; @end /**

Information that implicitly denies authorization. When policy doesn't explicitly deny or allow an action on a resource it is considered an implicit deny.

*/ @interface AWSIoTImplicitDeny : AWSModel /**

Policies that don't contain a matching allow or deny statement for the specified action on the specified resource.

*/ @property (nonatomic, strong) NSArray * _Nullable policies; @end /**

Provides additional filters for specific data sources. Named shadow is the only data source that currently supports and requires a filter. To add named shadows to your fleet indexing configuration, set namedShadowIndexingMode to be ON and specify your shadow names in filter.

*/ @interface AWSIoTIndexingFilter : AWSModel /**

The shadow names that you select to index. The default maximum number of shadow names for indexing is 10. To increase the limit, see Amazon Web Services IoT Device Management Quotas in the Amazon Web Services General Reference.

*/ @property (nonatomic, strong) NSArray * _Nullable namedShadowNames; @end /**

Sends message data to an IoT Analytics channel.

*/ @interface AWSIoTIotAnalyticsAction : AWSModel /**

Whether to process the action as a batch. The default value is false.

When batchMode is true and the rule SQL statement evaluates to an Array, each Array element is delivered as a separate message when passed by BatchPutMessage to the IoT Analytics channel. The resulting array can't have more than 100 messages.

*/ @property (nonatomic, strong) NSNumber * _Nullable batchMode; /**

(deprecated) The ARN of the IoT Analytics channel to which message data will be sent.

*/ @property (nonatomic, strong) NSString * _Nullable channelArn; /**

The name of the IoT Analytics channel to which message data will be sent.

*/ @property (nonatomic, strong) NSString * _Nullable channelName; /**

The ARN of the role which has a policy that grants IoT Analytics permission to send message data via IoT Analytics (iotanalytics:BatchPutMessage).

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Sends an input to an IoT Events detector.

Required parameters: [inputName, roleArn] */ @interface AWSIoTIotEventsAction : AWSModel /**

Whether to process the event actions as a batch. The default value is false.

When batchMode is true, you can't specify a messageId.

When batchMode is true and the rule SQL statement evaluates to an Array, each Array element is treated as a separate message when it's sent to IoT Events by calling BatchPutMessage. The resulting array can't have more than 10 messages.

*/ @property (nonatomic, strong) NSNumber * _Nullable batchMode; /**

The name of the IoT Events input.

*/ @property (nonatomic, strong) NSString * _Nullable inputName; /**

The ID of the message. The default messageId is a new UUID value.

When batchMode is true, you can't specify a messageId--a new UUID value will be assigned.

Assign a value to this property to ensure that only one input (message) with a given messageId will be processed by an IoT Events detector.

*/ @property (nonatomic, strong) NSString * _Nullable messageId; /**

The ARN of the role that grants IoT permission to send an input to an IoT Events detector. ("Action":"iotevents:BatchPutMessage").

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Describes an action to send data from an MQTT message that triggered the rule to IoT SiteWise asset properties.

Required parameters: [putAssetPropertyValueEntries, roleArn] */ @interface AWSIoTIotSiteWiseAction : AWSModel /**

A list of asset property value entries.

*/ @property (nonatomic, strong) NSArray * _Nullable putAssetPropertyValueEntries; /**

The ARN of the role that grants IoT permission to send an asset property value to IoT SiteWise. ("Action": "iotsitewise:BatchPutAssetPropertyValue"). The trust policy can restrict access to specific asset hierarchy paths.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

The certificate issuer indentifier.

*/ @interface AWSIoTIssuerCertificateIdentifier : AWSModel /**

The issuer certificate serial number.

*/ @property (nonatomic, strong) NSString * _Nullable issuerCertificateSerialNumber; /**

The subject of the issuer certificate.

*/ @property (nonatomic, strong) NSString * _Nullable issuerCertificateSubject; /**

The issuer ID.

*/ @property (nonatomic, strong) NSString * _Nullable issuerId; @end /**

The Job object contains details about a job.

*/ @interface AWSIoTJob : AWSModel /**

Configuration for criteria to abort the job.

*/ @property (nonatomic, strong) AWSIoTAbortConfig * _Nullable abortConfig; /**

If the job was updated, describes the reason for the update.

*/ @property (nonatomic, strong) NSString * _Nullable comment; /**

The time, in seconds since the epoch, when the job was completed.

*/ @property (nonatomic, strong) NSDate * _Nullable completedAt; /**

The time, in seconds since the epoch, when the job was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

A short text description of the job.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The package version Amazon Resource Names (ARNs) that are installed on the device when the job successfully completes.

Note:The following Length Constraints relates to a single string. Up to five strings are allowed.

*/ @property (nonatomic, strong) NSArray * _Nullable destinationPackageVersions; /**

A key-value map that pairs the patterns that need to be replaced in a managed template job document schema. You can use the description of each key as a guidance to specify the inputs during runtime when creating a job.

documentParameters can only be used when creating jobs from Amazon Web Services managed templates. This parameter can't be used with custom job templates or to create jobs from them.

*/ @property (nonatomic, strong) NSDictionary * _Nullable documentParameters; /**

Will be true if the job was canceled with the optional force parameter set to true.

*/ @property (nonatomic, strong) NSNumber * _Nullable forceCanceled; /**

Indicates whether a job is concurrent. Will be true when a job is rolling out new job executions or canceling previously created executions, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable isConcurrent; /**

An ARN identifying the job with format "arn:aws:iot:region:account:job/jobId".

*/ @property (nonatomic, strong) NSString * _Nullable jobArn; /**

The configuration for the criteria to retry the job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRetryConfig * _Nullable jobExecutionsRetryConfig; /**

Allows you to create a staged rollout of a job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRolloutConfig * _Nullable jobExecutionsRolloutConfig; /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

Details about the job process.

*/ @property (nonatomic, strong) AWSIoTJobProcessDetails * _Nullable jobProcessDetails; /**

The ARN of the job template used to create the job.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateArn; /**

The time, in seconds since the epoch, when the job was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastUpdatedAt; /**

The namespace used to indicate that a job is a customer-managed job.

When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.

$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/

The namespaceId feature is in public preview.

*/ @property (nonatomic, strong) NSString * _Nullable namespaceId; /**

Configuration for pre-signed S3 URLs.

*/ @property (nonatomic, strong) AWSIoTPresignedUrlConfig * _Nullable presignedUrlConfig; /**

If the job was updated, provides the reason code for the update.

*/ @property (nonatomic, strong) NSString * _Nullable reasonCode; /**

Displays the next seven maintenance window occurrences and their start times.

*/ @property (nonatomic, strong) NSArray * _Nullable scheduledJobRollouts; /**

The configuration that allows you to schedule a job for a future date and time in addition to specifying the end behavior for each job execution.

*/ @property (nonatomic, strong) AWSIoTSchedulingConfig * _Nullable schedulingConfig; /**

The status of the job, one of IN_PROGRESS, CANCELED, DELETION_IN_PROGRESS or COMPLETED.

*/ @property (nonatomic, assign) AWSIoTJobStatus status; /**

Specifies whether the job will continue to run (CONTINUOUS), or will be complete after all those things specified as targets have completed the job (SNAPSHOT). If continuous, the job may also be run on a thing when a change is detected in a target. For example, a job will run on a device when the thing representing the device is added to a target group, even after the job was completed by all things originally in the group.

We recommend that you use continuous jobs instead of snapshot jobs for dynamic thing group targets. By using continuous jobs, devices that join the group receive the job execution even after the job has been created.

*/ @property (nonatomic, assign) AWSIoTTargetSelection targetSelection; /**

A list of IoT things and thing groups to which the job should be sent.

*/ @property (nonatomic, strong) NSArray * _Nullable targets; /**

Specifies the amount of time each device has to finish its execution of the job. A timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the timer expires, it will be automatically set to TIMED_OUT.

*/ @property (nonatomic, strong) AWSIoTTimeoutConfig * _Nullable timeoutConfig; @end /**

The job execution object represents the execution of a job on a particular device.

*/ @interface AWSIoTJobExecution : AWSModel /**

The estimated number of seconds that remain before the job execution status will be changed to TIMED_OUT. The timeout interval can be anywhere between 1 minute and 7 days (1 to 10080 minutes). The actual job execution timeout can occur up to 60 seconds later than the estimated duration. This value will not be included if the job execution has reached a terminal status.

*/ @property (nonatomic, strong) NSNumber * _Nullable approximateSecondsBeforeTimedOut; /**

A string (consisting of the digits "0" through "9") which identifies this particular job execution on this particular device. It can be used in commands which return or update job execution information.

*/ @property (nonatomic, strong) NSNumber * _Nullable executionNumber; /**

Will be true if the job execution was canceled with the optional force parameter set to true.

*/ @property (nonatomic, strong) NSNumber * _Nullable forceCanceled; /**

The unique identifier you assigned to the job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The time, in seconds since the epoch, when the job execution was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastUpdatedAt; /**

The time, in seconds since the epoch, when the job execution was queued.

*/ @property (nonatomic, strong) NSDate * _Nullable queuedAt; /**

The time, in seconds since the epoch, when the job execution started.

*/ @property (nonatomic, strong) NSDate * _Nullable startedAt; /**

The status of the job execution (IN_PROGRESS, QUEUED, FAILED, SUCCEEDED, TIMED_OUT, CANCELED, or REJECTED).

*/ @property (nonatomic, assign) AWSIoTJobExecutionStatus status; /**

A collection of name/value pairs that describe the status of the job execution.

*/ @property (nonatomic, strong) AWSIoTJobExecutionStatusDetails * _Nullable statusDetails; /**

The ARN of the thing on which the job execution is running.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; /**

The version of the job execution. Job execution versions are incremented each time they are updated by a device.

*/ @property (nonatomic, strong) NSNumber * _Nullable versionNumber; @end /**

Details of the job execution status.

*/ @interface AWSIoTJobExecutionStatusDetails : AWSModel /**

The job execution status.

*/ @property (nonatomic, strong) NSDictionary * _Nullable detailsMap; @end /**

The job execution summary.

*/ @interface AWSIoTJobExecutionSummary : AWSModel /**

A string (consisting of the digits "0" through "9") which identifies this particular job execution on this particular device. It can be used later in commands which return or update job execution information.

*/ @property (nonatomic, strong) NSNumber * _Nullable executionNumber; /**

The time, in seconds since the epoch, when the job execution was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastUpdatedAt; /**

The time, in seconds since the epoch, when the job execution was queued.

*/ @property (nonatomic, strong) NSDate * _Nullable queuedAt; /**

The number that indicates how many retry attempts have been completed for this job on this device.

*/ @property (nonatomic, strong) NSNumber * _Nullable retryAttempt; /**

The time, in seconds since the epoch, when the job execution started.

*/ @property (nonatomic, strong) NSDate * _Nullable startedAt; /**

The status of the job execution.

*/ @property (nonatomic, assign) AWSIoTJobExecutionStatus status; @end /**

Contains a summary of information about job executions for a specific job.

*/ @interface AWSIoTJobExecutionSummaryForJob : AWSModel /**

Contains a subset of information about a job execution.

*/ @property (nonatomic, strong) AWSIoTJobExecutionSummary * _Nullable jobExecutionSummary; /**

The ARN of the thing on which the job execution is running.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; @end /**

The job execution summary for a thing.

*/ @interface AWSIoTJobExecutionSummaryForThing : AWSModel /**

Contains a subset of information about a job execution.

*/ @property (nonatomic, strong) AWSIoTJobExecutionSummary * _Nullable jobExecutionSummary; /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; @end /**

The configuration that determines how many retries are allowed for each failure type for a job.

Required parameters: [criteriaList] */ @interface AWSIoTJobExecutionsRetryConfig : AWSModel /**

The list of criteria that determines how many retries are allowed for each failure type for a job.

*/ @property (nonatomic, strong) NSArray * _Nullable criteriaList; @end /**

Allows you to create a staged rollout of a job.

*/ @interface AWSIoTJobExecutionsRolloutConfig : AWSModel /**

The rate of increase for a job rollout. This parameter allows you to define an exponential rate for a job rollout.

*/ @property (nonatomic, strong) AWSIoTExponentialRolloutRate * _Nullable exponentialRate; /**

The maximum number of things that will be notified of a pending job, per minute. This parameter allows you to create a staged rollout.

*/ @property (nonatomic, strong) NSNumber * _Nullable maximumPerMinute; @end /**

The job process details.

*/ @interface AWSIoTJobProcessDetails : AWSModel /**

The number of things that cancelled the job.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfCanceledThings; /**

The number of things that failed executing the job.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfFailedThings; /**

The number of things currently executing the job.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfInProgressThings; /**

The number of things that are awaiting execution of the job.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfQueuedThings; /**

The number of things that rejected the job.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfRejectedThings; /**

The number of things that are no longer scheduled to execute the job because they have been deleted or have been removed from the group that was a target of the job.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfRemovedThings; /**

The number of things which successfully completed the job.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfSucceededThings; /**

The number of things whose job execution status is TIMED_OUT.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfTimedOutThings; /**

The target devices to which the job execution is being rolled out. This value will be null after the job execution has finished rolling out to all the target devices.

*/ @property (nonatomic, strong) NSArray * _Nullable processingTargets; @end /**

The job summary.

*/ @interface AWSIoTJobSummary : AWSModel /**

The time, in seconds since the epoch, when the job completed.

*/ @property (nonatomic, strong) NSDate * _Nullable completedAt; /**

The time, in seconds since the epoch, when the job was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

Indicates whether a job is concurrent. Will be true when a job is rolling out new job executions or canceling previously created executions, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable isConcurrent; /**

The job ARN.

*/ @property (nonatomic, strong) NSString * _Nullable jobArn; /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The time, in seconds since the epoch, when the job was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastUpdatedAt; /**

The job summary status.

*/ @property (nonatomic, assign) AWSIoTJobStatus status; /**

Specifies whether the job will continue to run (CONTINUOUS), or will be complete after all those things specified as targets have completed the job (SNAPSHOT). If continuous, the job may also be run on a thing when a change is detected in a target. For example, a job will run on a thing when the thing is added to a target group, even after the job was completed by all things originally in the group.

We recommend that you use continuous jobs instead of snapshot jobs for dynamic thing group targets. By using continuous jobs, devices that join the group receive the job execution even after the job has been created.

*/ @property (nonatomic, assign) AWSIoTTargetSelection targetSelection; /**

The ID of the thing group.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupId; @end /**

An object that contains information about the job template.

*/ @interface AWSIoTJobTemplateSummary : AWSModel /**

The time, in seconds since the epoch, when the job template was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

A description of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The ARN of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateArn; /**

The unique identifier of the job template.

*/ @property (nonatomic, strong) NSString * _Nullable jobTemplateId; @end /**

Send messages to an Amazon Managed Streaming for Apache Kafka (Amazon MSK) or self-managed Apache Kafka cluster.

Required parameters: [destinationArn, topic, clientProperties] */ @interface AWSIoTKafkaAction : AWSModel /**

Properties of the Apache Kafka producer client.

*/ @property (nonatomic, strong) NSDictionary * _Nullable clientProperties; /**

The ARN of Kafka action's VPC TopicRuleDestination.

*/ @property (nonatomic, strong) NSString * _Nullable destinationArn; /**

The Kafka message key.

*/ @property (nonatomic, strong) NSString * _Nullable key; /**

The Kafka message partition.

*/ @property (nonatomic, strong) NSString * _Nullable partition; /**

The Kafka topic for messages to be sent to the Kafka broker.

*/ @property (nonatomic, strong) NSString * _Nullable topic; @end /**

Describes a key pair.

*/ @interface AWSIoTKeyPair : AWSModel /**

The private key.

*/ @property (nonatomic, strong) NSString * _Nullable privateKey; /**

The public key.

*/ @property (nonatomic, strong) NSString * _Nullable publicKey; @end /**

Describes an action to write data to an Amazon Kinesis stream.

Required parameters: [roleArn, streamName] */ @interface AWSIoTKinesisAction : AWSModel /**

The partition key.

*/ @property (nonatomic, strong) NSString * _Nullable partitionKey; /**

The ARN of the IAM role that grants access to the Amazon Kinesis stream.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The name of the Amazon Kinesis stream.

*/ @property (nonatomic, strong) NSString * _Nullable streamName; @end /**

Describes an action to invoke a Lambda function.

Required parameters: [functionArn] */ @interface AWSIoTLambdaAction : AWSModel /**

The ARN of the Lambda function.

*/ @property (nonatomic, strong) NSString * _Nullable functionArn; @end /** */ @interface AWSIoTListActiveViolationsRequest : AWSRequest /**

The criteria for a behavior.

*/ @property (nonatomic, assign) AWSIoTBehaviorCriteriaType behaviorCriteriaType; /**

A list of all suppressed alerts.

*/ @property (nonatomic, strong) NSNumber * _Nullable listSuppressedAlerts; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The name of the Device Defender security profile for which violations are listed.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The name of the thing whose active violations are listed.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The verification state of the violation (detect alarm).

*/ @property (nonatomic, assign) AWSIoTVerificationState verificationState; @end /** */ @interface AWSIoTListActiveViolationsResponse : AWSModel /**

The list of active violations.

*/ @property (nonatomic, strong) NSArray * _Nullable activeViolations; /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListAttachedPoliciesRequest : AWSRequest /**

The token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The maximum number of results to be returned per request.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; /**

When true, recursively list attached policies.

*/ @property (nonatomic, strong) NSNumber * _Nullable recursive; /**

The group or principal for which the policies will be listed. Valid principals are CertificateArn (arn:aws:iot:region:accountId:cert/certificateId), thingGroupArn (arn:aws:iot:region:accountId:thinggroup/groupName) and CognitoId (region:id).

*/ @property (nonatomic, strong) NSString * _Nullable target; @end /** */ @interface AWSIoTListAttachedPoliciesResponse : AWSModel /**

The token to retrieve the next set of results, or ``null`` if there are no more results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; /**

The policies.

*/ @property (nonatomic, strong) NSArray * _Nullable policies; @end /** */ @interface AWSIoTListAuditFindingsRequest : AWSRequest /**

A filter to limit results to the findings for the specified audit check.

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

A filter to limit results to those found before the specified time. You must specify either the startTime and endTime or the taskId, but not both.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

Boolean flag indicating whether only the suppressed findings or the unsuppressed findings should be listed. If this parameter isn't provided, the response will list both suppressed and unsuppressed findings.

*/ @property (nonatomic, strong) NSNumber * _Nullable listSuppressedFindings; /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

Information identifying the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; /**

A filter to limit results to those found after the specified time. You must specify either the startTime and endTime or the taskId, but not both.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

A filter to limit results to the audit with the specified ID. You must specify either the taskId or the startTime and endTime, but not both.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTListAuditFindingsResponse : AWSModel /**

The findings (results) of the audit.

*/ @property (nonatomic, strong) NSArray * _Nullable findings; /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListAuditMitigationActionsExecutionsRequest : AWSRequest /**

Specify this filter to limit results to those with a specific status.

*/ @property (nonatomic, assign) AWSIoTAuditMitigationActionsExecutionStatus actionStatus; /**

Specify this filter to limit results to those that were applied to a specific audit finding.

*/ @property (nonatomic, strong) NSString * _Nullable findingId; /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

Specify this filter to limit results to actions for a specific audit mitigation actions task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTListAuditMitigationActionsExecutionsResponse : AWSModel /**

A set of task execution results based on the input parameters. Details include the mitigation action applied, start time, and task status.

*/ @property (nonatomic, strong) NSArray * _Nullable actionsExecutions; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListAuditMitigationActionsTasksRequest : AWSRequest /**

Specify this filter to limit results to tasks that were applied to results for a specific audit.

*/ @property (nonatomic, strong) NSString * _Nullable auditTaskId; /**

Specify this filter to limit results to tasks that were completed or canceled on or before a specific date and time.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

Specify this filter to limit results to tasks that were applied to a specific audit finding.

*/ @property (nonatomic, strong) NSString * _Nullable findingId; /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

Specify this filter to limit results to tasks that began on or after a specific date and time.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

Specify this filter to limit results to tasks that are in a specific state.

*/ @property (nonatomic, assign) AWSIoTAuditMitigationActionsTaskStatus taskStatus; @end /** */ @interface AWSIoTListAuditMitigationActionsTasksResponse : AWSModel /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The collection of audit mitigation tasks that matched the filter criteria.

*/ @property (nonatomic, strong) NSArray * _Nullable tasks; @end /** */ @interface AWSIoTListAuditSuppressionsRequest : AWSRequest /**

Determines whether suppressions are listed in ascending order by expiration date or not. If parameter isn't provided, ascendingOrder=true.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

An audit check name. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

Information that identifies the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; @end /** */ @interface AWSIoTListAuditSuppressionsResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

List of audit suppressions.

*/ @property (nonatomic, strong) NSArray * _Nullable suppressions; @end /** */ @interface AWSIoTListAuditTasksRequest : AWSRequest /**

The end of the time period.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The beginning of the time period. Audit information is retained for a limited time (90 days). Requesting a start time prior to what is retained results in an "InvalidRequestException".

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

A filter to limit the output to audits with the specified completion status: can be one of "IN_PROGRESS", "COMPLETED", "FAILED", or "CANCELED".

*/ @property (nonatomic, assign) AWSIoTAuditTaskStatus taskStatus; /**

A filter to limit the output to the specified type of audit: can be one of "ON_DEMAND_AUDIT_TASK" or "SCHEDULED__AUDIT_TASK".

*/ @property (nonatomic, assign) AWSIoTAuditTaskType taskType; @end /** */ @interface AWSIoTListAuditTasksResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The audits that were performed during the specified time period.

*/ @property (nonatomic, strong) NSArray * _Nullable tasks; @end /** */ @interface AWSIoTListAuthorizersRequest : AWSRequest /**

Return the list of authorizers in ascending alphabetical order.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

A marker used to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; /**

The status of the list authorizers request.

*/ @property (nonatomic, assign) AWSIoTAuthorizerStatus status; @end /** */ @interface AWSIoTListAuthorizersResponse : AWSModel /**

The authorizers.

*/ @property (nonatomic, strong) NSArray * _Nullable authorizers; /**

A marker used to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; @end /** */ @interface AWSIoTListBillingGroupsRequest : AWSRequest /**

The maximum number of results to return per request.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

Limit the results to billing groups whose names have the given prefix.

*/ @property (nonatomic, strong) NSString * _Nullable namePrefixFilter; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListBillingGroupsResponse : AWSModel /**

The list of billing groups.

*/ @property (nonatomic, strong) NSArray * _Nullable billingGroups; /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /**

Input for the ListCACertificates operation.

*/ @interface AWSIoTListCACertificatesRequest : AWSRequest /**

Determines the order of the results.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The result page size.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /**

The output from the ListCACertificates operation.

*/ @interface AWSIoTListCACertificatesResponse : AWSModel /**

The CA certificates registered in your Amazon Web Services account.

*/ @property (nonatomic, strong) NSArray * _Nullable certificates; /**

The current position within the list of CA certificates.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; @end /**

The input to the ListCertificatesByCA operation.

Required parameters: [caCertificateId] */ @interface AWSIoTListCertificatesByCARequest : AWSRequest /**

Specifies the order for results. If True, the results are returned in ascending order, based on the creation date.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

The ID of the CA certificate. This operation will list all registered device certificate that were signed by this CA certificate.

*/ @property (nonatomic, strong) NSString * _Nullable caCertificateId; /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The result page size.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; @end /**

The output of the ListCertificatesByCA operation.

*/ @interface AWSIoTListCertificatesByCAResponse : AWSModel /**

The device certificates signed by the specified CA certificate.

*/ @property (nonatomic, strong) NSArray * _Nullable certificates; /**

The marker for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; @end /**

The input for the ListCertificates operation.

*/ @interface AWSIoTListCertificatesRequest : AWSRequest /**

Specifies the order for results. If True, the results are returned in ascending order, based on the creation date.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The result page size.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; @end /**

The output of the ListCertificates operation.

*/ @interface AWSIoTListCertificatesResponse : AWSModel /**

The descriptions of the certificates.

*/ @property (nonatomic, strong) NSArray * _Nullable certificates; /**

The marker for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; @end /** */ @interface AWSIoTListCustomMetricsRequest : AWSRequest /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListCustomMetricsResponse : AWSModel /**

The name of the custom metric.

*/ @property (nonatomic, strong) NSArray * _Nullable metricNames; /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListDetectMitigationActionsExecutionsRequest : AWSRequest /**

The end of the time period for which ML Detect mitigation actions executions are returned.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A filter to limit results to those found after the specified time. You must specify either the startTime and endTime or the taskId, but not both.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

The unique identifier of the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; /**

The name of the thing whose mitigation actions are listed.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The unique identifier of the violation.

*/ @property (nonatomic, strong) NSString * _Nullable violationId; @end /** */ @interface AWSIoTListDetectMitigationActionsExecutionsResponse : AWSModel /**

List of actions executions.

*/ @property (nonatomic, strong) NSArray * _Nullable actionsExecutions; /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListDetectMitigationActionsTasksRequest : AWSRequest /**

The end of the time period for which ML Detect mitigation actions tasks are returned.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A filter to limit results to those found after the specified time. You must specify either the startTime and endTime or the taskId, but not both.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; @end /** */ @interface AWSIoTListDetectMitigationActionsTasksResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The collection of ML Detect mitigation tasks that matched the filter criteria.

*/ @property (nonatomic, strong) NSArray * _Nullable tasks; @end /** */ @interface AWSIoTListDimensionsRequest : AWSRequest /**

The maximum number of results to retrieve at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListDimensionsResponse : AWSModel /**

A list of the names of the defined dimensions. Use DescribeDimension to get details for a dimension.

*/ @property (nonatomic, strong) NSArray * _Nullable dimensionNames; /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListDomainConfigurationsRequest : AWSRequest /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The result page size.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; /**

The type of service delivered by the endpoint.

*/ @property (nonatomic, assign) AWSIoTServiceType serviceType; @end /** */ @interface AWSIoTListDomainConfigurationsResponse : AWSModel /**

A list of objects that contain summary information about the user's domain configurations.

*/ @property (nonatomic, strong) NSArray * _Nullable domainConfigurations; /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; @end /** */ @interface AWSIoTListFleetMetricsRequest : AWSRequest /**

The maximum number of results to return in this operation.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListFleetMetricsResponse : AWSModel /**

The list of fleet metrics objects.

*/ @property (nonatomic, strong) NSArray * _Nullable fleetMetrics; /**

The token for the next set of results. Will not be returned if the operation has returned all results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListIndicesRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token used to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListIndicesResponse : AWSModel /**

The index names.

*/ @property (nonatomic, strong) NSArray * _Nullable indexNames; /**

The token used to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListJobExecutionsForJobRequest : AWSRequest /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The maximum number of results to be returned per request.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The status of the job.

*/ @property (nonatomic, assign) AWSIoTJobExecutionStatus status; @end /** */ @interface AWSIoTListJobExecutionsForJobResponse : AWSModel /**

A list of job execution summaries.

*/ @property (nonatomic, strong) NSArray * _Nullable executionSummaries; /**

The token for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListJobExecutionsForThingRequest : AWSRequest /**

The unique identifier you assigned to this job when it was created.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The maximum number of results to be returned per request.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The namespace used to indicate that a job is a customer-managed job.

When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.

$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/

The namespaceId feature is in public preview.

*/ @property (nonatomic, strong) NSString * _Nullable namespaceId; /**

The token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

An optional filter that lets you search for jobs that have the specified status.

*/ @property (nonatomic, assign) AWSIoTJobExecutionStatus status; /**

The thing name.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTListJobExecutionsForThingResponse : AWSModel /**

A list of job execution summaries.

*/ @property (nonatomic, strong) NSArray * _Nullable executionSummaries; /**

The token for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListJobTemplatesRequest : AWSRequest /**

The maximum number of results to return in the list.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token to use to return the next set of results in the list.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListJobTemplatesResponse : AWSModel /**

A list of objects that contain information about the job templates.

*/ @property (nonatomic, strong) NSArray * _Nullable jobTemplates; /**

The token for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListJobsRequest : AWSRequest /**

The maximum number of results to return per request.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The namespace used to indicate that a job is a customer-managed job.

When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.

$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/

The namespaceId feature is in public preview.

*/ @property (nonatomic, strong) NSString * _Nullable namespaceId; /**

The token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

An optional filter that lets you search for jobs that have the specified status.

*/ @property (nonatomic, assign) AWSIoTJobStatus status; /**

Specifies whether the job will continue to run (CONTINUOUS), or will be complete after all those things specified as targets have completed the job (SNAPSHOT). If continuous, the job may also be run on a thing when a change is detected in a target. For example, a job will run on a thing when the thing is added to a target group, even after the job was completed by all things originally in the group.

We recommend that you use continuous jobs instead of snapshot jobs for dynamic thing group targets. By using continuous jobs, devices that join the group receive the job execution even after the job has been created.

*/ @property (nonatomic, assign) AWSIoTTargetSelection targetSelection; /**

A filter that limits the returned jobs to those for the specified group.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupId; /**

A filter that limits the returned jobs to those for the specified group.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; @end /** */ @interface AWSIoTListJobsResponse : AWSModel /**

A list of jobs.

*/ @property (nonatomic, strong) NSArray * _Nullable jobs; /**

The token for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListManagedJobTemplatesRequest : AWSRequest /**

Maximum number of entries that can be returned.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

An optional parameter for template name. If specified, only the versions of the managed job templates that have the specified template name will be returned.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /** */ @interface AWSIoTListManagedJobTemplatesResponse : AWSModel /**

A list of managed job templates that are returned.

*/ @property (nonatomic, strong) NSArray * _Nullable managedJobTemplates; /**

The token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListMetricValuesRequest : AWSRequest /**

The dimension name.

*/ @property (nonatomic, strong) NSString * _Nullable dimensionName; /**

The dimension value operator.

*/ @property (nonatomic, assign) AWSIoTDimensionValueOperator dimensionValueOperator; /**

The end of the time period for which metric values are returned.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The name of the security profile metric for which values are returned.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The start of the time period for which metric values are returned.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

The name of the thing for which security profile metric values are returned.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTListMetricValuesResponse : AWSModel /**

The data the thing reports for the metric during the specified time period.

*/ @property (nonatomic, strong) NSArray * _Nullable metricDatumList; /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListMitigationActionsRequest : AWSRequest /**

Specify a value to limit the result to mitigation actions with a specific action type.

*/ @property (nonatomic, assign) AWSIoTMitigationActionType actionType; /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListMitigationActionsResponse : AWSModel /**

A set of actions that matched the specified filter criteria.

*/ @property (nonatomic, strong) NSArray * _Nullable actionIdentifiers; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListOTAUpdatesRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

A token used to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The OTA update job status.

*/ @property (nonatomic, assign) AWSIoTOTAUpdateStatus otaUpdateStatus; @end /** */ @interface AWSIoTListOTAUpdatesResponse : AWSModel /**

A token to use to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A list of OTA update jobs.

*/ @property (nonatomic, strong) NSArray * _Nullable otaUpdates; @end /**

The input to the ListOutgoingCertificates operation.

*/ @interface AWSIoTListOutgoingCertificatesRequest : AWSRequest /**

Specifies the order for results. If True, the results are returned in ascending order, based on the creation date.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The result page size.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; @end /**

The output from the ListOutgoingCertificates operation.

*/ @interface AWSIoTListOutgoingCertificatesResponse : AWSModel /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; /**

The certificates that are being transferred but not yet accepted.

*/ @property (nonatomic, strong) NSArray * _Nullable outgoingCertificates; @end /** */ @interface AWSIoTListPackageVersionsRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The name of the target package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

The status of the package version. For more information, see Package version lifecycle.

*/ @property (nonatomic, assign) AWSIoTPackageVersionStatus status; @end /** */ @interface AWSIoTListPackageVersionsResponse : AWSModel /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

Lists the package versions associated to the package.

*/ @property (nonatomic, strong) NSArray * _Nullable packageVersionSummaries; @end /** */ @interface AWSIoTListPackagesRequest : AWSRequest /**

The maximum number of results returned at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListPackagesResponse : AWSModel /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The software package summary.

*/ @property (nonatomic, strong) NSArray * _Nullable packageSummaries; @end /**

The input for the ListPolicies operation.

*/ @interface AWSIoTListPoliciesRequest : AWSRequest /**

Specifies the order for results. If true, the results are returned in ascending creation order.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The result page size.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; @end /**

The output from the ListPolicies operation.

*/ @interface AWSIoTListPoliciesResponse : AWSModel /**

The marker for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; /**

The descriptions of the policies.

*/ @property (nonatomic, strong) NSArray * _Nullable policies; @end /**

The input for the ListPolicyPrincipals operation.

Required parameters: [policyName] */ @interface AWSIoTListPolicyPrincipalsRequest : AWSRequest /**

Specifies the order for results. If true, the results are returned in ascending creation order.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The result page size.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; @end /**

The output from the ListPolicyPrincipals operation.

*/ @interface AWSIoTListPolicyPrincipalsResponse : AWSModel /**

The marker for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; /**

The descriptions of the principals.

*/ @property (nonatomic, strong) NSArray * _Nullable principals; @end /**

The input for the ListPolicyVersions operation.

Required parameters: [policyName] */ @interface AWSIoTListPolicyVersionsRequest : AWSRequest /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; @end /**

The output from the ListPolicyVersions operation.

*/ @interface AWSIoTListPolicyVersionsResponse : AWSModel /**

The policy versions.

*/ @property (nonatomic, strong) NSArray * _Nullable policyVersions; @end /**

The input for the ListPrincipalPolicies operation.

Required parameters: [principal] */ @interface AWSIoTListPrincipalPoliciesRequest : AWSRequest /**

Specifies the order for results. If true, results are returned in ascending creation order.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

The marker for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The result page size.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; /**

The principal. Valid principals are CertificateArn (arn:aws:iot:region:accountId:cert/certificateId), thingGroupArn (arn:aws:iot:region:accountId:thinggroup/groupName) and CognitoId (region:id).

*/ @property (nonatomic, strong) NSString * _Nullable principal; @end /**

The output from the ListPrincipalPolicies operation.

*/ @interface AWSIoTListPrincipalPoliciesResponse : AWSModel /**

The marker for the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; /**

The policies.

*/ @property (nonatomic, strong) NSArray * _Nullable policies; @end /**

The input for the ListPrincipalThings operation.

Required parameters: [principal] */ @interface AWSIoTListPrincipalThingsRequest : AWSRequest /**

The maximum number of results to return in this operation.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The principal.

*/ @property (nonatomic, strong) NSString * _Nullable principal; @end /**

The output from the ListPrincipalThings operation.

*/ @interface AWSIoTListPrincipalThingsResponse : AWSModel /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The things.

*/ @property (nonatomic, strong) NSArray * _Nullable things; @end /** */ @interface AWSIoTListProvisioningTemplateVersionsRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

A token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /** */ @interface AWSIoTListProvisioningTemplateVersionsResponse : AWSModel /**

A token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The list of provisioning template versions.

*/ @property (nonatomic, strong) NSArray * _Nullable versions; @end /** */ @interface AWSIoTListProvisioningTemplatesRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

A token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListProvisioningTemplatesResponse : AWSModel /**

A token to retrieve the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A list of provisioning templates

*/ @property (nonatomic, strong) NSArray * _Nullable templates; @end /** */ @interface AWSIoTListRelatedResourcesForAuditFindingRequest : AWSRequest /**

The finding Id.

*/ @property (nonatomic, strong) NSString * _Nullable findingId; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListRelatedResourcesForAuditFindingResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null for the first API call.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The related resources.

*/ @property (nonatomic, strong) NSArray * _Nullable relatedResources; @end /** */ @interface AWSIoTListRoleAliasesRequest : AWSRequest /**

Return the list of role aliases in ascending alphabetical order.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

A marker used to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; @end /** */ @interface AWSIoTListRoleAliasesResponse : AWSModel /**

A marker used to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; /**

The role aliases.

*/ @property (nonatomic, strong) NSArray * _Nullable roleAliases; @end /** */ @interface AWSIoTListScheduledAuditsRequest : AWSRequest /**

The maximum number of results to return at one time. The default is 25.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListScheduledAuditsResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The list of scheduled audits.

*/ @property (nonatomic, strong) NSArray * _Nullable scheduledAudits; @end /** */ @interface AWSIoTListSecurityProfilesForTargetRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

If true, return child groups too.

*/ @property (nonatomic, strong) NSNumber * _Nullable recursive; /**

The ARN of the target (thing group) whose attached security profiles you want to get.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileTargetArn; @end /** */ @interface AWSIoTListSecurityProfilesForTargetResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A list of security profiles and their associated targets.

*/ @property (nonatomic, strong) NSArray * _Nullable securityProfileTargetMappings; @end /** */ @interface AWSIoTListSecurityProfilesRequest : AWSRequest /**

A filter to limit results to the security profiles that use the defined dimension. Cannot be used with metricName

*/ @property (nonatomic, strong) NSString * _Nullable dimensionName; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The name of the custom metric. Cannot be used with dimensionName.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListSecurityProfilesResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A list of security profile identifiers (names and ARNs).

*/ @property (nonatomic, strong) NSArray * _Nullable securityProfileIdentifiers; @end /** */ @interface AWSIoTListStreamsRequest : AWSRequest /**

Set to true to return the list of streams in ascending order.

*/ @property (nonatomic, strong) NSNumber * _Nullable ascendingOrder; /**

The maximum number of results to return at a time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

A token used to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListStreamsResponse : AWSModel /**

A token used to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A list of streams.

*/ @property (nonatomic, strong) NSArray * _Nullable streams; @end /** */ @interface AWSIoTListTagsForResourceRequest : AWSRequest /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The ARN of the resource.

*/ @property (nonatomic, strong) NSString * _Nullable resourceArn; @end /** */ @interface AWSIoTListTagsForResourceResponse : AWSModel /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The list of tags assigned to the resource.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /** */ @interface AWSIoTListTargetsForPolicyRequest : AWSRequest /**

A marker used to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable marker; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable pageSize; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; @end /** */ @interface AWSIoTListTargetsForPolicyResponse : AWSModel /**

A marker used to get the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextMarker; /**

The policy targets.

*/ @property (nonatomic, strong) NSArray * _Nullable targets; @end /** */ @interface AWSIoTListTargetsForSecurityProfileRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; @end /** */ @interface AWSIoTListTargetsForSecurityProfileResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The thing groups to which the security profile is attached.

*/ @property (nonatomic, strong) NSArray * _Nullable securityProfileTargets; @end /** */ @interface AWSIoTListThingGroupsForThingRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The thing name.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTListThingGroupsForThingResponse : AWSModel /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The thing groups.

*/ @property (nonatomic, strong) NSArray * _Nullable thingGroups; @end /** */ @interface AWSIoTListThingGroupsRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

A filter that limits the results to those with the specified name prefix.

*/ @property (nonatomic, strong) NSString * _Nullable namePrefixFilter; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A filter that limits the results to those with the specified parent group.

*/ @property (nonatomic, strong) NSString * _Nullable parentGroup; /**

If true, return child groups as well.

*/ @property (nonatomic, strong) NSNumber * _Nullable recursive; @end /** */ @interface AWSIoTListThingGroupsResponse : AWSModel /**

The token to use to get the next set of results. Will not be returned if operation has returned all results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The thing groups.

*/ @property (nonatomic, strong) NSArray * _Nullable thingGroups; @end /**

The input for the ListThingPrincipal operation.

Required parameters: [thingName] */ @interface AWSIoTListThingPrincipalsRequest : AWSRequest /**

The maximum number of results to return in this operation.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The name of the thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /**

The output from the ListThingPrincipals operation.

*/ @interface AWSIoTListThingPrincipalsResponse : AWSModel /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The principals associated with the thing.

*/ @property (nonatomic, strong) NSArray * _Nullable principals; @end /** */ @interface AWSIoTListThingRegistrationTaskReportsRequest : AWSRequest /**

The maximum number of results to return per request.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The type of task report.

*/ @property (nonatomic, assign) AWSIoTReportType reportType; /**

The id of the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTListThingRegistrationTaskReportsResponse : AWSModel /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The type of task report.

*/ @property (nonatomic, assign) AWSIoTReportType reportType; /**

Links to the task resources.

*/ @property (nonatomic, strong) NSArray * _Nullable resourceLinks; @end /** */ @interface AWSIoTListThingRegistrationTasksRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The status of the bulk thing provisioning task.

*/ @property (nonatomic, assign) AWSIoTStatus status; @end /** */ @interface AWSIoTListThingRegistrationTasksResponse : AWSModel /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A list of bulk thing provisioning task IDs.

*/ @property (nonatomic, strong) NSArray * _Nullable taskIds; @end /**

The input for the ListThingTypes operation.

*/ @interface AWSIoTListThingTypesRequest : AWSRequest /**

The maximum number of results to return in this operation.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The name of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; @end /**

The output for the ListThingTypes operation.

*/ @interface AWSIoTListThingTypesResponse : AWSModel /**

The token for the next set of results. Will not be returned if operation has returned all results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The thing types.

*/ @property (nonatomic, strong) NSArray * _Nullable thingTypes; @end /** */ @interface AWSIoTListThingsInBillingGroupRequest : AWSRequest /**

The name of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The maximum number of results to return per request.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListThingsInBillingGroupResponse : AWSModel /**

The token to use to get the next set of results. Will not be returned if operation has returned all results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A list of things in the billing group.

*/ @property (nonatomic, strong) NSArray * _Nullable things; @end /** */ @interface AWSIoTListThingsInThingGroupRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

When true, list things in this thing group and in all child groups as well.

*/ @property (nonatomic, strong) NSNumber * _Nullable recursive; /**

The thing group name.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; @end /** */ @interface AWSIoTListThingsInThingGroupResponse : AWSModel /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The things in the specified thing group.

*/ @property (nonatomic, strong) NSArray * _Nullable things; @end /**

The input for the ListThings operation.

*/ @interface AWSIoTListThingsRequest : AWSRequest /**

The attribute name used to search for things.

*/ @property (nonatomic, strong) NSString * _Nullable attributeName; /**

The attribute value used to search for things.

*/ @property (nonatomic, strong) NSString * _Nullable attributeValue; /**

The maximum number of results to return in this operation.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The name of the thing type used to search for things.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; /**

When true, the action returns the thing resources with attribute values that start with the attributeValue provided.

When false, or not present, the action returns only the thing resources with attribute values that match the entire attributeValue provided.

*/ @property (nonatomic, strong) NSNumber * _Nullable usePrefixAttributeValue; @end /**

The output from the ListThings operation.

*/ @interface AWSIoTListThingsResponse : AWSModel /**

The token to use to get the next set of results. Will not be returned if operation has returned all results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The things.

*/ @property (nonatomic, strong) NSArray * _Nullable things; @end /** */ @interface AWSIoTListTopicRuleDestinationsRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListTopicRuleDestinationsResponse : AWSModel /**

Information about a topic rule destination.

*/ @property (nonatomic, strong) NSArray * _Nullable destinationSummaries; /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /**

The input for the ListTopicRules operation.

*/ @interface AWSIoTListTopicRulesRequest : AWSRequest /**

The maximum number of results to return.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

Specifies whether the rule is disabled.

*/ @property (nonatomic, strong) NSNumber * _Nullable ruleDisabled; /**

The topic.

*/ @property (nonatomic, strong) NSString * _Nullable topic; @end /**

The output from the ListTopicRules operation.

*/ @interface AWSIoTListTopicRulesResponse : AWSModel /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The rules.

*/ @property (nonatomic, strong) NSArray * _Nullable rules; @end /** */ @interface AWSIoTListV2LoggingLevelsRequest : AWSRequest /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

To retrieve the next set of results, the nextToken value from a previous response; otherwise null to receive the first set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The type of resource for which you are configuring logging. Must be THING_Group.

*/ @property (nonatomic, assign) AWSIoTLogTargetType targetType; @end /** */ @interface AWSIoTListV2LoggingLevelsResponse : AWSModel /**

The logging configuration for a target.

*/ @property (nonatomic, strong) NSArray * _Nullable logTargetConfigurations; /**

The token to use to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; @end /** */ @interface AWSIoTListViolationEventsRequest : AWSRequest /**

The criteria for a behavior.

*/ @property (nonatomic, assign) AWSIoTBehaviorCriteriaType behaviorCriteriaType; /**

The end time for the alerts to be listed.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

A list of all suppressed alerts.

*/ @property (nonatomic, strong) NSNumber * _Nullable listSuppressedAlerts; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token for the next set of results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

A filter to limit results to those alerts generated by the specified security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The start time for the alerts to be listed.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; /**

A filter to limit results to those alerts caused by the specified thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The verification state of the violation (detect alarm).

*/ @property (nonatomic, assign) AWSIoTVerificationState verificationState; @end /** */ @interface AWSIoTListViolationEventsResponse : AWSModel /**

A token that can be used to retrieve the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The security profile violation alerts issued for this account during the given time period, potentially filtered by security profile, behavior violated, or thing (device) violating.

*/ @property (nonatomic, strong) NSArray * _Nullable violationEvents; @end /**

The Amazon Location rule action sends device location updates from an MQTT message to an Amazon Location tracker resource.

Required parameters: [roleArn, trackerName, deviceId, latitude, longitude] */ @interface AWSIoTLocationAction : AWSModel /**

The unique ID of the device providing the location data.

*/ @property (nonatomic, strong) NSString * _Nullable deviceId; /**

A string that evaluates to a double value that represents the latitude of the device's location.

*/ @property (nonatomic, strong) NSString * _Nullable latitude; /**

A string that evaluates to a double value that represents the longitude of the device's location.

*/ @property (nonatomic, strong) NSString * _Nullable longitude; /**

The IAM role that grants permission to write to the Amazon Location resource.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The time that the location data was sampled. The default value is the time the MQTT message was processed.

*/ @property (nonatomic, strong) AWSIoTLocationTimestamp * _Nullable timestamp; /**

The name of the tracker resource in Amazon Location in which the location is updated.

*/ @property (nonatomic, strong) NSString * _Nullable trackerName; @end /**

Describes how to interpret an application-defined timestamp value from an MQTT message payload and the precision of that value.

Required parameters: [value] */ @interface AWSIoTLocationTimestamp : AWSModel /**

The precision of the timestamp value that results from the expression described in value.

Valid values: SECONDS | MILLISECONDS | MICROSECONDS | NANOSECONDS. The default is MILLISECONDS.

*/ @property (nonatomic, strong) NSString * _Nullable unit; /**

An expression that returns a long epoch time value.

*/ @property (nonatomic, strong) NSString * _Nullable value; @end /**

A log target.

Required parameters: [targetType] */ @interface AWSIoTLogTarget : AWSModel /**

The target name.

*/ @property (nonatomic, strong) NSString * _Nullable targetName; /**

The target type.

*/ @property (nonatomic, assign) AWSIoTLogTargetType targetType; @end /**

The target configuration.

*/ @interface AWSIoTLogTargetConfiguration : AWSModel /**

The logging level.

*/ @property (nonatomic, assign) AWSIoTLogLevel logLevel; /**

A log target

*/ @property (nonatomic, strong) AWSIoTLogTarget * _Nullable logTarget; @end /**

Describes the logging options payload.

Required parameters: [roleArn] */ @interface AWSIoTLoggingOptionsPayload : AWSModel /**

The log level.

*/ @property (nonatomic, assign) AWSIoTLogLevel logLevel; /**

The ARN of the IAM role that grants access.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

The configuration of an ML Detect Security Profile.

Required parameters: [confidenceLevel] */ @interface AWSIoTMachineLearningDetectionConfig : AWSModel /**

The sensitivity of anomalous behavior evaluation. Can be Low, Medium, or High.

*/ @property (nonatomic, assign) AWSIoTConfidenceLevel confidenceLevel; @end /**

An optional configuration within the SchedulingConfig to setup a recurring maintenance window with a predetermined start time and duration for the rollout of a job document to all devices in a target group for a job.

Required parameters: [startTime, durationInMinutes] */ @interface AWSIoTMaintenanceWindow : AWSModel /**

Displays the duration of the next maintenance window.

*/ @property (nonatomic, strong) NSNumber * _Nullable durationInMinutes; /**

Displays the start time of the next maintenance window.

*/ @property (nonatomic, strong) NSString * _Nullable startTime; @end /**

An object that contains information about the managed template.

*/ @interface AWSIoTManagedJobTemplateSummary : AWSModel /**

The description for a managed template.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

A list of environments that are supported with the managed job template.

*/ @property (nonatomic, strong) NSArray * _Nullable environments; /**

The Amazon Resource Name (ARN) for a managed template.

*/ @property (nonatomic, strong) NSString * _Nullable templateArn; /**

The unique Name for a managed template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

The version for a managed template.

*/ @property (nonatomic, strong) NSString * _Nullable templateVersion; @end /**

A metric.

*/ @interface AWSIoTMetricDatum : AWSModel /**

The time the metric value was reported.

*/ @property (nonatomic, strong) NSDate * _Nullable timestamp; /**

The value reported for the metric.

*/ @property (nonatomic, strong) AWSIoTMetricValue * _Nullable value; @end /**

The dimension of a metric.

Required parameters: [dimensionName] */ @interface AWSIoTMetricDimension : AWSModel /**

A unique identifier for the dimension.

*/ @property (nonatomic, strong) NSString * _Nullable dimensionName; /**

Defines how the dimensionValues of a dimension are interpreted. For example, for dimension type TOPIC_FILTER, the IN operator, a message will be counted only if its topic matches one of the topic filters. With NOT_IN operator, a message will be counted only if it doesn't match any of the topic filters. The operator is optional: if it's not provided (is null), it will be interpreted as IN.

*/ @property (nonatomic, assign) AWSIoTDimensionValueOperator operatorValue; @end /**

The metric you want to retain. Dimensions are optional.

Required parameters: [metric] */ @interface AWSIoTMetricToRetain : AWSModel /**

What is measured by the behavior.

*/ @property (nonatomic, strong) NSString * _Nullable metric; /**

The dimension of a metric. This can't be used with custom metrics.

*/ @property (nonatomic, strong) AWSIoTMetricDimension * _Nullable metricDimension; @end /**

The value to be compared with the metric.

*/ @interface AWSIoTMetricValue : AWSModel /**

If the comparisonOperator calls for a set of CIDRs, use this to specify that set to be compared with the metric.

*/ @property (nonatomic, strong) NSArray * _Nullable cidrs; /**

If the comparisonOperator calls for a numeric value, use this to specify that numeric value to be compared with the metric.

*/ @property (nonatomic, strong) NSNumber * _Nullable count; /**

The numeral value of a metric.

*/ @property (nonatomic, strong) NSNumber * _Nullable number; /**

The numeral values of a metric.

*/ @property (nonatomic, strong) NSArray * _Nullable numbers; /**

If the comparisonOperator calls for a set of ports, use this to specify that set to be compared with the metric.

*/ @property (nonatomic, strong) NSArray * _Nullable ports; /**

The string values of a metric.

*/ @property (nonatomic, strong) NSArray * _Nullable strings; @end /**

Describes which changes should be applied as part of a mitigation action.

*/ @interface AWSIoTMitigationAction : AWSModel /**

The set of parameters for this mitigation action. The parameters vary, depending on the kind of action you apply.

*/ @property (nonatomic, strong) AWSIoTMitigationActionParams * _Nullable actionParams; /**

A unique identifier for the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable identifier; /**

A user-friendly name for the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable name; /**

The IAM role ARN used to apply this mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Information that identifies a mitigation action. This information is returned by ListMitigationActions.

*/ @interface AWSIoTMitigationActionIdentifier : AWSModel /**

The IAM role ARN used to apply this mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionArn; /**

The friendly name of the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionName; /**

The date when this mitigation action was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; @end /**

The set of parameters for this mitigation action. You can specify only one type of parameter (in other words, you can apply only one action for each defined mitigation action).

*/ @interface AWSIoTMitigationActionParams : AWSModel /**

Parameters to define a mitigation action that moves devices associated with a certificate to one or more specified thing groups, typically for quarantine.

*/ @property (nonatomic, strong) AWSIoTAddThingsToThingGroupParams * _Nullable addThingsToThingGroupParams; /**

Parameters to define a mitigation action that enables Amazon Web Services IoT Core logging at a specified level of detail.

*/ @property (nonatomic, strong) AWSIoTEnableIoTLoggingParams * _Nullable enableIoTLoggingParams; /**

Parameters to define a mitigation action that publishes findings to Amazon Simple Notification Service (Amazon SNS. You can implement your own custom actions in response to the Amazon SNS messages.

*/ @property (nonatomic, strong) AWSIoTPublishFindingToSnsParams * _Nullable publishFindingToSnsParams; /**

Parameters to define a mitigation action that adds a blank policy to restrict permissions.

*/ @property (nonatomic, strong) AWSIoTReplaceDefaultPolicyVersionParams * _Nullable replaceDefaultPolicyVersionParams; /**

Parameters to define a mitigation action that changes the state of the CA certificate to inactive.

*/ @property (nonatomic, strong) AWSIoTUpdateCACertificateParams * _Nullable updateCACertificateParams; /**

Parameters to define a mitigation action that changes the state of the device certificate to inactive.

*/ @property (nonatomic, strong) AWSIoTUpdateDeviceCertificateParams * _Nullable updateDeviceCertificateParams; @end /**

Specifies the MQTT context to use for the test authorizer request

*/ @interface AWSIoTMqttContext : AWSModel /**

The value of the clientId key in an MQTT authorization request.

*/ @property (nonatomic, strong) NSString * _Nullable clientId; /**

The value of the password key in an MQTT authorization request.

*/ @property (nonatomic, strong) NSData * _Nullable password; /**

The value of the username key in an MQTT authorization request.

*/ @property (nonatomic, strong) NSString * _Nullable username; @end /**

Specifies MQTT Version 5.0 headers information. For more information, see MQTT from Amazon Web Services IoT Core Developer Guide.

*/ @interface AWSIoTMqttHeaders : AWSModel /**

A UTF-8 encoded string that describes the content of the publishing message.

For more information, see Content Type from the MQTT Version 5.0 specification.

Supports substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable contentType; /**

The base64-encoded binary data used by the sender of the request message to identify which request the response message is for when it's received.

For more information, see Correlation Data from the MQTT Version 5.0 specification.

This binary data must be based64-encoded.

Supports substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable correlationData; /**

A user-defined integer value that will persist a message at the message broker for a specified amount of time to ensure that the message will expire if it's no longer relevant to the subscriber. The value of messageExpiry represents the number of seconds before it expires. For more information about the limits of messageExpiry, see Amazon Web Services IoT Core message broker and protocol limits and quotas from the Amazon Web Services Reference Guide.

Supports substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable messageExpiry; /**

An Enum string value that indicates whether the payload is formatted as UTF-8.

Valid values are UNSPECIFIED_BYTES and UTF8_DATA.

For more information, see Payload Format Indicator from the MQTT Version 5.0 specification.

Supports substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable payloadFormatIndicator; /**

A UTF-8 encoded string that's used as the topic name for a response message. The response topic is used to describe the topic which the receiver should publish to as part of the request-response flow. The topic must not contain wildcard characters.

For more information, see Response Topic from the MQTT Version 5.0 specification.

Supports substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable responseTopic; /**

An array of key-value pairs that you define in the MQTT5 header.

*/ @property (nonatomic, strong) NSArray * _Nullable userProperties; @end /**

Information about the resource that was noncompliant with the audit check.

*/ @interface AWSIoTNonCompliantResource : AWSModel /**

Other information about the noncompliant resource.

*/ @property (nonatomic, strong) NSDictionary * _Nullable additionalInfo; /**

Information that identifies the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; /**

The type of the noncompliant resource.

*/ @property (nonatomic, assign) AWSIoTResourceType resourceType; @end /**

Describes a file to be associated with an OTA update.

*/ @interface AWSIoTOTAUpdateFile : AWSModel /**

A list of name/attribute pairs.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

The code signing method of the file.

*/ @property (nonatomic, strong) AWSIoTCodeSigning * _Nullable codeSigning; /**

The location of the updated firmware.

*/ @property (nonatomic, strong) AWSIoTFileLocation * _Nullable fileLocation; /**

The name of the file.

*/ @property (nonatomic, strong) NSString * _Nullable fileName; /**

An integer value you can include in the job document to allow your devices to identify the type of file received from the cloud.

*/ @property (nonatomic, strong) NSNumber * _Nullable fileType; /**

The file version.

*/ @property (nonatomic, strong) NSString * _Nullable fileVersion; @end /**

Information about an OTA update.

*/ @interface AWSIoTOTAUpdateInfo : AWSModel /**

A collection of name/value pairs

*/ @property (nonatomic, strong) NSDictionary * _Nullable additionalParameters; /**

The IoT job ARN associated with the OTA update.

*/ @property (nonatomic, strong) NSString * _Nullable awsIotJobArn; /**

The IoT job ID associated with the OTA update.

*/ @property (nonatomic, strong) NSString * _Nullable awsIotJobId; /**

Configuration for the rollout of OTA updates.

*/ @property (nonatomic, strong) AWSIoTAwsJobExecutionsRolloutConfig * _Nullable awsJobExecutionsRolloutConfig; /**

Configuration information for pre-signed URLs. Valid when protocols contains HTTP.

*/ @property (nonatomic, strong) AWSIoTAwsJobPresignedUrlConfig * _Nullable awsJobPresignedUrlConfig; /**

The date when the OTA update was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

A description of the OTA update.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

Error information associated with the OTA update.

*/ @property (nonatomic, strong) AWSIoTErrorInfo * _Nullable errorInfo; /**

The date when the OTA update was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The OTA update ARN.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateArn; /**

A list of files associated with the OTA update.

*/ @property (nonatomic, strong) NSArray * _Nullable otaUpdateFiles; /**

The OTA update ID.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateId; /**

The status of the OTA update.

*/ @property (nonatomic, assign) AWSIoTOTAUpdateStatus otaUpdateStatus; /**

The protocol used to transfer the OTA update image. Valid values are [HTTP], [MQTT], [HTTP, MQTT]. When both HTTP and MQTT are specified, the target device can choose the protocol.

*/ @property (nonatomic, strong) NSArray * _Nullable protocols; /**

Specifies whether the OTA update will continue to run (CONTINUOUS), or will be complete after all those things specified as targets have completed the OTA update (SNAPSHOT). If continuous, the OTA update may also be run on a thing when a change is detected in a target. For example, an OTA update will run on a thing when the thing is added to a target group, even after the OTA update was completed by all things originally in the group.

*/ @property (nonatomic, assign) AWSIoTTargetSelection targetSelection; /**

The targets of the OTA update.

*/ @property (nonatomic, strong) NSArray * _Nullable targets; @end /**

An OTA update summary.

*/ @interface AWSIoTOTAUpdateSummary : AWSModel /**

The date when the OTA update was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The OTA update ARN.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateArn; /**

The OTA update ID.

*/ @property (nonatomic, strong) NSString * _Nullable otaUpdateId; @end /**

Describes an action that writes data to an Amazon OpenSearch Service domain.

Required parameters: [roleArn, endpoint, index, type, id] */ @interface AWSIoTOpenSearchAction : AWSModel /**

The endpoint of your OpenSearch domain.

*/ @property (nonatomic, strong) NSString * _Nullable endpoint; /**

The unique identifier for the document you are storing.

*/ @property (nonatomic, strong) NSString * _Nullable identifier; /**

The OpenSearch index where you want to store your data.

*/ @property (nonatomic, strong) NSString * _Nullable index; /**

The IAM role ARN that has access to OpenSearch.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The type of document you are storing.

*/ @property (nonatomic, strong) NSString * _Nullable types; @end /**

A certificate that has been transferred but not yet accepted.

*/ @interface AWSIoTOutgoingCertificate : AWSModel /**

The certificate ARN.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The certificate ID.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The certificate creation date.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The date the transfer was initiated.

*/ @property (nonatomic, strong) NSDate * _Nullable transferDate; /**

The transfer message.

*/ @property (nonatomic, strong) NSString * _Nullable transferMessage; /**

The Amazon Web Services account to which the transfer was made.

*/ @property (nonatomic, strong) NSString * _Nullable transferredTo; @end /**

A summary of information about a software package.

*/ @interface AWSIoTPackageSummary : AWSModel /**

The date that the package was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The name of the default package version.

*/ @property (nonatomic, strong) NSString * _Nullable defaultVersionName; /**

The date that the package was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The name for the target package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; @end /**

A summary of information about a package version.

*/ @interface AWSIoTPackageVersionSummary : AWSModel /**

The date that the package version was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The date that the package version was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The name of the associated software package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

The status of the package version. For more information, see Package version lifecycle.

*/ @property (nonatomic, assign) AWSIoTPackageVersionStatus status; /**

The name of the target package version.

*/ @property (nonatomic, strong) NSString * _Nullable versionName; @end /**

Describes the percentile and percentile value.

*/ @interface AWSIoTPercentPair : AWSModel /**

The percentile.

*/ @property (nonatomic, strong) NSNumber * _Nullable percent; /**

The value of the percentile.

*/ @property (nonatomic, strong) NSNumber * _Nullable value; @end /**

Describes an IoT policy.

*/ @interface AWSIoTPolicy : AWSModel /**

The policy ARN.

*/ @property (nonatomic, strong) NSString * _Nullable policyArn; /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; @end /**

Describes a policy version.

*/ @interface AWSIoTPolicyVersion : AWSModel /**

The date and time the policy was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createDate; /**

Specifies whether the policy version is the default.

*/ @property (nonatomic, strong) NSNumber * _Nullable isDefaultVersion; /**

The policy version ID.

*/ @property (nonatomic, strong) NSString * _Nullable versionId; @end /**

Information about the version of the policy associated with the resource.

*/ @interface AWSIoTPolicyVersionIdentifier : AWSModel /**

The name of the policy.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The ID of the version of the policy associated with the resource.

*/ @property (nonatomic, strong) NSString * _Nullable policyVersionId; @end /**

Configuration for pre-signed S3 URLs.

*/ @interface AWSIoTPresignedUrlConfig : AWSModel /**

How long (in seconds) pre-signed URLs are valid. Valid values are 60 - 3600, the default value is 3600 seconds. Pre-signed URLs are generated when Jobs receives an MQTT request for the job document.

*/ @property (nonatomic, strong) NSNumber * _Nullable expiresInSec; /**

The ARN of an IAM role that grants permission to download files from the S3 bucket where the job data/updates are stored. The role must also grant permission for IoT to download the files.

For information about addressing the confused deputy problem, see cross-service confused deputy prevention in the Amazon Web Services IoT Core developer guide.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Structure that contains payloadVersion and targetArn.

Required parameters: [targetArn] */ @interface AWSIoTProvisioningHook : AWSModel /**

The payload that was sent to the target function.

Note: Only Lambda functions are currently supported.

*/ @property (nonatomic, strong) NSString * _Nullable payloadVersion; /**

The ARN of the target function.

Note: Only Lambda functions are currently supported.

*/ @property (nonatomic, strong) NSString * _Nullable targetArn; @end /**

A summary of information about a provisioning template.

*/ @interface AWSIoTProvisioningTemplateSummary : AWSModel /**

The date when the provisioning template summary was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The description of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

True if the fleet provision template is enabled, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable enabled; /**

The date when the provisioning template summary was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The ARN of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateArn; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; /**

The type you define in a provisioning template. You can create a template with only one type. You can't change the template type after its creation. The default value is FLEET_PROVISIONING. For more information about provisioning template, see: Provisioning template.

*/ @property (nonatomic, assign) AWSIoTTemplateType types; @end /**

A summary of information about a fleet provision template version.

*/ @interface AWSIoTProvisioningTemplateVersionSummary : AWSModel /**

The date when the provisioning template version was created

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

True if the provisioning template version is the default version, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable isDefaultVersion; /**

The ID of the fleet provisioning template version.

*/ @property (nonatomic, strong) NSNumber * _Nullable versionId; @end /**

Parameters to define a mitigation action that publishes findings to Amazon SNS. You can implement your own custom actions in response to the Amazon SNS messages.

Required parameters: [topicArn] */ @interface AWSIoTPublishFindingToSnsParams : AWSModel /**

The ARN of the topic to which you want to publish the findings.

*/ @property (nonatomic, strong) NSString * _Nullable topicArn; @end /**

An asset property value entry containing the following information.

Required parameters: [propertyValues] */ @interface AWSIoTPutAssetPropertyValueEntry : AWSModel /**

The ID of the IoT SiteWise asset. You must specify either a propertyAlias or both an aliasId and a propertyId. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable assetId; /**

Optional. A unique identifier for this entry that you can define to better track which message caused an error in case of failure. Accepts substitution templates. Defaults to a new UUID.

*/ @property (nonatomic, strong) NSString * _Nullable entryId; /**

The name of the property alias associated with your asset property. You must specify either a propertyAlias or both an aliasId and a propertyId. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable propertyAlias; /**

The ID of the asset's property. You must specify either a propertyAlias or both an aliasId and a propertyId. Accepts substitution templates.

*/ @property (nonatomic, strong) NSString * _Nullable propertyId; /**

A list of property values to insert that each contain timestamp, quality, and value (TQV) information.

*/ @property (nonatomic, strong) NSArray * _Nullable propertyValues; @end /**

The input for the DynamoActionVS action that specifies the DynamoDB table to which the message data will be written.

Required parameters: [tableName] */ @interface AWSIoTPutItemInput : AWSModel /**

The table where the message data will be written.

*/ @property (nonatomic, strong) NSString * _Nullable tableName; @end /** */ @interface AWSIoTPutVerificationStateOnViolationRequest : AWSRequest /**

The verification state of the violation.

*/ @property (nonatomic, assign) AWSIoTVerificationState verificationState; /**

The description of the verification state of the violation (detect alarm).

*/ @property (nonatomic, strong) NSString * _Nullable verificationStateDescription; /**

The violation ID.

*/ @property (nonatomic, strong) NSString * _Nullable violationId; @end /** */ @interface AWSIoTPutVerificationStateOnViolationResponse : AWSModel @end /**

Allows you to define a criteria to initiate the increase in rate of rollout for a job.

*/ @interface AWSIoTRateIncreaseCriteria : AWSModel /**

The threshold for number of notified things that will initiate the increase in rate of rollout.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfNotifiedThings; /**

The threshold for number of succeeded things that will initiate the increase in rate of rollout.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfSucceededThings; @end /**

The input to the RegisterCACertificate operation.

Required parameters: [caCertificate] */ @interface AWSIoTRegisterCACertificateRequest : AWSRequest /**

Allows this CA certificate to be used for auto registration of device certificates.

*/ @property (nonatomic, strong) NSNumber * _Nullable allowAutoRegistration; /**

The CA certificate.

*/ @property (nonatomic, strong) NSString * _Nullable caCertificate; /**

Describes the certificate mode in which the Certificate Authority (CA) will be registered. If the verificationCertificate field is not provided, set certificateMode to be SNI_ONLY. If the verificationCertificate field is provided, set certificateMode to be DEFAULT. When certificateMode is not provided, it defaults to DEFAULT. All the device certificates that are registered using this CA will be registered in the same certificate mode as the CA. For more information about certificate mode for device certificates, see certificate mode.

*/ @property (nonatomic, assign) AWSIoTCertificateMode certificateMode; /**

Information about the registration configuration.

*/ @property (nonatomic, strong) AWSIoTRegistrationConfig * _Nullable registrationConfig; /**

A boolean value that specifies if the CA certificate is set to active.

Valid values: ACTIVE | INACTIVE

*/ @property (nonatomic, strong) NSNumber * _Nullable setAsActive; /**

Metadata which can be used to manage the CA certificate.

For URI Request parameters use format: ...key1=value1&key2=value2...

For the CLI command-line parameter use format: &&tags "key1=value1&key2=value2..."

For the cli-input-json file use format: "tags": "key1=value1&key2=value2..."

*/ @property (nonatomic, strong) NSArray * _Nullable tags; /**

The private key verification certificate. If certificateMode is SNI_ONLY, the verificationCertificate field must be empty. If certificateMode is DEFAULT or not provided, the verificationCertificate field must not be empty.

*/ @property (nonatomic, strong) NSString * _Nullable verificationCertificate; @end /**

The output from the RegisterCACertificateResponse operation.

*/ @interface AWSIoTRegisterCACertificateResponse : AWSModel /**

The CA certificate ARN.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The CA certificate identifier.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; @end /**

The input to the RegisterCertificate operation.

Required parameters: [certificatePem] */ @interface AWSIoTRegisterCertificateRequest : AWSRequest /**

The CA certificate used to sign the device certificate being registered.

*/ @property (nonatomic, strong) NSString * _Nullable caCertificatePem; /**

The certificate data, in PEM format.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePem; /**

A boolean value that specifies if the certificate is set to active.

Valid values: ACTIVE | INACTIVE

*/ @property (nonatomic, strong) NSNumber * _Nullable setAsActive; /**

The status of the register certificate request. Valid values that you can use include ACTIVE, INACTIVE, and REVOKED.

*/ @property (nonatomic, assign) AWSIoTCertificateStatus status; @end /**

The output from the RegisterCertificate operation.

*/ @interface AWSIoTRegisterCertificateResponse : AWSModel /**

The certificate ARN.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The certificate identifier.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; @end /** */ @interface AWSIoTRegisterCertificateWithoutCARequest : AWSRequest /**

The certificate data, in PEM format.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePem; /**

The status of the register certificate request.

*/ @property (nonatomic, assign) AWSIoTCertificateStatus status; @end /** */ @interface AWSIoTRegisterCertificateWithoutCAResponse : AWSModel /**

The Amazon Resource Name (ARN) of the registered certificate.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The ID of the registered certificate. (The last part of the certificate ARN contains the certificate ID.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; @end /** */ @interface AWSIoTRegisterThingRequest : AWSRequest /**

The parameters for provisioning a thing. See Provisioning Templates for more information.

*/ @property (nonatomic, strong) NSDictionary * _Nullable parameters; /**

The provisioning template. See Provisioning Devices That Have Device Certificates for more information.

*/ @property (nonatomic, strong) NSString * _Nullable templateBody; @end /** */ @interface AWSIoTRegisterThingResponse : AWSModel /**

The certificate data, in PEM format.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePem; /**

ARNs for the generated resources.

*/ @property (nonatomic, strong) NSDictionary * _Nullable resourceArns; @end /**

The registration configuration.

*/ @interface AWSIoTRegistrationConfig : AWSModel /**

The ARN of the role.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The template body.

*/ @property (nonatomic, strong) NSString * _Nullable templateBody; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /**

The input for the RejectCertificateTransfer operation.

Required parameters: [certificateId] */ @interface AWSIoTRejectCertificateTransferRequest : AWSRequest /**

The ID of the certificate. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The reason the certificate transfer was rejected.

*/ @property (nonatomic, strong) NSString * _Nullable rejectReason; @end /**

Information about a related resource.

*/ @interface AWSIoTRelatedResource : AWSModel /**

Other information about the resource.

*/ @property (nonatomic, strong) NSDictionary * _Nullable additionalInfo; /**

Information that identifies the resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; /**

The type of resource.

*/ @property (nonatomic, assign) AWSIoTResourceType resourceType; @end /** */ @interface AWSIoTRemoveThingFromBillingGroupRequest : AWSRequest /**

The ARN of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupArn; /**

The name of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The ARN of the thing to be removed from the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; /**

The name of the thing to be removed from the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTRemoveThingFromBillingGroupResponse : AWSModel @end /** */ @interface AWSIoTRemoveThingFromThingGroupRequest : AWSRequest /**

The ARN of the thing to remove from the group.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; /**

The group ARN.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupArn; /**

The group name.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; /**

The name of the thing to remove from the group.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTRemoveThingFromThingGroupResponse : AWSModel @end /**

Parameters to define a mitigation action that adds a blank policy to restrict permissions.

Required parameters: [templateName] */ @interface AWSIoTReplaceDefaultPolicyVersionParams : AWSModel /**

The name of the template to be applied. The only supported value is BLANK_POLICY.

*/ @property (nonatomic, assign) AWSIoTPolicyTemplateName templateName; @end /**

The input for the ReplaceTopicRule operation.

Required parameters: [ruleName, topicRulePayload] */ @interface AWSIoTReplaceTopicRuleRequest : AWSRequest /**

The name of the rule.

*/ @property (nonatomic, strong) NSString * _Nullable ruleName; /**

The rule payload.

*/ @property (nonatomic, strong) AWSIoTTopicRulePayload * _Nullable topicRulePayload; @end /**

Describes an action to republish to another topic.

Required parameters: [roleArn, topic] */ @interface AWSIoTRepublishAction : AWSModel /**

MQTT Version 5.0 headers information. For more information, see MQTT from the Amazon Web Services IoT Core Developer Guide.

*/ @property (nonatomic, strong) AWSIoTMqttHeaders * _Nullable headers; /**

The Quality of Service (QoS) level to use when republishing messages. The default value is 0.

*/ @property (nonatomic, strong) NSNumber * _Nullable qos; /**

The ARN of the IAM role that grants access.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The name of the MQTT topic.

*/ @property (nonatomic, strong) NSString * _Nullable topic; @end /**

Information that identifies the noncompliant resource.

*/ @interface AWSIoTResourceIdentifier : AWSModel /**

The account with which the resource is associated.

*/ @property (nonatomic, strong) NSString * _Nullable account; /**

The ID of the CA certificate used to authorize the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable caCertificateId; /**

The client ID.

*/ @property (nonatomic, strong) NSString * _Nullable clientId; /**

The ID of the Amazon Cognito identity pool.

*/ @property (nonatomic, strong) NSString * _Nullable cognitoIdentityPoolId; /**

The ARN of the identified device certificate.

*/ @property (nonatomic, strong) NSString * _Nullable deviceCertificateArn; /**

The ID of the certificate attached to the resource.

*/ @property (nonatomic, strong) NSString * _Nullable deviceCertificateId; /**

The ARN of the IAM role that has overly permissive actions.

*/ @property (nonatomic, strong) NSString * _Nullable iamRoleArn; /**

The issuer certificate identifier.

*/ @property (nonatomic, strong) AWSIoTIssuerCertificateIdentifier * _Nullable issuerCertificateIdentifier; /**

The version of the policy associated with the resource.

*/ @property (nonatomic, strong) AWSIoTPolicyVersionIdentifier * _Nullable policyVersionIdentifier; /**

The ARN of the role alias that has overly permissive actions.

*/ @property (nonatomic, strong) NSString * _Nullable roleAliasArn; @end /**

The criteria that determines how many retries are allowed for each failure type for a job.

Required parameters: [failureType, numberOfRetries] */ @interface AWSIoTRetryCriteria : AWSModel /**

The type of job execution failures that can initiate a job retry.

*/ @property (nonatomic, assign) AWSIoTRetryableFailureType failureType; /**

The number of retries allowed for a failure type for the job.

*/ @property (nonatomic, strong) NSNumber * _Nullable numberOfRetries; @end /**

Role alias description.

*/ @interface AWSIoTRoleAliasDescription : AWSModel /**

The UNIX timestamp of when the role alias was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The number of seconds for which the credential is valid.

*/ @property (nonatomic, strong) NSNumber * _Nullable credentialDurationSeconds; /**

The UNIX timestamp of when the role alias was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The role alias owner.

*/ @property (nonatomic, strong) NSString * _Nullable owner; /**

The role alias.

*/ @property (nonatomic, strong) NSString * _Nullable roleAlias; /**

The ARN of the role alias.

*/ @property (nonatomic, strong) NSString * _Nullable roleAliasArn; /**

The role ARN.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Describes an action to write data to an Amazon S3 bucket.

Required parameters: [roleArn, bucketName, key] */ @interface AWSIoTS3Action : AWSModel /**

The Amazon S3 bucket.

*/ @property (nonatomic, strong) NSString * _Nullable bucketName; /**

The Amazon S3 canned ACL that controls access to the object identified by the object key. For more information, see S3 canned ACLs.

*/ @property (nonatomic, assign) AWSIoTCannedAccessControlList cannedAcl; /**

The object key. For more information, see Actions, resources, and condition keys for Amazon S3.

*/ @property (nonatomic, strong) NSString * _Nullable key; /**

The ARN of the IAM role that grants access.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Describes the location of updated firmware in S3.

*/ @interface AWSIoTS3Destination : AWSModel /**

The S3 bucket that contains the updated firmware.

*/ @property (nonatomic, strong) NSString * _Nullable bucket; /**

The S3 prefix.

*/ @property (nonatomic, strong) NSString * _Nullable prefix; @end /**

The S3 location.

*/ @interface AWSIoTS3Location : AWSModel /**

The S3 bucket.

*/ @property (nonatomic, strong) NSString * _Nullable bucket; /**

The S3 key.

*/ @property (nonatomic, strong) NSString * _Nullable key; /**

The S3 bucket version.

*/ @property (nonatomic, strong) NSString * _Nullable version; @end /**

Describes an action to write a message to a Salesforce IoT Cloud Input Stream.

Required parameters: [token, url] */ @interface AWSIoTSalesforceAction : AWSModel /**

The token used to authenticate access to the Salesforce IoT Cloud Input Stream. The token is available from the Salesforce IoT Cloud platform after creation of the Input Stream.

*/ @property (nonatomic, strong) NSString * _Nullable token; /**

The URL exposed by the Salesforce IoT Cloud Input Stream. The URL is available from the Salesforce IoT Cloud platform after creation of the Input Stream.

*/ @property (nonatomic, strong) NSString * _Nullable url; @end /**

Information about the scheduled audit.

*/ @interface AWSIoTScheduledAuditMetadata : AWSModel /**

The day of the month on which the scheduled audit is run (if the frequency is "MONTHLY"). If days 29-31 are specified, and the month does not have that many days, the audit takes place on the "LAST" day of the month.

*/ @property (nonatomic, strong) NSString * _Nullable dayOfMonth; /**

The day of the week on which the scheduled audit is run (if the frequency is "WEEKLY" or "BIWEEKLY").

*/ @property (nonatomic, assign) AWSIoTDayOfWeek dayOfWeek; /**

How often the scheduled audit occurs.

*/ @property (nonatomic, assign) AWSIoTAuditFrequency frequency; /**

The ARN of the scheduled audit.

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditArn; /**

The name of the scheduled audit.

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditName; @end /**

Displays the next seven maintenance window occurrences and their start times.

*/ @interface AWSIoTScheduledJobRollout : AWSModel /**

Displays the start times of the next seven maintenance window occurrences.

*/ @property (nonatomic, strong) NSString * _Nullable startTime; @end /**

Specifies the date and time that a job will begin the rollout of the job document to all devices in the target group. Additionally, you can specify the end behavior for each job execution when it reaches the scheduled end time.

*/ @interface AWSIoTSchedulingConfig : AWSModel /**

Specifies the end behavior for all job executions after a job reaches the selected endTime. If endTime is not selected when creating the job, then endBehavior does not apply.

*/ @property (nonatomic, assign) AWSIoTJobEndBehavior endBehavior; /**

The time a job will stop rollout of the job document to all devices in the target group for a job. The endTime must take place no later than two years from the current time and be scheduled a minimum of thirty minutes from the current time. The minimum duration between startTime and endTime is thirty minutes. The maximum duration between startTime and endTime is two years. The date and time format for the endTime is YYYY-MM-DD for the date and HH:MM for the time.

*/ @property (nonatomic, strong) NSString * _Nullable endTime; /**

An optional configuration within the SchedulingConfig to setup a recurring maintenance window with a predetermined start time and duration for the rollout of a job document to all devices in a target group for a job.

*/ @property (nonatomic, strong) NSArray * _Nullable maintenanceWindows; /**

The time a job will begin rollout of the job document to all devices in the target group for a job. The startTime can be scheduled up to a year in advance and must be scheduled a minimum of thirty minutes from the current time. The date and time format for the startTime is YYYY-MM-DD for the date and HH:MM for the time.

*/ @property (nonatomic, strong) NSString * _Nullable startTime; @end /** */ @interface AWSIoTSearchIndexRequest : AWSRequest /**

The search index name.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The maximum number of results to return at one time.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxResults; /**

The token used to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The search query string. For more information about the search query syntax, see Query syntax.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The query version.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; @end /** */ @interface AWSIoTSearchIndexResponse : AWSModel /**

The token used to get the next set of results, or null if there are no additional results.

*/ @property (nonatomic, strong) NSString * _Nullable nextToken; /**

The thing groups that match the search query.

*/ @property (nonatomic, strong) NSArray * _Nullable thingGroups; /**

The things that match the search query.

*/ @property (nonatomic, strong) NSArray * _Nullable things; @end /**

Identifying information for a Device Defender security profile.

Required parameters: [name, arn] */ @interface AWSIoTSecurityProfileIdentifier : AWSModel /**

The ARN of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable arn; /**

The name you've given to the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable name; @end /**

A target to which an alert is sent when a security profile behavior is violated.

Required parameters: [arn] */ @interface AWSIoTSecurityProfileTarget : AWSModel /**

The ARN of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable arn; @end /**

Information about a security profile and the target associated with it.

*/ @interface AWSIoTSecurityProfileTargetMapping : AWSModel /**

Information that identifies the security profile.

*/ @property (nonatomic, strong) AWSIoTSecurityProfileIdentifier * _Nullable securityProfileIdentifier; /**

Information about the target (thing group) associated with the security profile.

*/ @property (nonatomic, strong) AWSIoTSecurityProfileTarget * _Nullable target; @end /**

An object that contains information about a server certificate.

*/ @interface AWSIoTServerCertificateSummary : AWSModel /**

The ARN of the server certificate.

*/ @property (nonatomic, strong) NSString * _Nullable serverCertificateArn; /**

The status of the server certificate.

*/ @property (nonatomic, assign) AWSIoTServerCertificateStatus serverCertificateStatus; /**

Details that explain the status of the server certificate.

*/ @property (nonatomic, strong) NSString * _Nullable serverCertificateStatusDetail; @end /** */ @interface AWSIoTSetDefaultAuthorizerRequest : AWSRequest /**

The authorizer name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; @end /** */ @interface AWSIoTSetDefaultAuthorizerResponse : AWSModel /**

The authorizer ARN.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerArn; /**

The authorizer name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; @end /**

The input for the SetDefaultPolicyVersion operation.

Required parameters: [policyName, policyVersionId] */ @interface AWSIoTSetDefaultPolicyVersionRequest : AWSRequest /**

The policy name.

*/ @property (nonatomic, strong) NSString * _Nullable policyName; /**

The policy version ID.

*/ @property (nonatomic, strong) NSString * _Nullable policyVersionId; @end /**

The input for the SetLoggingOptions operation.

Required parameters: [loggingOptionsPayload] */ @interface AWSIoTSetLoggingOptionsRequest : AWSRequest /**

The logging options payload.

*/ @property (nonatomic, strong) AWSIoTLoggingOptionsPayload * _Nullable loggingOptionsPayload; @end /** */ @interface AWSIoTSetV2LoggingLevelRequest : AWSRequest /**

The log level.

*/ @property (nonatomic, assign) AWSIoTLogLevel logLevel; /**

The log target.

*/ @property (nonatomic, strong) AWSIoTLogTarget * _Nullable logTarget; @end /** */ @interface AWSIoTSetV2LoggingOptionsRequest : AWSRequest /**

The default logging level.

*/ @property (nonatomic, assign) AWSIoTLogLevel defaultLogLevel; /**

If true all logs are disabled. The default is false.

*/ @property (nonatomic, strong) NSNumber * _Nullable disableAllLogs; /**

The ARN of the role that allows IoT to write to Cloudwatch logs.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

For more information, see Signature Version 4 signing process.

Required parameters: [signingRegion, serviceName, roleArn] */ @interface AWSIoTSigV4Authorization : AWSModel /**

The ARN of the signing role.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The service name to use while signing with Sig V4.

*/ @property (nonatomic, strong) NSString * _Nullable serviceName; /**

The signing region.

*/ @property (nonatomic, strong) NSString * _Nullable signingRegion; @end /**

Describes the code-signing profile.

*/ @interface AWSIoTSigningProfileParameter : AWSModel /**

Certificate ARN.

*/ @property (nonatomic, strong) NSString * _Nullable certificateArn; /**

The location of the code-signing certificate on your device.

*/ @property (nonatomic, strong) NSString * _Nullable certificatePathOnDevice; /**

The hardware platform of your device.

*/ @property (nonatomic, strong) NSString * _Nullable platform; @end /**

Describes an action to publish to an Amazon SNS topic.

Required parameters: [targetArn, roleArn] */ @interface AWSIoTSnsAction : AWSModel /**

(Optional) The message format of the message to publish. Accepted values are "JSON" and "RAW". The default value of the attribute is "RAW". SNS uses this setting to determine if the payload should be parsed and relevant platform-specific bits of the payload should be extracted. To read more about SNS message formats, see https://docs.aws.amazon.com/sns/latest/dg/json-formats.html refer to their official documentation.

*/ @property (nonatomic, assign) AWSIoTMessageFormat messageFormat; /**

The ARN of the IAM role that grants access.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The ARN of the SNS topic.

*/ @property (nonatomic, strong) NSString * _Nullable targetArn; @end /**

Describes an action to publish data to an Amazon SQS queue.

Required parameters: [roleArn, queueUrl] */ @interface AWSIoTSqsAction : AWSModel /**

The URL of the Amazon SQS queue.

*/ @property (nonatomic, strong) NSString * _Nullable queueUrl; /**

The ARN of the IAM role that grants access.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

Specifies whether to use Base64 encoding.

*/ @property (nonatomic, strong) NSNumber * _Nullable useBase64; @end /** */ @interface AWSIoTStartAuditMitigationActionsTaskRequest : AWSRequest /**

For an audit check, specifies which mitigation actions to apply. Those actions must be defined in your Amazon Web Services accounts.

*/ @property (nonatomic, strong) NSDictionary *> * _Nullable auditCheckToActionsMapping; /**

Each audit mitigation task must have a unique client request token. If you try to start a new task with the same token as a task that already exists, an exception occurs. If you omit this value, a unique client request token is generated automatically.

*/ @property (nonatomic, strong) NSString * _Nullable clientRequestToken; /**

Specifies the audit findings to which the mitigation actions are applied. You can apply them to a type of audit check, to all findings from an audit, or to a specific set of findings.

*/ @property (nonatomic, strong) AWSIoTAuditMitigationActionsTaskTarget * _Nullable target; /**

A unique identifier for the task. You can use this identifier to check the status of the task or to cancel it.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTStartAuditMitigationActionsTaskResponse : AWSModel /**

The unique identifier for the audit mitigation task. This matches the taskId that you specified in the request.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTStartDetectMitigationActionsTaskRequest : AWSRequest /**

The actions to be performed when a device has unexpected behavior.

*/ @property (nonatomic, strong) NSArray * _Nullable actions; /**

Each mitigation action task must have a unique client request token. If you try to create a new task with the same token as a task that already exists, an exception occurs. If you omit this value, Amazon Web Services SDKs will automatically generate a unique client request.

*/ @property (nonatomic, strong) NSString * _Nullable clientRequestToken; /**

Specifies to list only active violations.

*/ @property (nonatomic, strong) NSNumber * _Nullable includeOnlyActiveViolations; /**

Specifies to include suppressed alerts.

*/ @property (nonatomic, strong) NSNumber * _Nullable includeSuppressedAlerts; /**

Specifies the ML Detect findings to which the mitigation actions are applied.

*/ @property (nonatomic, strong) AWSIoTDetectMitigationActionsTaskTarget * _Nullable target; /**

The unique identifier of the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; /**

Specifies the time period of which violation events occurred between.

*/ @property (nonatomic, strong) AWSIoTViolationEventOccurrenceRange * _Nullable violationEventOccurrenceRange; @end /** */ @interface AWSIoTStartDetectMitigationActionsTaskResponse : AWSModel /**

The unique identifier of the task.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTStartOnDemandAuditTaskRequest : AWSRequest /**

Which checks are performed during the audit. The checks you specify must be enabled for your account or an exception occurs. Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or UpdateAccountAuditConfiguration to select which checks are enabled.

*/ @property (nonatomic, strong) NSArray * _Nullable targetCheckNames; @end /** */ @interface AWSIoTStartOnDemandAuditTaskResponse : AWSModel /**

The ID of the on-demand audit you started.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /**

Information required to start a signing job.

*/ @interface AWSIoTStartSigningJobParameter : AWSModel /**

The location to write the code-signed file.

*/ @property (nonatomic, strong) AWSIoTDestination * _Nullable destination; /**

The code-signing profile name.

*/ @property (nonatomic, strong) NSString * _Nullable signingProfileName; /**

Describes the code-signing profile.

*/ @property (nonatomic, strong) AWSIoTSigningProfileParameter * _Nullable signingProfileParameter; @end /** */ @interface AWSIoTStartThingRegistrationTaskRequest : AWSRequest /**

The S3 bucket that contains the input file.

*/ @property (nonatomic, strong) NSString * _Nullable inputFileBucket; /**

The name of input file within the S3 bucket. This file contains a newline delimited JSON file. Each line contains the parameter values to provision one device (thing).

*/ @property (nonatomic, strong) NSString * _Nullable inputFileKey; /**

The IAM role ARN that grants permission the input file.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateBody; @end /** */ @interface AWSIoTStartThingRegistrationTaskResponse : AWSModel /**

The bulk thing provisioning task ID.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /**

A statistical ranking (percentile) that indicates a threshold value by which a behavior is determined to be in compliance or in violation of the behavior.

*/ @interface AWSIoTStatisticalThreshold : AWSModel /**

The percentile that resolves to a threshold value by which compliance with a behavior is determined. Metrics are collected over the specified period (durationSeconds) from all reporting devices in your account and statistical ranks are calculated. Then, the measurements from a device are collected over the same period. If the accumulated measurements from the device fall above or below (comparisonOperator) the value associated with the percentile specified, then the device is considered to be in compliance with the behavior, otherwise a violation occurs.

*/ @property (nonatomic, strong) NSString * _Nullable statistic; @end /**

A map of key-value pairs for all supported statistics. For issues with missing or unexpected values for this API, consult Fleet indexing troubleshooting guide.

*/ @interface AWSIoTStatistics : AWSModel /**

The average of the aggregated field values.

*/ @property (nonatomic, strong) NSNumber * _Nullable average; /**

The count of things that match the query string criteria and contain a valid aggregation field value.

*/ @property (nonatomic, strong) NSNumber * _Nullable count; /**

The maximum aggregated field value.

*/ @property (nonatomic, strong) NSNumber * _Nullable maximum; /**

The minimum aggregated field value.

*/ @property (nonatomic, strong) NSNumber * _Nullable minimum; /**

The standard deviation of the aggregated field values.

*/ @property (nonatomic, strong) NSNumber * _Nullable stdDeviation; /**

The sum of the aggregated field values.

*/ @property (nonatomic, strong) NSNumber * _Nullable sum; /**

The sum of the squares of the aggregated field values.

*/ @property (nonatomic, strong) NSNumber * _Nullable sumOfSquares; /**

The variance of the aggregated field values.

*/ @property (nonatomic, strong) NSNumber * _Nullable variance; @end /**

Starts execution of a Step Functions state machine.

Required parameters: [stateMachineName, roleArn] */ @interface AWSIoTStepFunctionsAction : AWSModel /**

(Optional) A name will be given to the state machine execution consisting of this prefix followed by a UUID. Step Functions automatically creates a unique name for each state machine execution if one is not provided.

*/ @property (nonatomic, strong) NSString * _Nullable executionNamePrefix; /**

The ARN of the role that grants IoT permission to start execution of a state machine ("Action":"states:StartExecution").

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The name of the Step Functions state machine whose execution will be started.

*/ @property (nonatomic, strong) NSString * _Nullable stateMachineName; @end /** */ @interface AWSIoTStopThingRegistrationTaskRequest : AWSRequest /**

The bulk thing provisioning task ID.

*/ @property (nonatomic, strong) NSString * _Nullable taskId; @end /** */ @interface AWSIoTStopThingRegistrationTaskResponse : AWSModel @end /**

Describes a group of files that can be streamed.

*/ @interface AWSIoTStream : AWSModel /**

The ID of a file associated with a stream.

*/ @property (nonatomic, strong) NSNumber * _Nullable fileId; /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; @end /**

Represents a file to stream.

*/ @interface AWSIoTStreamFile : AWSModel /**

The file ID.

*/ @property (nonatomic, strong) NSNumber * _Nullable fileId; /**

The location of the file in S3.

*/ @property (nonatomic, strong) AWSIoTS3Location * _Nullable s3Location; @end /**

Information about a stream.

*/ @interface AWSIoTStreamInfo : AWSModel /**

The date when the stream was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

The description of the stream.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The files to stream.

*/ @property (nonatomic, strong) NSArray * _Nullable files; /**

The date when the stream was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastUpdatedAt; /**

An IAM role IoT assumes to access your S3 files.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The stream ARN.

*/ @property (nonatomic, strong) NSString * _Nullable streamArn; /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; /**

The stream version.

*/ @property (nonatomic, strong) NSNumber * _Nullable streamVersion; @end /**

A summary of a stream.

*/ @interface AWSIoTStreamSummary : AWSModel /**

A description of the stream.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The stream ARN.

*/ @property (nonatomic, strong) NSString * _Nullable streamArn; /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; /**

The stream version.

*/ @property (nonatomic, strong) NSNumber * _Nullable streamVersion; @end /**

A set of key/value pairs that are used to manage the resource.

Required parameters: [Key] */ @interface AWSIoTTag : AWSModel /**

The tag's key.

*/ @property (nonatomic, strong) NSString * _Nullable key; /**

The tag's value.

*/ @property (nonatomic, strong) NSString * _Nullable value; @end /** */ @interface AWSIoTTagResourceRequest : AWSRequest /**

The ARN of the resource.

*/ @property (nonatomic, strong) NSString * _Nullable resourceArn; /**

The new or modified tags for the resource.

*/ @property (nonatomic, strong) NSArray * _Nullable tags; @end /** */ @interface AWSIoTTagResourceResponse : AWSModel @end /**

Statistics for the checks performed during the audit.

*/ @interface AWSIoTTaskStatistics : AWSModel /**

The number of checks that did not run because the audit was canceled.

*/ @property (nonatomic, strong) NSNumber * _Nullable canceledChecks; /**

The number of checks that found compliant resources.

*/ @property (nonatomic, strong) NSNumber * _Nullable compliantChecks; /**

The number of checks.

*/ @property (nonatomic, strong) NSNumber * _Nullable failedChecks; /**

The number of checks in progress.

*/ @property (nonatomic, strong) NSNumber * _Nullable inProgressChecks; /**

The number of checks that found noncompliant resources.

*/ @property (nonatomic, strong) NSNumber * _Nullable nonCompliantChecks; /**

The number of checks in this audit.

*/ @property (nonatomic, strong) NSNumber * _Nullable totalChecks; /**

The number of checks waiting for data collection.

*/ @property (nonatomic, strong) NSNumber * _Nullable waitingForDataCollectionChecks; @end /**

Provides summary counts of how many tasks for findings are in a particular state. This information is included in the response from DescribeAuditMitigationActionsTask.

*/ @interface AWSIoTTaskStatisticsForAuditCheck : AWSModel /**

The number of findings to which the mitigation action task was canceled when applied.

*/ @property (nonatomic, strong) NSNumber * _Nullable canceledFindingsCount; /**

The number of findings for which at least one of the actions failed when applied.

*/ @property (nonatomic, strong) NSNumber * _Nullable failedFindingsCount; /**

The number of findings skipped because of filter conditions provided in the parameters to the command.

*/ @property (nonatomic, strong) NSNumber * _Nullable skippedFindingsCount; /**

The number of findings for which all mitigation actions succeeded when applied.

*/ @property (nonatomic, strong) NSNumber * _Nullable succeededFindingsCount; /**

The total number of findings to which a task is being applied.

*/ @property (nonatomic, strong) NSNumber * _Nullable totalFindingsCount; @end /**

Performs an aggregation that will return a list of buckets. The list of buckets is a ranked list of the number of occurrences of an aggregation field value.

*/ @interface AWSIoTTermsAggregation : AWSModel /**

The number of buckets to return in the response. Default to 10.

*/ @property (nonatomic, strong) NSNumber * _Nullable maxBuckets; @end /** */ @interface AWSIoTTestAuthorizationRequest : AWSRequest /**

A list of authorization info objects. Simulating authorization will create a response for each authInfo object in the list.

*/ @property (nonatomic, strong) NSArray * _Nullable authInfos; /**

The MQTT client ID.

*/ @property (nonatomic, strong) NSString * _Nullable clientId; /**

The Cognito identity pool ID.

*/ @property (nonatomic, strong) NSString * _Nullable cognitoIdentityPoolId; /**

When testing custom authorization, the policies specified here are treated as if they are attached to the principal being authorized.

*/ @property (nonatomic, strong) NSArray * _Nullable policyNamesToAdd; /**

When testing custom authorization, the policies specified here are treated as if they are not attached to the principal being authorized.

*/ @property (nonatomic, strong) NSArray * _Nullable policyNamesToSkip; /**

The principal. Valid principals are CertificateArn (arn:aws:iot:region:accountId:cert/certificateId), thingGroupArn (arn:aws:iot:region:accountId:thinggroup/groupName) and CognitoId (region:id).

*/ @property (nonatomic, strong) NSString * _Nullable principal; @end /** */ @interface AWSIoTTestAuthorizationResponse : AWSModel /**

The authentication results.

*/ @property (nonatomic, strong) NSArray * _Nullable authResults; @end /** */ @interface AWSIoTTestInvokeAuthorizerRequest : AWSRequest /**

The custom authorizer name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; /**

Specifies a test HTTP authorization request.

*/ @property (nonatomic, strong) AWSIoTHttpContext * _Nullable httpContext; /**

Specifies a test MQTT authorization request.

*/ @property (nonatomic, strong) AWSIoTMqttContext * _Nullable mqttContext; /**

Specifies a test TLS authorization request.

*/ @property (nonatomic, strong) AWSIoTTlsContext * _Nullable tlsContext; /**

The token returned by your custom authentication service.

*/ @property (nonatomic, strong) NSString * _Nullable token; /**

The signature made with the token and your custom authentication service's private key. This value must be Base-64-encoded.

*/ @property (nonatomic, strong) NSString * _Nullable tokenSignature; @end /** */ @interface AWSIoTTestInvokeAuthorizerResponse : AWSModel /**

The number of seconds after which the connection is terminated.

*/ @property (nonatomic, strong) NSNumber * _Nullable disconnectAfterInSeconds; /**

True if the token is authenticated, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable isAuthenticated; /**

IAM policy documents.

*/ @property (nonatomic, strong) NSArray * _Nullable policyDocuments; /**

The principal ID.

*/ @property (nonatomic, strong) NSString * _Nullable principalId; /**

The number of seconds after which the temporary credentials are refreshed.

*/ @property (nonatomic, strong) NSNumber * _Nullable refreshAfterInSeconds; @end /**

The properties of the thing, including thing name, thing type name, and a list of thing attributes.

*/ @interface AWSIoTThingAttribute : AWSModel /**

A list of thing attributes which are name-value pairs.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

The thing ARN.

*/ @property (nonatomic, strong) NSString * _Nullable thingArn; /**

The name of the thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The name of the thing type, if the thing has been associated with a type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; /**

The version of the thing record in the registry.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /**

The connectivity status of the thing.

*/ @interface AWSIoTThingConnectivity : AWSModel /**

True if the thing is connected to the Amazon Web Services IoT Core service; false if it is not connected.

*/ @property (nonatomic, strong) NSNumber * _Nullable connected; /**

The reason why the client is disconnected. If the thing has been disconnected for approximately an hour, the disconnectReason value might be missing.

*/ @property (nonatomic, strong) NSString * _Nullable disconnectReason; /**

The epoch time (in milliseconds) when the thing last connected or disconnected. If the thing has been disconnected for approximately an hour, the time value might be missing.

*/ @property (nonatomic, strong) NSNumber * _Nullable timestamp; @end /**

The thing search index document.

*/ @interface AWSIoTThingDocument : AWSModel /**

The attributes.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

Indicates whether the thing is connected to the Amazon Web Services IoT Core service.

*/ @property (nonatomic, strong) AWSIoTThingConnectivity * _Nullable connectivity; /**

Contains Device Defender data.

For more information about Device Defender, see Device Defender.

*/ @property (nonatomic, strong) NSString * _Nullable deviceDefender; /**

The unnamed shadow and named shadow.

For more information about shadows, see IoT Device Shadow service.

*/ @property (nonatomic, strong) NSString * _Nullable shadow; /**

Thing group names.

*/ @property (nonatomic, strong) NSArray * _Nullable thingGroupNames; /**

The thing ID.

*/ @property (nonatomic, strong) NSString * _Nullable thingId; /**

The thing name.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The thing type name.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; @end /**

The thing group search index document.

*/ @interface AWSIoTThingGroupDocument : AWSModel /**

The thing group attributes.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

Parent group names.

*/ @property (nonatomic, strong) NSArray * _Nullable parentGroupNames; /**

The thing group description.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupDescription; /**

The thing group ID.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupId; /**

The thing group name.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; @end /**

Thing group indexing configuration.

Required parameters: [thingGroupIndexingMode] */ @interface AWSIoTThingGroupIndexingConfiguration : AWSModel /**

A list of thing group fields to index. This list cannot contain any managed fields. Use the GetIndexingConfiguration API to get a list of managed fields.

Contains custom field names and their data type.

*/ @property (nonatomic, strong) NSArray * _Nullable customFields; /**

Contains fields that are indexed and whose types are already known by the Fleet Indexing service. This is an optional field. For more information, see Managed fields in the Amazon Web Services IoT Core Developer Guide.

*/ @property (nonatomic, strong) NSArray * _Nullable managedFields; /**

Thing group indexing mode.

*/ @property (nonatomic, assign) AWSIoTThingGroupIndexingMode thingGroupIndexingMode; @end /**

Thing group metadata.

*/ @interface AWSIoTThingGroupMetadata : AWSModel /**

The UNIX timestamp of when the thing group was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The parent thing group name.

*/ @property (nonatomic, strong) NSString * _Nullable parentGroupName; /**

The root parent thing group.

*/ @property (nonatomic, strong) NSArray * _Nullable rootToParentThingGroups; @end /**

Thing group properties.

*/ @interface AWSIoTThingGroupProperties : AWSModel /**

The thing group attributes in JSON format.

*/ @property (nonatomic, strong) AWSIoTAttributePayload * _Nullable attributePayload; /**

The thing group description.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupDescription; @end /**

The thing indexing configuration. For more information, see Managing Thing Indexing.

Required parameters: [thingIndexingMode] */ @interface AWSIoTThingIndexingConfiguration : AWSModel /**

Contains custom field names and their data type.

*/ @property (nonatomic, strong) NSArray * _Nullable customFields; /**

Device Defender indexing mode. Valid values are:

  • VIOLATIONS – Your thing index contains Device Defender violations. To enable Device Defender indexing, deviceDefenderIndexingMode must not be set to OFF.

  • OFF - Device Defender indexing is disabled.

For more information about Device Defender violations, see Device Defender Detect.

*/ @property (nonatomic, assign) AWSIoTDeviceDefenderIndexingMode deviceDefenderIndexingMode; /**

Provides additional filters for specific data sources. Named shadow is the only data source that currently supports and requires a filter. To add named shadows to your fleet indexing configuration, set namedShadowIndexingMode to be ON and specify your shadow names in filter.

*/ @property (nonatomic, strong) AWSIoTIndexingFilter * _Nullable filter; /**

Contains fields that are indexed and whose types are already known by the Fleet Indexing service.

*/ @property (nonatomic, strong) NSArray * _Nullable managedFields; /**

Named shadow indexing mode. Valid values are:

  • ON – Your thing index contains named shadow. To enable thing named shadow indexing, namedShadowIndexingMode must not be set to OFF.

  • OFF - Named shadow indexing is disabled.

For more information about Shadows, see IoT Device Shadow service.

*/ @property (nonatomic, assign) AWSIoTNamedShadowIndexingMode namedShadowIndexingMode; /**

Thing connectivity indexing mode. Valid values are:

  • STATUS – Your thing index contains connectivity status. To enable thing connectivity indexing, thingIndexMode must not be set to OFF.

  • OFF - Thing connectivity status indexing is disabled.

*/ @property (nonatomic, assign) AWSIoTThingConnectivityIndexingMode thingConnectivityIndexingMode; /**

Thing indexing mode. Valid values are:

  • REGISTRY – Your thing index contains registry data only.

  • REGISTRY_AND_SHADOW - Your thing index contains registry and shadow data.

  • OFF - Thing indexing is disabled.

*/ @property (nonatomic, assign) AWSIoTThingIndexingMode thingIndexingMode; @end /**

The definition of the thing type, including thing type name and description.

*/ @interface AWSIoTThingTypeDefinition : AWSModel /**

The thing type ARN.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeArn; /**

The ThingTypeMetadata contains additional information about the thing type including: creation date and time, a value indicating whether the thing type is deprecated, and a date and time when it was deprecated.

*/ @property (nonatomic, strong) AWSIoTThingTypeMetadata * _Nullable thingTypeMetadata; /**

The name of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; /**

The ThingTypeProperties for the thing type.

*/ @property (nonatomic, strong) AWSIoTThingTypeProperties * _Nullable thingTypeProperties; @end /**

The ThingTypeMetadata contains additional information about the thing type including: creation date and time, a value indicating whether the thing type is deprecated, and a date and time when time was deprecated.

*/ @interface AWSIoTThingTypeMetadata : AWSModel /**

The date and time when the thing type was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

Whether the thing type is deprecated. If true, no new things could be associated with this type.

*/ @property (nonatomic, strong) NSNumber * _Nullable deprecated; /**

The date and time when the thing type was deprecated.

*/ @property (nonatomic, strong) NSDate * _Nullable deprecationDate; @end /**

The ThingTypeProperties contains information about the thing type including: a thing type description, and a list of searchable thing attribute names.

*/ @interface AWSIoTThingTypeProperties : AWSModel /**

A list of searchable thing attribute names.

*/ @property (nonatomic, strong) NSArray * _Nullable searchableAttributes; /**

The description of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeDescription; @end /**

Specifies the amount of time each device has to finish its execution of the job. A timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the timer expires, it will be automatically set to TIMED_OUT.

*/ @interface AWSIoTTimeoutConfig : AWSModel /**

Specifies the amount of time, in minutes, this device has to finish execution of this job. The timeout interval can be anywhere between 1 minute and 7 days (1 to 10080 minutes). The in progress timer can't be updated and will apply to all job executions for the job. Whenever a job execution remains in the IN_PROGRESS status for longer than this interval, the job execution will fail and switch to the terminal TIMED_OUT status.

*/ @property (nonatomic, strong) NSNumber * _Nullable inProgressTimeoutInMinutes; @end /**

The Timestream rule action writes attributes (measures) from an MQTT message into an Amazon Timestream table. For more information, see the Timestream topic rule action documentation.

Required parameters: [roleArn, databaseName, tableName, dimensions] */ @interface AWSIoTTimestreamAction : AWSModel /**

The name of an Amazon Timestream database.

*/ @property (nonatomic, strong) NSString * _Nullable databaseName; /**

Metadata attributes of the time series that are written in each measure record.

*/ @property (nonatomic, strong) NSArray * _Nullable dimensions; /**

The ARN of the role that grants permission to write to the Amazon Timestream database table.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The name of the database table into which to write the measure records.

*/ @property (nonatomic, strong) NSString * _Nullable tableName; /**

Specifies an application-defined value to replace the default value assigned to the Timestream record's timestamp in the time column.

You can use this property to specify the value and the precision of the Timestream record's timestamp. You can specify a value from the message payload or a value computed by a substitution template.

If omitted, the topic rule action assigns the timestamp, in milliseconds, at the time it processed the rule.

*/ @property (nonatomic, strong) AWSIoTTimestreamTimestamp * _Nullable timestamp; @end /**

Metadata attributes of the time series that are written in each measure record.

Required parameters: [name, value] */ @interface AWSIoTTimestreamDimension : AWSModel /**

The metadata dimension name. This is the name of the column in the Amazon Timestream database table record.

Dimensions cannot be named: measure_name, measure_value, or time. These names are reserved. Dimension names cannot start with ts_ or measure_value and they cannot contain the colon (:) character.

*/ @property (nonatomic, strong) NSString * _Nullable name; /**

The value to write in this column of the database record.

*/ @property (nonatomic, strong) NSString * _Nullable value; @end /**

Describes how to interpret an application-defined timestamp value from an MQTT message payload and the precision of that value.

Required parameters: [value, unit] */ @interface AWSIoTTimestreamTimestamp : AWSModel /**

The precision of the timestamp value that results from the expression described in value.

Valid values: SECONDS | MILLISECONDS | MICROSECONDS | NANOSECONDS. The default is MILLISECONDS.

*/ @property (nonatomic, strong) NSString * _Nullable unit; /**

An expression that returns a long epoch time value.

*/ @property (nonatomic, strong) NSString * _Nullable value; @end /**

An object that specifies the TLS configuration for a domain.

*/ @interface AWSIoTTlsConfig : AWSModel /**

The security policy for a domain configuration. For more information, see Security policies in the Amazon Web Services IoT Core developer guide.

*/ @property (nonatomic, strong) NSString * _Nullable securityPolicy; @end /**

Specifies the TLS context to use for the test authorizer request.

*/ @interface AWSIoTTlsContext : AWSModel /**

The value of the serverName key in a TLS authorization request.

*/ @property (nonatomic, strong) NSString * _Nullable serverName; @end /**

Describes a rule.

*/ @interface AWSIoTTopicRule : AWSModel /**

The actions associated with the rule.

*/ @property (nonatomic, strong) NSArray * _Nullable actions; /**

The version of the SQL rules engine to use when evaluating the rule.

*/ @property (nonatomic, strong) NSString * _Nullable awsIotSqlVersion; /**

The date and time the rule was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

The description of the rule.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The action to perform when an error occurs.

*/ @property (nonatomic, strong) AWSIoTAction * _Nullable errorAction; /**

Specifies whether the rule is disabled.

*/ @property (nonatomic, strong) NSNumber * _Nullable ruleDisabled; /**

The name of the rule.

*/ @property (nonatomic, strong) NSString * _Nullable ruleName; /**

The SQL statement used to query the topic. When using a SQL query with multiple lines, be sure to escape the newline characters.

*/ @property (nonatomic, strong) NSString * _Nullable sql; @end /**

A topic rule destination.

*/ @interface AWSIoTTopicRuleDestination : AWSModel /**

The topic rule destination URL.

*/ @property (nonatomic, strong) NSString * _Nullable arn; /**

The date and time when the topic rule destination was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

Properties of the HTTP URL.

*/ @property (nonatomic, strong) AWSIoTHttpUrlDestinationProperties * _Nullable httpUrlProperties; /**

The date and time when the topic rule destination was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastUpdatedAt; /**

The status of the topic rule destination. Valid values are:

IN_PROGRESS

A topic rule destination was created but has not been confirmed. You can set status to IN_PROGRESS by calling UpdateTopicRuleDestination. Calling UpdateTopicRuleDestination causes a new confirmation challenge to be sent to your confirmation endpoint.

ENABLED

Confirmation was completed, and traffic to this destination is allowed. You can set status to DISABLED by calling UpdateTopicRuleDestination.

DISABLED

Confirmation was completed, and traffic to this destination is not allowed. You can set status to ENABLED by calling UpdateTopicRuleDestination.

ERROR

Confirmation could not be completed, for example if the confirmation timed out. You can call GetTopicRuleDestination for details about the error. You can set status to IN_PROGRESS by calling UpdateTopicRuleDestination. Calling UpdateTopicRuleDestination causes a new confirmation challenge to be sent to your confirmation endpoint.

*/ @property (nonatomic, assign) AWSIoTTopicRuleDestinationStatus status; /**

Additional details or reason why the topic rule destination is in the current status.

*/ @property (nonatomic, strong) NSString * _Nullable statusReason; /**

Properties of the virtual private cloud (VPC) connection.

*/ @property (nonatomic, strong) AWSIoTVpcDestinationProperties * _Nullable vpcProperties; @end /**

Configuration of the topic rule destination.

*/ @interface AWSIoTTopicRuleDestinationConfiguration : AWSModel /**

Configuration of the HTTP URL.

*/ @property (nonatomic, strong) AWSIoTHttpUrlDestinationConfiguration * _Nullable httpUrlConfiguration; /**

Configuration of the virtual private cloud (VPC) connection.

*/ @property (nonatomic, strong) AWSIoTVpcDestinationConfiguration * _Nullable vpcConfiguration; @end /**

Information about the topic rule destination.

*/ @interface AWSIoTTopicRuleDestinationSummary : AWSModel /**

The topic rule destination ARN.

*/ @property (nonatomic, strong) NSString * _Nullable arn; /**

The date and time when the topic rule destination was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

Information about the HTTP URL.

*/ @property (nonatomic, strong) AWSIoTHttpUrlDestinationSummary * _Nullable httpUrlSummary; /**

The date and time when the topic rule destination was last updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastUpdatedAt; /**

The status of the topic rule destination. Valid values are:

IN_PROGRESS

A topic rule destination was created but has not been confirmed. You can set status to IN_PROGRESS by calling UpdateTopicRuleDestination. Calling UpdateTopicRuleDestination causes a new confirmation challenge to be sent to your confirmation endpoint.

ENABLED

Confirmation was completed, and traffic to this destination is allowed. You can set status to DISABLED by calling UpdateTopicRuleDestination.

DISABLED

Confirmation was completed, and traffic to this destination is not allowed. You can set status to ENABLED by calling UpdateTopicRuleDestination.

ERROR

Confirmation could not be completed, for example if the confirmation timed out. You can call GetTopicRuleDestination for details about the error. You can set status to IN_PROGRESS by calling UpdateTopicRuleDestination. Calling UpdateTopicRuleDestination causes a new confirmation challenge to be sent to your confirmation endpoint.

*/ @property (nonatomic, assign) AWSIoTTopicRuleDestinationStatus status; /**

The reason the topic rule destination is in the current status.

*/ @property (nonatomic, strong) NSString * _Nullable statusReason; /**

Information about the virtual private cloud (VPC) connection.

*/ @property (nonatomic, strong) AWSIoTVpcDestinationSummary * _Nullable vpcDestinationSummary; @end /**

Describes a rule.

*/ @interface AWSIoTTopicRuleListItem : AWSModel /**

The date and time the rule was created.

*/ @property (nonatomic, strong) NSDate * _Nullable createdAt; /**

The rule ARN.

*/ @property (nonatomic, strong) NSString * _Nullable ruleArn; /**

Specifies whether the rule is disabled.

*/ @property (nonatomic, strong) NSNumber * _Nullable ruleDisabled; /**

The name of the rule.

*/ @property (nonatomic, strong) NSString * _Nullable ruleName; /**

The pattern for the topic names that apply.

*/ @property (nonatomic, strong) NSString * _Nullable topicPattern; @end /**

Describes a rule.

Required parameters: [sql, actions] */ @interface AWSIoTTopicRulePayload : AWSModel /**

The actions associated with the rule.

*/ @property (nonatomic, strong) NSArray * _Nullable actions; /**

The version of the SQL rules engine to use when evaluating the rule.

*/ @property (nonatomic, strong) NSString * _Nullable awsIotSqlVersion; /**

The description of the rule.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The action to take when an error occurs.

*/ @property (nonatomic, strong) AWSIoTAction * _Nullable errorAction; /**

Specifies whether the rule is disabled.

*/ @property (nonatomic, strong) NSNumber * _Nullable ruleDisabled; /**

The SQL statement used to query the topic. For more information, see IoT SQL Reference in the IoT Developer Guide.

*/ @property (nonatomic, strong) NSString * _Nullable sql; @end /**

The input for the TransferCertificate operation.

Required parameters: [certificateId, targetAwsAccount] */ @interface AWSIoTTransferCertificateRequest : AWSRequest /**

The ID of the certificate. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The Amazon Web Services account.

*/ @property (nonatomic, strong) NSString * _Nullable targetAwsAccount; /**

The transfer message.

*/ @property (nonatomic, strong) NSString * _Nullable transferMessage; @end /**

The output from the TransferCertificate operation.

*/ @interface AWSIoTTransferCertificateResponse : AWSModel /**

The ARN of the certificate.

*/ @property (nonatomic, strong) NSString * _Nullable transferredCertificateArn; @end /**

Data used to transfer a certificate to an Amazon Web Services account.

*/ @interface AWSIoTTransferData : AWSModel /**

The date the transfer was accepted.

*/ @property (nonatomic, strong) NSDate * _Nullable acceptDate; /**

The date the transfer was rejected.

*/ @property (nonatomic, strong) NSDate * _Nullable rejectDate; /**

The reason why the transfer was rejected.

*/ @property (nonatomic, strong) NSString * _Nullable rejectReason; /**

The date the transfer took place.

*/ @property (nonatomic, strong) NSDate * _Nullable transferDate; /**

The transfer message.

*/ @property (nonatomic, strong) NSString * _Nullable transferMessage; @end /** */ @interface AWSIoTUntagResourceRequest : AWSRequest /**

The ARN of the resource.

*/ @property (nonatomic, strong) NSString * _Nullable resourceArn; /**

A list of the keys of the tags to be removed from the resource.

*/ @property (nonatomic, strong) NSArray * _Nullable tagKeys; @end /** */ @interface AWSIoTUntagResourceResponse : AWSModel @end /** */ @interface AWSIoTUpdateAccountAuditConfigurationRequest : AWSRequest /**

Specifies which audit checks are enabled and disabled for this account. Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are currently enabled.

Some data collection might start immediately when certain checks are enabled. When a check is disabled, any data collected so far in relation to the check is deleted.

You cannot disable a check if it's used by any scheduled audit. You must first delete the check from the scheduled audit or delete the scheduled audit itself.

On the first call to UpdateAccountAuditConfiguration, this parameter is required and must specify at least one enabled check.

*/ @property (nonatomic, strong) NSDictionary * _Nullable auditCheckConfigurations; /**

Information about the targets to which audit notifications are sent.

*/ @property (nonatomic, strong) NSDictionary * _Nullable auditNotificationTargetConfigurations; /**

The Amazon Resource Name (ARN) of the role that grants permission to IoT to access information about your devices, policies, certificates, and other items as required when performing an audit.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /** */ @interface AWSIoTUpdateAccountAuditConfigurationResponse : AWSModel @end /** */ @interface AWSIoTUpdateAuditSuppressionRequest : AWSRequest /**

An audit check name. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSString * _Nullable checkName; /**

The description of the audit suppression.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The expiration date (epoch timestamp in seconds) that you want the suppression to adhere to.

*/ @property (nonatomic, strong) NSDate * _Nullable expirationDate; /**

Information that identifies the noncompliant resource.

*/ @property (nonatomic, strong) AWSIoTResourceIdentifier * _Nullable resourceIdentifier; /**

Indicates whether a suppression should exist indefinitely or not.

*/ @property (nonatomic, strong) NSNumber * _Nullable suppressIndefinitely; @end /** */ @interface AWSIoTUpdateAuditSuppressionResponse : AWSModel @end /** */ @interface AWSIoTUpdateAuthorizerRequest : AWSRequest /**

The ARN of the authorizer's Lambda function.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerFunctionArn; /**

The authorizer name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; /**

When true, the result from the authorizer’s Lambda function is cached for the time specified in refreshAfterInSeconds. The cached result is used while the device reuses the same HTTP connection.

*/ @property (nonatomic, strong) NSNumber * _Nullable enableCachingForHttp; /**

The status of the update authorizer request.

*/ @property (nonatomic, assign) AWSIoTAuthorizerStatus status; /**

The key used to extract the token from the HTTP headers.

*/ @property (nonatomic, strong) NSString * _Nullable tokenKeyName; /**

The public keys used to verify the token signature.

*/ @property (nonatomic, strong) NSDictionary * _Nullable tokenSigningPublicKeys; @end /** */ @interface AWSIoTUpdateAuthorizerResponse : AWSModel /**

The authorizer ARN.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerArn; /**

The authorizer name.

*/ @property (nonatomic, strong) NSString * _Nullable authorizerName; @end /** */ @interface AWSIoTUpdateBillingGroupRequest : AWSRequest /**

The name of the billing group.

*/ @property (nonatomic, strong) NSString * _Nullable billingGroupName; /**

The properties of the billing group.

*/ @property (nonatomic, strong) AWSIoTBillingGroupProperties * _Nullable billingGroupProperties; /**

The expected version of the billing group. If the version of the billing group does not match the expected version specified in the request, the UpdateBillingGroup request is rejected with a VersionConflictException.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; @end /** */ @interface AWSIoTUpdateBillingGroupResponse : AWSModel /**

The latest version of the billing group.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /**

Parameters to define a mitigation action that changes the state of the CA certificate to inactive.

Required parameters: [action] */ @interface AWSIoTUpdateCACertificateParams : AWSModel /**

The action that you want to apply to the CA certificate. The only supported value is DEACTIVATE.

*/ @property (nonatomic, assign) AWSIoTCACertificateUpdateAction action; @end /**

The input to the UpdateCACertificate operation.

Required parameters: [certificateId] */ @interface AWSIoTUpdateCACertificateRequest : AWSRequest /**

The CA certificate identifier.

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The new value for the auto registration status. Valid values are: "ENABLE" or "DISABLE".

*/ @property (nonatomic, assign) AWSIoTAutoRegistrationStatus latestAutoRegistrationStatus; /**

The updated status of the CA certificate.

Note: The status value REGISTER_INACTIVE is deprecated and should not be used.

*/ @property (nonatomic, assign) AWSIoTCACertificateStatus latestStatus; /**

Information about the registration configuration.

*/ @property (nonatomic, strong) AWSIoTRegistrationConfig * _Nullable registrationConfig; /**

If true, removes auto registration.

*/ @property (nonatomic, strong) NSNumber * _Nullable removeAutoRegistration; @end /**

The input for the UpdateCertificate operation.

Required parameters: [certificateId, newStatus] */ @interface AWSIoTUpdateCertificateRequest : AWSRequest /**

The ID of the certificate. (The last part of the certificate ARN contains the certificate ID.)

*/ @property (nonatomic, strong) NSString * _Nullable certificateId; /**

The new status.

Note: Setting the status to PENDING_TRANSFER or PENDING_ACTIVATION will result in an exception being thrown. PENDING_TRANSFER and PENDING_ACTIVATION are statuses used internally by IoT. They are not intended for developer use.

Note: The status value REGISTER_INACTIVE is deprecated and should not be used.

*/ @property (nonatomic, assign) AWSIoTCertificateStatus latestStatus; @end /** */ @interface AWSIoTUpdateCustomMetricRequest : AWSRequest /**

Field represents a friendly name in the console for the custom metric, it doesn't have to be unique. Don't use this name as the metric identifier in the device metric report. Can be updated.

*/ @property (nonatomic, strong) NSString * _Nullable displayName; /**

The name of the custom metric. Cannot be updated.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; @end /** */ @interface AWSIoTUpdateCustomMetricResponse : AWSModel /**

The creation date of the custom metric in milliseconds since epoch.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

A friendly name in the console for the custom metric

*/ @property (nonatomic, strong) NSString * _Nullable displayName; /**

The time the custom metric was last modified in milliseconds since epoch.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The Amazon Resource Number (ARN) of the custom metric.

*/ @property (nonatomic, strong) NSString * _Nullable metricArn; /**

The name of the custom metric.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The type of the custom metric.

The type number only takes a single metric value as an input, but while submitting the metrics value in the DeviceMetrics report, it must be passed as an array with a single value.

*/ @property (nonatomic, assign) AWSIoTCustomMetricType metricType; @end /**

Parameters to define a mitigation action that changes the state of the device certificate to inactive.

Required parameters: [action] */ @interface AWSIoTUpdateDeviceCertificateParams : AWSModel /**

The action that you want to apply to the device certificate. The only supported value is DEACTIVATE.

*/ @property (nonatomic, assign) AWSIoTDeviceCertificateUpdateAction action; @end /** */ @interface AWSIoTUpdateDimensionRequest : AWSRequest /**

A unique identifier for the dimension. Choose something that describes the type and value to make it easy to remember what it does.

*/ @property (nonatomic, strong) NSString * _Nullable name; /**

Specifies the value or list of values for the dimension. For TOPIC_FILTER dimensions, this is a pattern used to match the MQTT topic (for example, "admin/#").

*/ @property (nonatomic, strong) NSArray * _Nullable stringValues; @end /** */ @interface AWSIoTUpdateDimensionResponse : AWSModel /**

The Amazon Resource Name (ARN)of the created dimension.

*/ @property (nonatomic, strong) NSString * _Nullable arn; /**

The date and time, in milliseconds since epoch, when the dimension was initially created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The date and time, in milliseconds since epoch, when the dimension was most recently updated.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

A unique identifier for the dimension.

*/ @property (nonatomic, strong) NSString * _Nullable name; /**

The value or list of values used to scope the dimension. For example, for topic filters, this is the pattern used to match the MQTT topic name.

*/ @property (nonatomic, strong) NSArray * _Nullable stringValues; /**

The type of the dimension.

*/ @property (nonatomic, assign) AWSIoTDimensionType types; @end /** */ @interface AWSIoTUpdateDomainConfigurationRequest : AWSRequest /**

An object that specifies the authorization service for a domain.

*/ @property (nonatomic, strong) AWSIoTAuthorizerConfig * _Nullable authorizerConfig; /**

The name of the domain configuration to be updated.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationName; /**

The status to which the domain configuration should be updated.

*/ @property (nonatomic, assign) AWSIoTDomainConfigurationStatus domainConfigurationStatus; /**

Removes the authorization configuration from a domain.

*/ @property (nonatomic, strong) NSNumber * _Nullable removeAuthorizerConfig; /**

An object that specifies the TLS configuration for a domain.

*/ @property (nonatomic, strong) AWSIoTTlsConfig * _Nullable tlsConfig; @end /** */ @interface AWSIoTUpdateDomainConfigurationResponse : AWSModel /**

The ARN of the domain configuration that was updated.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationArn; /**

The name of the domain configuration that was updated.

*/ @property (nonatomic, strong) NSString * _Nullable domainConfigurationName; @end /** */ @interface AWSIoTUpdateDynamicThingGroupRequest : AWSRequest /**

The expected version of the dynamic thing group to update.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

The dynamic thing group index to update.

Currently one index is supported: AWS_Things.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The dynamic thing group search query string to update.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The dynamic thing group query version to update.

Currently one query version is supported: "2017-09-30". If not specified, the query version defaults to this value.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; /**

The name of the dynamic thing group to update.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; /**

The dynamic thing group properties to update.

*/ @property (nonatomic, strong) AWSIoTThingGroupProperties * _Nullable thingGroupProperties; @end /** */ @interface AWSIoTUpdateDynamicThingGroupResponse : AWSModel /**

The dynamic thing group version.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /** */ @interface AWSIoTUpdateEventConfigurationsRequest : AWSRequest /**

The new event configuration values.

*/ @property (nonatomic, strong) NSDictionary * _Nullable eventConfigurations; @end /** */ @interface AWSIoTUpdateEventConfigurationsResponse : AWSModel @end /** */ @interface AWSIoTUpdateFleetMetricRequest : AWSRequest /**

The field to aggregate.

*/ @property (nonatomic, strong) NSString * _Nullable aggregationField; /**

The type of the aggregation query.

*/ @property (nonatomic, strong) AWSIoTAggregationType * _Nullable aggregationType; /**

The description of the fleet metric.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The expected version of the fleet metric record in the registry.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

The name of the index to search.

*/ @property (nonatomic, strong) NSString * _Nullable indexName; /**

The name of the fleet metric to update.

*/ @property (nonatomic, strong) NSString * _Nullable metricName; /**

The time in seconds between fleet metric emissions. Range [60(1 min), 86400(1 day)] and must be multiple of 60.

*/ @property (nonatomic, strong) NSNumber * _Nullable period; /**

The search query string.

*/ @property (nonatomic, strong) NSString * _Nullable queryString; /**

The version of the query.

*/ @property (nonatomic, strong) NSString * _Nullable queryVersion; /**

Used to support unit transformation such as milliseconds to seconds. The unit must be supported by CW metric.

*/ @property (nonatomic, assign) AWSIoTFleetMetricUnit unit; @end /** */ @interface AWSIoTUpdateIndexingConfigurationRequest : AWSRequest /**

Thing group indexing configuration.

*/ @property (nonatomic, strong) AWSIoTThingGroupIndexingConfiguration * _Nullable thingGroupIndexingConfiguration; /**

Thing indexing configuration.

*/ @property (nonatomic, strong) AWSIoTThingIndexingConfiguration * _Nullable thingIndexingConfiguration; @end /** */ @interface AWSIoTUpdateIndexingConfigurationResponse : AWSModel @end /** */ @interface AWSIoTUpdateJobRequest : AWSRequest /**

Allows you to create criteria to abort a job.

*/ @property (nonatomic, strong) AWSIoTAbortConfig * _Nullable abortConfig; /**

A short text description of the job.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

Allows you to create the criteria to retry a job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRetryConfig * _Nullable jobExecutionsRetryConfig; /**

Allows you to create a staged rollout of the job.

*/ @property (nonatomic, strong) AWSIoTJobExecutionsRolloutConfig * _Nullable jobExecutionsRolloutConfig; /**

The ID of the job to be updated.

*/ @property (nonatomic, strong) NSString * _Nullable jobId; /**

The namespace used to indicate that a job is a customer-managed job.

When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.

$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/

The namespaceId feature is in public preview.

*/ @property (nonatomic, strong) NSString * _Nullable namespaceId; /**

Configuration information for pre-signed S3 URLs.

*/ @property (nonatomic, strong) AWSIoTPresignedUrlConfig * _Nullable presignedUrlConfig; /**

Specifies the amount of time each device has to finish its execution of the job. The timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the time expires, it will be automatically set to TIMED_OUT.

*/ @property (nonatomic, strong) AWSIoTTimeoutConfig * _Nullable timeoutConfig; @end /** */ @interface AWSIoTUpdateMitigationActionRequest : AWSRequest /**

The friendly name for the mitigation action. You cannot change the name by using UpdateMitigationAction. Instead, you must delete and recreate the mitigation action with the new name.

*/ @property (nonatomic, strong) NSString * _Nullable actionName; /**

Defines the type of action and the parameters for that action.

*/ @property (nonatomic, strong) AWSIoTMitigationActionParams * _Nullable actionParams; /**

The ARN of the IAM role that is used to apply the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /** */ @interface AWSIoTUpdateMitigationActionResponse : AWSModel /**

The ARN for the new mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionArn; /**

A unique identifier for the mitigation action.

*/ @property (nonatomic, strong) NSString * _Nullable actionId; @end /** */ @interface AWSIoTUpdatePackageConfigurationRequest : AWSRequest /**

A unique case-sensitive identifier that you can provide to ensure the idempotency of the request. Don't reuse this client token if a new idempotent request is required.

*/ @property (nonatomic, strong) NSString * _Nullable clientToken; /**

Configuration to manage job's package version reporting. This updates the thing's reserved named shadow that the job targets.

*/ @property (nonatomic, strong) AWSIoTVersionUpdateByJobsConfig * _Nullable versionUpdateByJobsConfig; @end /** */ @interface AWSIoTUpdatePackageConfigurationResponse : AWSModel @end /** */ @interface AWSIoTUpdatePackageRequest : AWSRequest /**

A unique case-sensitive identifier that you can provide to ensure the idempotency of the request. Don't reuse this client token if a new idempotent request is required.

*/ @property (nonatomic, strong) NSString * _Nullable clientToken; /**

The name of the default package version.

Note: You cannot name a defaultVersion and set unsetDefaultVersion equal to true at the same time.

*/ @property (nonatomic, strong) NSString * _Nullable defaultVersionName; /**

The package description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The name of the target package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

Indicates whether you want to remove the named default package version from the software package. Set as true to remove the default package version.

Note: You cannot name a defaultVersion and set unsetDefaultVersion equal to true at the same time.

*/ @property (nonatomic, strong) NSNumber * _Nullable unsetDefaultVersion; @end /** */ @interface AWSIoTUpdatePackageResponse : AWSModel @end /** */ @interface AWSIoTUpdatePackageVersionRequest : AWSRequest /**

The status that the package version should be assigned. For more information, see Package version lifecycle.

*/ @property (nonatomic, assign) AWSIoTPackageVersionAction action; /**

Metadata that can be used to define a package version’s configuration. For example, the S3 file location, configuration options that are being sent to the device or fleet.

Note: Attributes can be updated only when the package version is in a draft state.

The combined size of all the attributes on a package version is limited to 3KB.

*/ @property (nonatomic, strong) NSDictionary * _Nullable attributes; /**

A unique case-sensitive identifier that you can provide to ensure the idempotency of the request. Don't reuse this client token if a new idempotent request is required.

*/ @property (nonatomic, strong) NSString * _Nullable clientToken; /**

The package version description.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The name of the associated software package.

*/ @property (nonatomic, strong) NSString * _Nullable packageName; /**

The name of the target package version.

*/ @property (nonatomic, strong) NSString * _Nullable versionName; @end /** */ @interface AWSIoTUpdatePackageVersionResponse : AWSModel @end /** */ @interface AWSIoTUpdateProvisioningTemplateRequest : AWSRequest /**

The ID of the default provisioning template version.

*/ @property (nonatomic, strong) NSNumber * _Nullable defaultVersionId; /**

The description of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

True to enable the provisioning template, otherwise false.

*/ @property (nonatomic, strong) NSNumber * _Nullable enabled; /**

Updates the pre-provisioning hook template. Only supports template of type FLEET_PROVISIONING. For more information about provisioning template types, see type.

*/ @property (nonatomic, strong) AWSIoTProvisioningHook * _Nullable preProvisioningHook; /**

The ARN of the role associated with the provisioning template. This IoT role grants permission to provision a device.

*/ @property (nonatomic, strong) NSString * _Nullable provisioningRoleArn; /**

Removes pre-provisioning hook template.

*/ @property (nonatomic, strong) NSNumber * _Nullable removePreProvisioningHook; /**

The name of the provisioning template.

*/ @property (nonatomic, strong) NSString * _Nullable templateName; @end /** */ @interface AWSIoTUpdateProvisioningTemplateResponse : AWSModel @end /** */ @interface AWSIoTUpdateRoleAliasRequest : AWSRequest /**

The number of seconds the credential will be valid.

This value must be less than or equal to the maximum session duration of the IAM role that the role alias references.

*/ @property (nonatomic, strong) NSNumber * _Nullable credentialDurationSeconds; /**

The role alias to update.

*/ @property (nonatomic, strong) NSString * _Nullable roleAlias; /**

The role ARN.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /** */ @interface AWSIoTUpdateRoleAliasResponse : AWSModel /**

The role alias.

*/ @property (nonatomic, strong) NSString * _Nullable roleAlias; /**

The role alias ARN.

*/ @property (nonatomic, strong) NSString * _Nullable roleAliasArn; @end /** */ @interface AWSIoTUpdateScheduledAuditRequest : AWSRequest /**

The day of the month on which the scheduled audit takes place. This can be 1 through 31 or LAST. This field is required if the frequency parameter is set to MONTHLY. If days 29-31 are specified, and the month does not have that many days, the audit takes place on the "LAST" day of the month.

*/ @property (nonatomic, strong) NSString * _Nullable dayOfMonth; /**

The day of the week on which the scheduled audit takes place. This can be one of SUN, MON, TUE, WED, THU, FRI, or SAT. This field is required if the "frequency" parameter is set to WEEKLY or BIWEEKLY.

*/ @property (nonatomic, assign) AWSIoTDayOfWeek dayOfWeek; /**

How often the scheduled audit takes place, either DAILY, WEEKLY, BIWEEKLY, or MONTHLY. The start time of each audit is determined by the system.

*/ @property (nonatomic, assign) AWSIoTAuditFrequency frequency; /**

The name of the scheduled audit. (Max. 128 chars)

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditName; /**

Which checks are performed during the scheduled audit. Checks must be enabled for your account. (Use DescribeAccountAuditConfiguration to see the list of all checks, including those that are enabled or use UpdateAccountAuditConfiguration to select which checks are enabled.)

*/ @property (nonatomic, strong) NSArray * _Nullable targetCheckNames; @end /** */ @interface AWSIoTUpdateScheduledAuditResponse : AWSModel /**

The ARN of the scheduled audit.

*/ @property (nonatomic, strong) NSString * _Nullable scheduledAuditArn; @end /** */ @interface AWSIoTUpdateSecurityProfileRequest : AWSRequest /**

Please use UpdateSecurityProfileRequest$additionalMetricsToRetainV2 instead.

A list of metrics whose data is retained (stored). By default, data is retained for any metric used in the profile's behaviors, but it is also retained for any metric specified here. Can be used with custom metrics; cannot be used with dimensions.

*/ @property (nonatomic, strong) NSArray * _Nullable additionalMetricsToRetain; /**

A list of metrics whose data is retained (stored). By default, data is retained for any metric used in the profile's behaviors, but it is also retained for any metric specified here. Can be used with custom metrics; cannot be used with dimensions.

*/ @property (nonatomic, strong) NSArray * _Nullable additionalMetricsToRetainV2; /**

Where the alerts are sent. (Alerts are always sent to the console.)

*/ @property (nonatomic, strong) NSDictionary * _Nullable alertTargets; /**

Specifies the behaviors that, when violated by a device (thing), cause an alert.

*/ @property (nonatomic, strong) NSArray * _Nullable behaviors; /**

If true, delete all additionalMetricsToRetain defined for this security profile. If any additionalMetricsToRetain are defined in the current invocation, an exception occurs.

*/ @property (nonatomic, strong) NSNumber * _Nullable deleteAdditionalMetricsToRetain; /**

If true, delete all alertTargets defined for this security profile. If any alertTargets are defined in the current invocation, an exception occurs.

*/ @property (nonatomic, strong) NSNumber * _Nullable deleteAlertTargets; /**

If true, delete all behaviors defined for this security profile. If any behaviors are defined in the current invocation, an exception occurs.

*/ @property (nonatomic, strong) NSNumber * _Nullable deleteBehaviors; /**

The expected version of the security profile. A new version is generated whenever the security profile is updated. If you specify a value that is different from the actual version, a VersionConflictException is thrown.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

A description of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileDescription; /**

The name of the security profile you want to update.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; @end /** */ @interface AWSIoTUpdateSecurityProfileResponse : AWSModel /**

Please use UpdateSecurityProfileResponse$additionalMetricsToRetainV2 instead.

A list of metrics whose data is retained (stored). By default, data is retained for any metric used in the security profile's behaviors, but it is also retained for any metric specified here.

*/ @property (nonatomic, strong) NSArray * _Nullable additionalMetricsToRetain; /**

A list of metrics whose data is retained (stored). By default, data is retained for any metric used in the profile's behaviors, but it is also retained for any metric specified here. Can be used with custom metrics; cannot be used with dimensions.

*/ @property (nonatomic, strong) NSArray * _Nullable additionalMetricsToRetainV2; /**

Where the alerts are sent. (Alerts are always sent to the console.)

*/ @property (nonatomic, strong) NSDictionary * _Nullable alertTargets; /**

Specifies the behaviors that, when violated by a device (thing), cause an alert.

*/ @property (nonatomic, strong) NSArray * _Nullable behaviors; /**

The time the security profile was created.

*/ @property (nonatomic, strong) NSDate * _Nullable creationDate; /**

The time the security profile was last modified.

*/ @property (nonatomic, strong) NSDate * _Nullable lastModifiedDate; /**

The ARN of the security profile that was updated.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileArn; /**

The description of the security profile.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileDescription; /**

The name of the security profile that was updated.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The updated version of the security profile.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /** */ @interface AWSIoTUpdateStreamRequest : AWSRequest /**

The description of the stream.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The files associated with the stream.

*/ @property (nonatomic, strong) NSArray * _Nullable files; /**

An IAM role that allows the IoT service principal assumes to access your S3 files.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; @end /** */ @interface AWSIoTUpdateStreamResponse : AWSModel /**

A description of the stream.

*/ @property (nonatomic, strong) NSString * _Nullable detail; /**

The stream ARN.

*/ @property (nonatomic, strong) NSString * _Nullable streamArn; /**

The stream ID.

*/ @property (nonatomic, strong) NSString * _Nullable streamId; /**

The stream version.

*/ @property (nonatomic, strong) NSNumber * _Nullable streamVersion; @end /** */ @interface AWSIoTUpdateThingGroupRequest : AWSRequest /**

The expected version of the thing group. If this does not match the version of the thing group being updated, the update will fail.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

The thing group to update.

*/ @property (nonatomic, strong) NSString * _Nullable thingGroupName; /**

The thing group properties.

*/ @property (nonatomic, strong) AWSIoTThingGroupProperties * _Nullable thingGroupProperties; @end /** */ @interface AWSIoTUpdateThingGroupResponse : AWSModel /**

The version of the updated thing group.

*/ @property (nonatomic, strong) NSNumber * _Nullable version; @end /** */ @interface AWSIoTUpdateThingGroupsForThingRequest : AWSRequest /**

Override dynamic thing groups with static thing groups when 10-group limit is reached. If a thing belongs to 10 thing groups, and one or more of those groups are dynamic thing groups, adding a thing to a static group removes the thing from the last dynamic group.

*/ @property (nonatomic, strong) NSNumber * _Nullable overrideDynamicGroups; /**

The groups to which the thing will be added.

*/ @property (nonatomic, strong) NSArray * _Nullable thingGroupsToAdd; /**

The groups from which the thing will be removed.

*/ @property (nonatomic, strong) NSArray * _Nullable thingGroupsToRemove; /**

The thing whose group memberships will be updated.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; @end /** */ @interface AWSIoTUpdateThingGroupsForThingResponse : AWSModel @end /**

The input for the UpdateThing operation.

Required parameters: [thingName] */ @interface AWSIoTUpdateThingRequest : AWSRequest /**

A list of thing attributes, a JSON string containing name-value pairs. For example:

{\"attributes\":{\"name1\":\"value2\"}}

This data is used to add new attributes or update existing attributes.

*/ @property (nonatomic, strong) AWSIoTAttributePayload * _Nullable attributePayload; /**

The expected version of the thing record in the registry. If the version of the record in the registry does not match the expected version specified in the request, the UpdateThing request is rejected with a VersionConflictException.

*/ @property (nonatomic, strong) NSNumber * _Nullable expectedVersion; /**

Remove a thing type association. If true, the association is removed.

*/ @property (nonatomic, strong) NSNumber * _Nullable removeThingType; /**

The name of the thing to update.

You can't change a thing's name. To change a thing's name, you must create a new thing, give it the new name, and then delete the old thing.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The name of the thing type.

*/ @property (nonatomic, strong) NSString * _Nullable thingTypeName; @end /**

The output from the UpdateThing operation.

*/ @interface AWSIoTUpdateThingResponse : AWSModel @end /** */ @interface AWSIoTUpdateTopicRuleDestinationRequest : AWSRequest /**

The ARN of the topic rule destination.

*/ @property (nonatomic, strong) NSString * _Nullable arn; /**

The status of the topic rule destination. Valid values are:

IN_PROGRESS

A topic rule destination was created but has not been confirmed. You can set status to IN_PROGRESS by calling UpdateTopicRuleDestination. Calling UpdateTopicRuleDestination causes a new confirmation challenge to be sent to your confirmation endpoint.

ENABLED

Confirmation was completed, and traffic to this destination is allowed. You can set status to DISABLED by calling UpdateTopicRuleDestination.

DISABLED

Confirmation was completed, and traffic to this destination is not allowed. You can set status to ENABLED by calling UpdateTopicRuleDestination.

ERROR

Confirmation could not be completed, for example if the confirmation timed out. You can call GetTopicRuleDestination for details about the error. You can set status to IN_PROGRESS by calling UpdateTopicRuleDestination. Calling UpdateTopicRuleDestination causes a new confirmation challenge to be sent to your confirmation endpoint.

*/ @property (nonatomic, assign) AWSIoTTopicRuleDestinationStatus status; @end /** */ @interface AWSIoTUpdateTopicRuleDestinationResponse : AWSModel @end /**

A key-value pair that you define in the header. Both the key and the value are either literal strings or valid substitution templates.

Required parameters: [key, value] */ @interface AWSIoTUserProperty : AWSModel /**

A key to be specified in UserProperty.

*/ @property (nonatomic, strong) NSString * _Nullable key; /**

A value to be specified in UserProperty.

*/ @property (nonatomic, strong) NSString * _Nullable value; @end /** */ @interface AWSIoTValidateSecurityProfileBehaviorsRequest : AWSRequest /**

Specifies the behaviors that, when violated by a device (thing), cause an alert.

*/ @property (nonatomic, strong) NSArray * _Nullable behaviors; @end /** */ @interface AWSIoTValidateSecurityProfileBehaviorsResponse : AWSModel /**

True if the behaviors were valid.

*/ @property (nonatomic, strong) NSNumber * _Nullable valid; /**

The list of any errors found in the behaviors.

*/ @property (nonatomic, strong) NSArray * _Nullable validationErrors; @end /**

Information about an error found in a behavior specification.

*/ @interface AWSIoTValidationError : AWSModel /**

The description of an error found in the behaviors.

*/ @property (nonatomic, strong) NSString * _Nullable errorMessage; @end /**

Configuration to manage IoT Job's package version reporting. If configured, Jobs updates the thing's reserved named shadow with the package version information up on successful job completion.

Note: For each job, the destinationPackageVersions attribute has to be set with the correct data for Jobs to report to the thing shadow.

*/ @interface AWSIoTVersionUpdateByJobsConfig : AWSModel /**

Indicates whether the Job is enabled or not.

*/ @property (nonatomic, strong) NSNumber * _Nullable enabled; /**

The Amazon Resource Name (ARN) of the role that grants permission to the IoT jobs service to update the reserved named shadow when the job successfully completes.

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; @end /**

Information about a Device Defender security profile behavior violation.

*/ @interface AWSIoTViolationEvent : AWSModel /**

The behavior that was violated.

*/ @property (nonatomic, strong) AWSIoTBehavior * _Nullable behavior; /**

The value of the metric (the measurement).

*/ @property (nonatomic, strong) AWSIoTMetricValue * _Nullable metricValue; /**

The name of the security profile whose behavior was violated.

*/ @property (nonatomic, strong) NSString * _Nullable securityProfileName; /**

The name of the thing responsible for the violation event.

*/ @property (nonatomic, strong) NSString * _Nullable thingName; /**

The verification state of the violation (detect alarm).

*/ @property (nonatomic, assign) AWSIoTVerificationState verificationState; /**

The description of the verification state of the violation.

*/ @property (nonatomic, strong) NSString * _Nullable verificationStateDescription; /**

The details of a violation event.

*/ @property (nonatomic, strong) AWSIoTViolationEventAdditionalInfo * _Nullable violationEventAdditionalInfo; /**

The time the violation event occurred.

*/ @property (nonatomic, strong) NSDate * _Nullable violationEventTime; /**

The type of violation event.

*/ @property (nonatomic, assign) AWSIoTViolationEventType violationEventType; /**

The ID of the violation event.

*/ @property (nonatomic, strong) NSString * _Nullable violationId; @end /**

The details of a violation event.

*/ @interface AWSIoTViolationEventAdditionalInfo : AWSModel /**

The sensitivity of anomalous behavior evaluation. Can be Low, Medium, or High.

*/ @property (nonatomic, assign) AWSIoTConfidenceLevel confidenceLevel; @end /**

Specifies the time period of which violation events occurred between.

Required parameters: [startTime, endTime] */ @interface AWSIoTViolationEventOccurrenceRange : AWSModel /**

The end date and time of a time period in which violation events occurred.

*/ @property (nonatomic, strong) NSDate * _Nullable endTime; /**

The start date and time of a time period in which violation events occurred.

*/ @property (nonatomic, strong) NSDate * _Nullable startTime; @end /**

The configuration information for a virtual private cloud (VPC) destination.

Required parameters: [subnetIds, vpcId, roleArn] */ @interface AWSIoTVpcDestinationConfiguration : AWSModel /**

The ARN of a role that has permission to create and attach to elastic network interfaces (ENIs).

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The security groups of the VPC destination.

*/ @property (nonatomic, strong) NSArray * _Nullable securityGroups; /**

The subnet IDs of the VPC destination.

*/ @property (nonatomic, strong) NSArray * _Nullable subnetIds; /**

The ID of the VPC.

*/ @property (nonatomic, strong) NSString * _Nullable vpcId; @end /**

The properties of a virtual private cloud (VPC) destination.

*/ @interface AWSIoTVpcDestinationProperties : AWSModel /**

The ARN of a role that has permission to create and attach to elastic network interfaces (ENIs).

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The security groups of the VPC destination.

*/ @property (nonatomic, strong) NSArray * _Nullable securityGroups; /**

The subnet IDs of the VPC destination.

*/ @property (nonatomic, strong) NSArray * _Nullable subnetIds; /**

The ID of the VPC.

*/ @property (nonatomic, strong) NSString * _Nullable vpcId; @end /**

The summary of a virtual private cloud (VPC) destination.

*/ @interface AWSIoTVpcDestinationSummary : AWSModel /**

The ARN of a role that has permission to create and attach to elastic network interfaces (ENIs).

*/ @property (nonatomic, strong) NSString * _Nullable roleArn; /**

The security groups of the VPC destination.

*/ @property (nonatomic, strong) NSArray * _Nullable securityGroups; /**

The subnet IDs of the VPC destination.

*/ @property (nonatomic, strong) NSArray * _Nullable subnetIds; /**

The ID of the VPC.

*/ @property (nonatomic, strong) NSString * _Nullable vpcId; @end NS_ASSUME_NONNULL_END