{-# LANGUAGE DeriveDataTypeable #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Network.AWS.CodeDeploy.Types.Product -- Copyright : (c) 2013-2016 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- module Network.AWS.CodeDeploy.Types.Product where import Network.AWS.CodeDeploy.Types.Sum import Network.AWS.Lens import Network.AWS.Prelude -- | Information about an application. -- -- /See:/ 'applicationInfo' smart constructor. data ApplicationInfo = ApplicationInfo' { _aiLinkedToGitHub :: !(Maybe Bool) , _aiApplicationId :: !(Maybe Text) , _aiApplicationName :: !(Maybe Text) , _aiCreateTime :: !(Maybe POSIX) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'ApplicationInfo' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'aiLinkedToGitHub' -- -- * 'aiApplicationId' -- -- * 'aiApplicationName' -- -- * 'aiCreateTime' applicationInfo :: ApplicationInfo applicationInfo = ApplicationInfo' { _aiLinkedToGitHub = Nothing , _aiApplicationId = Nothing , _aiApplicationName = Nothing , _aiCreateTime = Nothing } -- | True if the user has authenticated with GitHub for the specified application; otherwise, false. aiLinkedToGitHub :: Lens' ApplicationInfo (Maybe Bool) aiLinkedToGitHub = lens _aiLinkedToGitHub (\ s a -> s{_aiLinkedToGitHub = a}); -- | The application ID. aiApplicationId :: Lens' ApplicationInfo (Maybe Text) aiApplicationId = lens _aiApplicationId (\ s a -> s{_aiApplicationId = a}); -- | The application name. aiApplicationName :: Lens' ApplicationInfo (Maybe Text) aiApplicationName = lens _aiApplicationName (\ s a -> s{_aiApplicationName = a}); -- | The time at which the application was created. aiCreateTime :: Lens' ApplicationInfo (Maybe UTCTime) aiCreateTime = lens _aiCreateTime (\ s a -> s{_aiCreateTime = a}) . mapping _Time; instance FromJSON ApplicationInfo where parseJSON = withObject "ApplicationInfo" (\ x -> ApplicationInfo' <$> (x .:? "linkedToGitHub") <*> (x .:? "applicationId") <*> (x .:? "applicationName") <*> (x .:? "createTime")) instance Hashable ApplicationInfo instance NFData ApplicationInfo -- | Information about an Auto Scaling group. -- -- /See:/ 'autoScalingGroup' smart constructor. data AutoScalingGroup = AutoScalingGroup' { _asgHook :: !(Maybe Text) , _asgName :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'AutoScalingGroup' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'asgHook' -- -- * 'asgName' autoScalingGroup :: AutoScalingGroup autoScalingGroup = AutoScalingGroup' { _asgHook = Nothing , _asgName = Nothing } -- | An Auto Scaling lifecycle event hook name. asgHook :: Lens' AutoScalingGroup (Maybe Text) asgHook = lens _asgHook (\ s a -> s{_asgHook = a}); -- | The Auto Scaling group name. asgName :: Lens' AutoScalingGroup (Maybe Text) asgName = lens _asgName (\ s a -> s{_asgName = a}); instance FromJSON AutoScalingGroup where parseJSON = withObject "AutoScalingGroup" (\ x -> AutoScalingGroup' <$> (x .:? "hook") <*> (x .:? "name")) instance Hashable AutoScalingGroup instance NFData AutoScalingGroup -- | Information about a deployment configuration. -- -- /See:/ 'deploymentConfigInfo' smart constructor. data DeploymentConfigInfo = DeploymentConfigInfo' { _dciDeploymentConfigName :: !(Maybe Text) , _dciMinimumHealthyHosts :: !(Maybe MinimumHealthyHosts) , _dciDeploymentConfigId :: !(Maybe Text) , _dciCreateTime :: !(Maybe POSIX) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'DeploymentConfigInfo' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'dciDeploymentConfigName' -- -- * 'dciMinimumHealthyHosts' -- -- * 'dciDeploymentConfigId' -- -- * 'dciCreateTime' deploymentConfigInfo :: DeploymentConfigInfo deploymentConfigInfo = DeploymentConfigInfo' { _dciDeploymentConfigName = Nothing , _dciMinimumHealthyHosts = Nothing , _dciDeploymentConfigId = Nothing , _dciCreateTime = Nothing } -- | The deployment configuration name. dciDeploymentConfigName :: Lens' DeploymentConfigInfo (Maybe Text) dciDeploymentConfigName = lens _dciDeploymentConfigName (\ s a -> s{_dciDeploymentConfigName = a}); -- | Information about the number or percentage of minimum healthy instance. dciMinimumHealthyHosts :: Lens' DeploymentConfigInfo (Maybe MinimumHealthyHosts) dciMinimumHealthyHosts = lens _dciMinimumHealthyHosts (\ s a -> s{_dciMinimumHealthyHosts = a}); -- | The deployment configuration ID. dciDeploymentConfigId :: Lens' DeploymentConfigInfo (Maybe Text) dciDeploymentConfigId = lens _dciDeploymentConfigId (\ s a -> s{_dciDeploymentConfigId = a}); -- | The time at which the deployment configuration was created. dciCreateTime :: Lens' DeploymentConfigInfo (Maybe UTCTime) dciCreateTime = lens _dciCreateTime (\ s a -> s{_dciCreateTime = a}) . mapping _Time; instance FromJSON DeploymentConfigInfo where parseJSON = withObject "DeploymentConfigInfo" (\ x -> DeploymentConfigInfo' <$> (x .:? "deploymentConfigName") <*> (x .:? "minimumHealthyHosts") <*> (x .:? "deploymentConfigId") <*> (x .:? "createTime")) instance Hashable DeploymentConfigInfo instance NFData DeploymentConfigInfo -- | Information about a deployment group. -- -- /See:/ 'deploymentGroupInfo' smart constructor. data DeploymentGroupInfo = DeploymentGroupInfo' { _dgiServiceRoleARN :: !(Maybe Text) , _dgiDeploymentConfigName :: !(Maybe Text) , _dgiTargetRevision :: !(Maybe RevisionLocation) , _dgiEc2TagFilters :: !(Maybe [EC2TagFilter]) , _dgiOnPremisesInstanceTagFilters :: !(Maybe [TagFilter]) , _dgiApplicationName :: !(Maybe Text) , _dgiTriggerConfigurations :: !(Maybe [TriggerConfig]) , _dgiDeploymentGroupId :: !(Maybe Text) , _dgiAutoScalingGroups :: !(Maybe [AutoScalingGroup]) , _dgiDeploymentGroupName :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'DeploymentGroupInfo' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'dgiServiceRoleARN' -- -- * 'dgiDeploymentConfigName' -- -- * 'dgiTargetRevision' -- -- * 'dgiEc2TagFilters' -- -- * 'dgiOnPremisesInstanceTagFilters' -- -- * 'dgiApplicationName' -- -- * 'dgiTriggerConfigurations' -- -- * 'dgiDeploymentGroupId' -- -- * 'dgiAutoScalingGroups' -- -- * 'dgiDeploymentGroupName' deploymentGroupInfo :: DeploymentGroupInfo deploymentGroupInfo = DeploymentGroupInfo' { _dgiServiceRoleARN = Nothing , _dgiDeploymentConfigName = Nothing , _dgiTargetRevision = Nothing , _dgiEc2TagFilters = Nothing , _dgiOnPremisesInstanceTagFilters = Nothing , _dgiApplicationName = Nothing , _dgiTriggerConfigurations = Nothing , _dgiDeploymentGroupId = Nothing , _dgiAutoScalingGroups = Nothing , _dgiDeploymentGroupName = Nothing } -- | A service role ARN. dgiServiceRoleARN :: Lens' DeploymentGroupInfo (Maybe Text) dgiServiceRoleARN = lens _dgiServiceRoleARN (\ s a -> s{_dgiServiceRoleARN = a}); -- | The deployment configuration name. dgiDeploymentConfigName :: Lens' DeploymentGroupInfo (Maybe Text) dgiDeploymentConfigName = lens _dgiDeploymentConfigName (\ s a -> s{_dgiDeploymentConfigName = a}); -- | Information about the deployment group\'s target revision, including type and location. dgiTargetRevision :: Lens' DeploymentGroupInfo (Maybe RevisionLocation) dgiTargetRevision = lens _dgiTargetRevision (\ s a -> s{_dgiTargetRevision = a}); -- | The Amazon EC2 tags on which to filter. dgiEc2TagFilters :: Lens' DeploymentGroupInfo [EC2TagFilter] dgiEc2TagFilters = lens _dgiEc2TagFilters (\ s a -> s{_dgiEc2TagFilters = a}) . _Default . _Coerce; -- | The on-premises instance tags on which to filter. dgiOnPremisesInstanceTagFilters :: Lens' DeploymentGroupInfo [TagFilter] dgiOnPremisesInstanceTagFilters = lens _dgiOnPremisesInstanceTagFilters (\ s a -> s{_dgiOnPremisesInstanceTagFilters = a}) . _Default . _Coerce; -- | The application name. dgiApplicationName :: Lens' DeploymentGroupInfo (Maybe Text) dgiApplicationName = lens _dgiApplicationName (\ s a -> s{_dgiApplicationName = a}); -- | A list of associated triggers. dgiTriggerConfigurations :: Lens' DeploymentGroupInfo [TriggerConfig] dgiTriggerConfigurations = lens _dgiTriggerConfigurations (\ s a -> s{_dgiTriggerConfigurations = a}) . _Default . _Coerce; -- | The deployment group ID. dgiDeploymentGroupId :: Lens' DeploymentGroupInfo (Maybe Text) dgiDeploymentGroupId = lens _dgiDeploymentGroupId (\ s a -> s{_dgiDeploymentGroupId = a}); -- | A list of associated Auto Scaling groups. dgiAutoScalingGroups :: Lens' DeploymentGroupInfo [AutoScalingGroup] dgiAutoScalingGroups = lens _dgiAutoScalingGroups (\ s a -> s{_dgiAutoScalingGroups = a}) . _Default . _Coerce; -- | The deployment group name. dgiDeploymentGroupName :: Lens' DeploymentGroupInfo (Maybe Text) dgiDeploymentGroupName = lens _dgiDeploymentGroupName (\ s a -> s{_dgiDeploymentGroupName = a}); instance FromJSON DeploymentGroupInfo where parseJSON = withObject "DeploymentGroupInfo" (\ x -> DeploymentGroupInfo' <$> (x .:? "serviceRoleArn") <*> (x .:? "deploymentConfigName") <*> (x .:? "targetRevision") <*> (x .:? "ec2TagFilters" .!= mempty) <*> (x .:? "onPremisesInstanceTagFilters" .!= mempty) <*> (x .:? "applicationName") <*> (x .:? "triggerConfigurations" .!= mempty) <*> (x .:? "deploymentGroupId") <*> (x .:? "autoScalingGroups" .!= mempty) <*> (x .:? "deploymentGroupName")) instance Hashable DeploymentGroupInfo instance NFData DeploymentGroupInfo -- | Information about a deployment. -- -- /See:/ 'deploymentInfo' smart constructor. data DeploymentInfo = DeploymentInfo' { _diCreator :: !(Maybe DeploymentCreator) , _diStatus :: !(Maybe DeploymentStatus) , _diDeploymentId :: !(Maybe Text) , _diDeploymentConfigName :: !(Maybe Text) , _diStartTime :: !(Maybe POSIX) , _diCompleteTime :: !(Maybe POSIX) , _diErrorInformation :: !(Maybe ErrorInformation) , _diDeploymentOverview :: !(Maybe DeploymentOverview) , _diApplicationName :: !(Maybe Text) , _diRevision :: !(Maybe RevisionLocation) , _diDescription :: !(Maybe Text) , _diCreateTime :: !(Maybe POSIX) , _diDeploymentGroupName :: !(Maybe Text) , _diIgnoreApplicationStopFailures :: !(Maybe Bool) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'DeploymentInfo' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'diCreator' -- -- * 'diStatus' -- -- * 'diDeploymentId' -- -- * 'diDeploymentConfigName' -- -- * 'diStartTime' -- -- * 'diCompleteTime' -- -- * 'diErrorInformation' -- -- * 'diDeploymentOverview' -- -- * 'diApplicationName' -- -- * 'diRevision' -- -- * 'diDescription' -- -- * 'diCreateTime' -- -- * 'diDeploymentGroupName' -- -- * 'diIgnoreApplicationStopFailures' deploymentInfo :: DeploymentInfo deploymentInfo = DeploymentInfo' { _diCreator = Nothing , _diStatus = Nothing , _diDeploymentId = Nothing , _diDeploymentConfigName = Nothing , _diStartTime = Nothing , _diCompleteTime = Nothing , _diErrorInformation = Nothing , _diDeploymentOverview = Nothing , _diApplicationName = Nothing , _diRevision = Nothing , _diDescription = Nothing , _diCreateTime = Nothing , _diDeploymentGroupName = Nothing , _diIgnoreApplicationStopFailures = Nothing } -- | The means by which the deployment was created: -- -- - user: A user created the deployment. -- - autoscaling: Auto Scaling created the deployment. diCreator :: Lens' DeploymentInfo (Maybe DeploymentCreator) diCreator = lens _diCreator (\ s a -> s{_diCreator = a}); -- | The current state of the deployment as a whole. diStatus :: Lens' DeploymentInfo (Maybe DeploymentStatus) diStatus = lens _diStatus (\ s a -> s{_diStatus = a}); -- | The deployment ID. diDeploymentId :: Lens' DeploymentInfo (Maybe Text) diDeploymentId = lens _diDeploymentId (\ s a -> s{_diDeploymentId = a}); -- | The deployment configuration name. diDeploymentConfigName :: Lens' DeploymentInfo (Maybe Text) diDeploymentConfigName = lens _diDeploymentConfigName (\ s a -> s{_diDeploymentConfigName = a}); -- | A timestamp indicating when the deployment was deployed to the deployment group. -- -- In some cases, the reported value of the start time may be later than the complete time. This is due to differences in the clock settings of back-end servers that participate in the deployment process. diStartTime :: Lens' DeploymentInfo (Maybe UTCTime) diStartTime = lens _diStartTime (\ s a -> s{_diStartTime = a}) . mapping _Time; -- | A timestamp indicating when the deployment was complete. diCompleteTime :: Lens' DeploymentInfo (Maybe UTCTime) diCompleteTime = lens _diCompleteTime (\ s a -> s{_diCompleteTime = a}) . mapping _Time; -- | Information about any error associated with this deployment. diErrorInformation :: Lens' DeploymentInfo (Maybe ErrorInformation) diErrorInformation = lens _diErrorInformation (\ s a -> s{_diErrorInformation = a}); -- | A summary of the deployment status of the instances in the deployment. diDeploymentOverview :: Lens' DeploymentInfo (Maybe DeploymentOverview) diDeploymentOverview = lens _diDeploymentOverview (\ s a -> s{_diDeploymentOverview = a}); -- | The application name. diApplicationName :: Lens' DeploymentInfo (Maybe Text) diApplicationName = lens _diApplicationName (\ s a -> s{_diApplicationName = a}); -- | Information about the location of stored application artifacts and the service from which to retrieve them. diRevision :: Lens' DeploymentInfo (Maybe RevisionLocation) diRevision = lens _diRevision (\ s a -> s{_diRevision = a}); -- | A comment about the deployment. diDescription :: Lens' DeploymentInfo (Maybe Text) diDescription = lens _diDescription (\ s a -> s{_diDescription = a}); -- | A timestamp indicating when the deployment was created. diCreateTime :: Lens' DeploymentInfo (Maybe UTCTime) diCreateTime = lens _diCreateTime (\ s a -> s{_diCreateTime = a}) . mapping _Time; -- | The deployment group name. diDeploymentGroupName :: Lens' DeploymentInfo (Maybe Text) diDeploymentGroupName = lens _diDeploymentGroupName (\ s a -> s{_diDeploymentGroupName = a}); -- | If true, then if the deployment causes the ApplicationStop deployment lifecycle event to an instance to fail, the deployment to that instance will not be considered to have failed at that point and will continue on to the BeforeInstall deployment lifecycle event. -- -- If false or not specified, then if the deployment causes the ApplicationStop deployment lifecycle event to an instance to fail, the deployment to that instance will stop, and the deployment to that instance will be considered to have failed. diIgnoreApplicationStopFailures :: Lens' DeploymentInfo (Maybe Bool) diIgnoreApplicationStopFailures = lens _diIgnoreApplicationStopFailures (\ s a -> s{_diIgnoreApplicationStopFailures = a}); instance FromJSON DeploymentInfo where parseJSON = withObject "DeploymentInfo" (\ x -> DeploymentInfo' <$> (x .:? "creator") <*> (x .:? "status") <*> (x .:? "deploymentId") <*> (x .:? "deploymentConfigName") <*> (x .:? "startTime") <*> (x .:? "completeTime") <*> (x .:? "errorInformation") <*> (x .:? "deploymentOverview") <*> (x .:? "applicationName") <*> (x .:? "revision") <*> (x .:? "description") <*> (x .:? "createTime") <*> (x .:? "deploymentGroupName") <*> (x .:? "ignoreApplicationStopFailures")) instance Hashable DeploymentInfo instance NFData DeploymentInfo -- | Information about the deployment status of the instances in the deployment. -- -- /See:/ 'deploymentOverview' smart constructor. data DeploymentOverview = DeploymentOverview' { _doPending :: !(Maybe Integer) , _doSkipped :: !(Maybe Integer) , _doInProgress :: !(Maybe Integer) , _doSucceeded :: !(Maybe Integer) , _doFailed :: !(Maybe Integer) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'DeploymentOverview' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'doPending' -- -- * 'doSkipped' -- -- * 'doInProgress' -- -- * 'doSucceeded' -- -- * 'doFailed' deploymentOverview :: DeploymentOverview deploymentOverview = DeploymentOverview' { _doPending = Nothing , _doSkipped = Nothing , _doInProgress = Nothing , _doSucceeded = Nothing , _doFailed = Nothing } -- | The number of instances in the deployment in a pending state. doPending :: Lens' DeploymentOverview (Maybe Integer) doPending = lens _doPending (\ s a -> s{_doPending = a}); -- | The number of instances in the deployment in a skipped state. doSkipped :: Lens' DeploymentOverview (Maybe Integer) doSkipped = lens _doSkipped (\ s a -> s{_doSkipped = a}); -- | The number of instances in which the deployment is in progress. doInProgress :: Lens' DeploymentOverview (Maybe Integer) doInProgress = lens _doInProgress (\ s a -> s{_doInProgress = a}); -- | The number of instances in the deployment to which revisions have been successfully deployed. doSucceeded :: Lens' DeploymentOverview (Maybe Integer) doSucceeded = lens _doSucceeded (\ s a -> s{_doSucceeded = a}); -- | The number of instances in the deployment in a failed state. doFailed :: Lens' DeploymentOverview (Maybe Integer) doFailed = lens _doFailed (\ s a -> s{_doFailed = a}); instance FromJSON DeploymentOverview where parseJSON = withObject "DeploymentOverview" (\ x -> DeploymentOverview' <$> (x .:? "Pending") <*> (x .:? "Skipped") <*> (x .:? "InProgress") <*> (x .:? "Succeeded") <*> (x .:? "Failed")) instance Hashable DeploymentOverview instance NFData DeploymentOverview -- | Diagnostic information about executable scripts that are part of a deployment. -- -- /See:/ 'diagnostics' smart constructor. data Diagnostics = Diagnostics' { _dLogTail :: !(Maybe Text) , _dErrorCode :: !(Maybe LifecycleErrorCode) , _dScriptName :: !(Maybe Text) , _dMessage :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'Diagnostics' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'dLogTail' -- -- * 'dErrorCode' -- -- * 'dScriptName' -- -- * 'dMessage' diagnostics :: Diagnostics diagnostics = Diagnostics' { _dLogTail = Nothing , _dErrorCode = Nothing , _dScriptName = Nothing , _dMessage = Nothing } -- | The last portion of the diagnostic log. -- -- If available, AWS CodeDeploy returns up to the last 4 KB of the diagnostic log. dLogTail :: Lens' Diagnostics (Maybe Text) dLogTail = lens _dLogTail (\ s a -> s{_dLogTail = a}); -- | The associated error code: -- -- - Success: The specified script ran. -- - ScriptMissing: The specified script was not found in the specified location. -- - ScriptNotExecutable: The specified script is not a recognized executable file type. -- - ScriptTimedOut: The specified script did not finish running in the specified time period. -- - ScriptFailed: The specified script failed to run as expected. -- - UnknownError: The specified script did not run for an unknown reason. dErrorCode :: Lens' Diagnostics (Maybe LifecycleErrorCode) dErrorCode = lens _dErrorCode (\ s a -> s{_dErrorCode = a}); -- | The name of the script. dScriptName :: Lens' Diagnostics (Maybe Text) dScriptName = lens _dScriptName (\ s a -> s{_dScriptName = a}); -- | The message associated with the error. dMessage :: Lens' Diagnostics (Maybe Text) dMessage = lens _dMessage (\ s a -> s{_dMessage = a}); instance FromJSON Diagnostics where parseJSON = withObject "Diagnostics" (\ x -> Diagnostics' <$> (x .:? "logTail") <*> (x .:? "errorCode") <*> (x .:? "scriptName") <*> (x .:? "message")) instance Hashable Diagnostics instance NFData Diagnostics -- | Information about a tag filter. -- -- /See:/ 'ec2TagFilter' smart constructor. data EC2TagFilter = EC2TagFilter' { _etfValue :: !(Maybe Text) , _etfKey :: !(Maybe Text) , _etfType :: !(Maybe EC2TagFilterType) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'EC2TagFilter' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'etfValue' -- -- * 'etfKey' -- -- * 'etfType' ec2TagFilter :: EC2TagFilter ec2TagFilter = EC2TagFilter' { _etfValue = Nothing , _etfKey = Nothing , _etfType = Nothing } -- | The tag filter value. etfValue :: Lens' EC2TagFilter (Maybe Text) etfValue = lens _etfValue (\ s a -> s{_etfValue = a}); -- | The tag filter key. etfKey :: Lens' EC2TagFilter (Maybe Text) etfKey = lens _etfKey (\ s a -> s{_etfKey = a}); -- | The tag filter type: -- -- - KEY_ONLY: Key only. -- - VALUE_ONLY: Value only. -- - KEY_AND_VALUE: Key and value. etfType :: Lens' EC2TagFilter (Maybe EC2TagFilterType) etfType = lens _etfType (\ s a -> s{_etfType = a}); instance FromJSON EC2TagFilter where parseJSON = withObject "EC2TagFilter" (\ x -> EC2TagFilter' <$> (x .:? "Value") <*> (x .:? "Key") <*> (x .:? "Type")) instance Hashable EC2TagFilter instance NFData EC2TagFilter instance ToJSON EC2TagFilter where toJSON EC2TagFilter'{..} = object (catMaybes [("Value" .=) <$> _etfValue, ("Key" .=) <$> _etfKey, ("Type" .=) <$> _etfType]) -- | Information about a deployment error. -- -- /See:/ 'errorInformation' smart constructor. data ErrorInformation = ErrorInformation' { _eiCode :: !(Maybe DeployErrorCode) , _eiMessage :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'ErrorInformation' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'eiCode' -- -- * 'eiMessage' errorInformation :: ErrorInformation errorInformation = ErrorInformation' { _eiCode = Nothing , _eiMessage = Nothing } -- | The error code: -- -- - APPLICATION_MISSING: The application was missing. This error code will most likely be raised if the application is deleted after the deployment is created but before it is started. -- - DEPLOYMENT_GROUP_MISSING: The deployment group was missing. This error code will most likely be raised if the deployment group is deleted after the deployment is created but before it is started. -- - HEALTH_CONSTRAINTS: The deployment failed on too many instances to be successfully deployed within the instance health constraints specified. -- - HEALTH_CONSTRAINTS_INVALID: The revision cannot be successfully deployed within the instance health constraints specified. -- - IAM_ROLE_MISSING: The service role cannot be accessed. -- - IAM_ROLE_PERMISSIONS: The service role does not have the correct permissions. -- - INTERNAL_ERROR: There was an internal error. -- - NO_EC2_SUBSCRIPTION: The calling account is not subscribed to the Amazon EC2 service. -- - NO_INSTANCES: No instance were specified, or no instance can be found. -- - OVER_MAX_INSTANCES: The maximum number of instance was exceeded. -- - THROTTLED: The operation was throttled because the calling account exceeded the throttling limits of one or more AWS services. -- - TIMEOUT: The deployment has timed out. -- - REVISION_MISSING: The revision ID was missing. This error code will most likely be raised if the revision is deleted after the deployment is created but before it is started. eiCode :: Lens' ErrorInformation (Maybe DeployErrorCode) eiCode = lens _eiCode (\ s a -> s{_eiCode = a}); -- | An accompanying error message. eiMessage :: Lens' ErrorInformation (Maybe Text) eiMessage = lens _eiMessage (\ s a -> s{_eiMessage = a}); instance FromJSON ErrorInformation where parseJSON = withObject "ErrorInformation" (\ x -> ErrorInformation' <$> (x .:? "code") <*> (x .:? "message")) instance Hashable ErrorInformation instance NFData ErrorInformation -- | Information about an application revision. -- -- /See:/ 'genericRevisionInfo' smart constructor. data GenericRevisionInfo = GenericRevisionInfo' { _griRegisterTime :: !(Maybe POSIX) , _griFirstUsedTime :: !(Maybe POSIX) , _griDeploymentGroups :: !(Maybe [Text]) , _griLastUsedTime :: !(Maybe POSIX) , _griDescription :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'GenericRevisionInfo' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'griRegisterTime' -- -- * 'griFirstUsedTime' -- -- * 'griDeploymentGroups' -- -- * 'griLastUsedTime' -- -- * 'griDescription' genericRevisionInfo :: GenericRevisionInfo genericRevisionInfo = GenericRevisionInfo' { _griRegisterTime = Nothing , _griFirstUsedTime = Nothing , _griDeploymentGroups = Nothing , _griLastUsedTime = Nothing , _griDescription = Nothing } -- | When the revision was registered with AWS CodeDeploy. griRegisterTime :: Lens' GenericRevisionInfo (Maybe UTCTime) griRegisterTime = lens _griRegisterTime (\ s a -> s{_griRegisterTime = a}) . mapping _Time; -- | When the revision was first used by AWS CodeDeploy. griFirstUsedTime :: Lens' GenericRevisionInfo (Maybe UTCTime) griFirstUsedTime = lens _griFirstUsedTime (\ s a -> s{_griFirstUsedTime = a}) . mapping _Time; -- | The deployment groups for which this is the current target revision. griDeploymentGroups :: Lens' GenericRevisionInfo [Text] griDeploymentGroups = lens _griDeploymentGroups (\ s a -> s{_griDeploymentGroups = a}) . _Default . _Coerce; -- | When the revision was last used by AWS CodeDeploy. griLastUsedTime :: Lens' GenericRevisionInfo (Maybe UTCTime) griLastUsedTime = lens _griLastUsedTime (\ s a -> s{_griLastUsedTime = a}) . mapping _Time; -- | A comment about the revision. griDescription :: Lens' GenericRevisionInfo (Maybe Text) griDescription = lens _griDescription (\ s a -> s{_griDescription = a}); instance FromJSON GenericRevisionInfo where parseJSON = withObject "GenericRevisionInfo" (\ x -> GenericRevisionInfo' <$> (x .:? "registerTime") <*> (x .:? "firstUsedTime") <*> (x .:? "deploymentGroups" .!= mempty) <*> (x .:? "lastUsedTime") <*> (x .:? "description")) instance Hashable GenericRevisionInfo instance NFData GenericRevisionInfo -- | Information about the location of application artifacts stored in GitHub. -- -- /See:/ 'gitHubLocation' smart constructor. data GitHubLocation = GitHubLocation' { _ghlCommitId :: !(Maybe Text) , _ghlRepository :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'GitHubLocation' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'ghlCommitId' -- -- * 'ghlRepository' gitHubLocation :: GitHubLocation gitHubLocation = GitHubLocation' { _ghlCommitId = Nothing , _ghlRepository = Nothing } -- | The SHA1 commit ID of the GitHub commit that represents the bundled artifacts for the application revision. ghlCommitId :: Lens' GitHubLocation (Maybe Text) ghlCommitId = lens _ghlCommitId (\ s a -> s{_ghlCommitId = a}); -- | The GitHub account and repository pair that stores a reference to the commit that represents the bundled artifacts for the application revision. -- -- Specified as account\/repository. ghlRepository :: Lens' GitHubLocation (Maybe Text) ghlRepository = lens _ghlRepository (\ s a -> s{_ghlRepository = a}); instance FromJSON GitHubLocation where parseJSON = withObject "GitHubLocation" (\ x -> GitHubLocation' <$> (x .:? "commitId") <*> (x .:? "repository")) instance Hashable GitHubLocation instance NFData GitHubLocation instance ToJSON GitHubLocation where toJSON GitHubLocation'{..} = object (catMaybes [("commitId" .=) <$> _ghlCommitId, ("repository" .=) <$> _ghlRepository]) -- | Information about an on-premises instance. -- -- /See:/ 'instanceInfo' smart constructor. data InstanceInfo = InstanceInfo' { _iiRegisterTime :: !(Maybe POSIX) , _iiInstanceARN :: !(Maybe Text) , _iiDeregisterTime :: !(Maybe POSIX) , _iiIamUserARN :: !(Maybe Text) , _iiInstanceName :: !(Maybe Text) , _iiTags :: !(Maybe [Tag]) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'InstanceInfo' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'iiRegisterTime' -- -- * 'iiInstanceARN' -- -- * 'iiDeregisterTime' -- -- * 'iiIamUserARN' -- -- * 'iiInstanceName' -- -- * 'iiTags' instanceInfo :: InstanceInfo instanceInfo = InstanceInfo' { _iiRegisterTime = Nothing , _iiInstanceARN = Nothing , _iiDeregisterTime = Nothing , _iiIamUserARN = Nothing , _iiInstanceName = Nothing , _iiTags = Nothing } -- | The time at which the on-premises instance was registered. iiRegisterTime :: Lens' InstanceInfo (Maybe UTCTime) iiRegisterTime = lens _iiRegisterTime (\ s a -> s{_iiRegisterTime = a}) . mapping _Time; -- | The ARN of the on-premises instance. iiInstanceARN :: Lens' InstanceInfo (Maybe Text) iiInstanceARN = lens _iiInstanceARN (\ s a -> s{_iiInstanceARN = a}); -- | If the on-premises instance was deregistered, the time at which the on-premises instance was deregistered. iiDeregisterTime :: Lens' InstanceInfo (Maybe UTCTime) iiDeregisterTime = lens _iiDeregisterTime (\ s a -> s{_iiDeregisterTime = a}) . mapping _Time; -- | The IAM user ARN associated with the on-premises instance. iiIamUserARN :: Lens' InstanceInfo (Maybe Text) iiIamUserARN = lens _iiIamUserARN (\ s a -> s{_iiIamUserARN = a}); -- | The name of the on-premises instance. iiInstanceName :: Lens' InstanceInfo (Maybe Text) iiInstanceName = lens _iiInstanceName (\ s a -> s{_iiInstanceName = a}); -- | The tags currently associated with the on-premises instance. iiTags :: Lens' InstanceInfo [Tag] iiTags = lens _iiTags (\ s a -> s{_iiTags = a}) . _Default . _Coerce; instance FromJSON InstanceInfo where parseJSON = withObject "InstanceInfo" (\ x -> InstanceInfo' <$> (x .:? "registerTime") <*> (x .:? "instanceArn") <*> (x .:? "deregisterTime") <*> (x .:? "iamUserArn") <*> (x .:? "instanceName") <*> (x .:? "tags" .!= mempty)) instance Hashable InstanceInfo instance NFData InstanceInfo -- | Information about an instance in a deployment. -- -- /See:/ 'instanceSummary' smart constructor. data InstanceSummary = InstanceSummary' { _isInstanceId :: !(Maybe Text) , _isStatus :: !(Maybe InstanceStatus) , _isDeploymentId :: !(Maybe Text) , _isLastUpdatedAt :: !(Maybe POSIX) , _isLifecycleEvents :: !(Maybe [LifecycleEvent]) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'InstanceSummary' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'isInstanceId' -- -- * 'isStatus' -- -- * 'isDeploymentId' -- -- * 'isLastUpdatedAt' -- -- * 'isLifecycleEvents' instanceSummary :: InstanceSummary instanceSummary = InstanceSummary' { _isInstanceId = Nothing , _isStatus = Nothing , _isDeploymentId = Nothing , _isLastUpdatedAt = Nothing , _isLifecycleEvents = Nothing } -- | The instance ID. isInstanceId :: Lens' InstanceSummary (Maybe Text) isInstanceId = lens _isInstanceId (\ s a -> s{_isInstanceId = a}); -- | The deployment status for this instance: -- -- - Pending: The deployment is pending for this instance. -- - In Progress: The deployment is in progress for this instance. -- - Succeeded: The deployment has succeeded for this instance. -- - Failed: The deployment has failed for this instance. -- - Skipped: The deployment has been skipped for this instance. -- - Unknown: The deployment status is unknown for this instance. isStatus :: Lens' InstanceSummary (Maybe InstanceStatus) isStatus = lens _isStatus (\ s a -> s{_isStatus = a}); -- | The deployment ID. isDeploymentId :: Lens' InstanceSummary (Maybe Text) isDeploymentId = lens _isDeploymentId (\ s a -> s{_isDeploymentId = a}); -- | A timestamp indicating when the instance information was last updated. isLastUpdatedAt :: Lens' InstanceSummary (Maybe UTCTime) isLastUpdatedAt = lens _isLastUpdatedAt (\ s a -> s{_isLastUpdatedAt = a}) . mapping _Time; -- | A list of lifecycle events for this instance. isLifecycleEvents :: Lens' InstanceSummary [LifecycleEvent] isLifecycleEvents = lens _isLifecycleEvents (\ s a -> s{_isLifecycleEvents = a}) . _Default . _Coerce; instance FromJSON InstanceSummary where parseJSON = withObject "InstanceSummary" (\ x -> InstanceSummary' <$> (x .:? "instanceId") <*> (x .:? "status") <*> (x .:? "deploymentId") <*> (x .:? "lastUpdatedAt") <*> (x .:? "lifecycleEvents" .!= mempty)) instance Hashable InstanceSummary instance NFData InstanceSummary -- | Information about a deployment lifecycle event. -- -- /See:/ 'lifecycleEvent' smart constructor. data LifecycleEvent = LifecycleEvent' { _leStatus :: !(Maybe LifecycleEventStatus) , _leLifecycleEventName :: !(Maybe Text) , _leStartTime :: !(Maybe POSIX) , _leDiagnostics :: !(Maybe Diagnostics) , _leEndTime :: !(Maybe POSIX) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'LifecycleEvent' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'leStatus' -- -- * 'leLifecycleEventName' -- -- * 'leStartTime' -- -- * 'leDiagnostics' -- -- * 'leEndTime' lifecycleEvent :: LifecycleEvent lifecycleEvent = LifecycleEvent' { _leStatus = Nothing , _leLifecycleEventName = Nothing , _leStartTime = Nothing , _leDiagnostics = Nothing , _leEndTime = Nothing } -- | The deployment lifecycle event status: -- -- - Pending: The deployment lifecycle event is pending. -- - InProgress: The deployment lifecycle event is in progress. -- - Succeeded: The deployment lifecycle event ran successfully. -- - Failed: The deployment lifecycle event has failed. -- - Skipped: The deployment lifecycle event has been skipped. -- - Unknown: The deployment lifecycle event is unknown. leStatus :: Lens' LifecycleEvent (Maybe LifecycleEventStatus) leStatus = lens _leStatus (\ s a -> s{_leStatus = a}); -- | The deployment lifecycle event name, such as ApplicationStop, BeforeInstall, AfterInstall, ApplicationStart, or ValidateService. leLifecycleEventName :: Lens' LifecycleEvent (Maybe Text) leLifecycleEventName = lens _leLifecycleEventName (\ s a -> s{_leLifecycleEventName = a}); -- | A timestamp indicating when the deployment lifecycle event started. leStartTime :: Lens' LifecycleEvent (Maybe UTCTime) leStartTime = lens _leStartTime (\ s a -> s{_leStartTime = a}) . mapping _Time; -- | Diagnostic information about the deployment lifecycle event. leDiagnostics :: Lens' LifecycleEvent (Maybe Diagnostics) leDiagnostics = lens _leDiagnostics (\ s a -> s{_leDiagnostics = a}); -- | A timestamp indicating when the deployment lifecycle event ended. leEndTime :: Lens' LifecycleEvent (Maybe UTCTime) leEndTime = lens _leEndTime (\ s a -> s{_leEndTime = a}) . mapping _Time; instance FromJSON LifecycleEvent where parseJSON = withObject "LifecycleEvent" (\ x -> LifecycleEvent' <$> (x .:? "status") <*> (x .:? "lifecycleEventName") <*> (x .:? "startTime") <*> (x .:? "diagnostics") <*> (x .:? "endTime")) instance Hashable LifecycleEvent instance NFData LifecycleEvent -- | Information about minimum healthy instance. -- -- /See:/ 'minimumHealthyHosts' smart constructor. data MinimumHealthyHosts = MinimumHealthyHosts' { _mhhValue :: !(Maybe Int) , _mhhType :: !(Maybe MinimumHealthyHostsType) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'MinimumHealthyHosts' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'mhhValue' -- -- * 'mhhType' minimumHealthyHosts :: MinimumHealthyHosts minimumHealthyHosts = MinimumHealthyHosts' { _mhhValue = Nothing , _mhhType = Nothing } -- | The minimum healthy instance value. mhhValue :: Lens' MinimumHealthyHosts (Maybe Int) mhhValue = lens _mhhValue (\ s a -> s{_mhhValue = a}); -- | The minimum healthy instance type: -- -- - HOST_COUNT: The minimum number of healthy instance as an absolute value. -- - FLEET_PERCENT: The minimum number of healthy instance as a percentage of the total number of instance in the deployment. -- -- In an example of nine instance, if a HOST_COUNT of six is specified, deploy to up to three instances at a time. The deployment will be successful if six or more instances are deployed to successfully; otherwise, the deployment fails. If a FLEET_PERCENT of 40 is specified, deploy to up to five instance at a time. The deployment will be successful if four or more instance are deployed to successfully; otherwise, the deployment fails. -- -- In a call to the get deployment configuration operation, CodeDeployDefault.OneAtATime will return a minimum healthy instance type of MOST_CONCURRENCY and a value of 1. This means a deployment to only one instance at a time. (You cannot set the type to MOST_CONCURRENCY, only to HOST_COUNT or FLEET_PERCENT.) In addition, with CodeDeployDefault.OneAtATime, AWS CodeDeploy will try to ensure that all instances but one are kept in a healthy state during the deployment. Although this allows one instance at a time to be taken offline for a new deployment, it also means that if the deployment to the last instance fails, the overall deployment still succeeds. mhhType :: Lens' MinimumHealthyHosts (Maybe MinimumHealthyHostsType) mhhType = lens _mhhType (\ s a -> s{_mhhType = a}); instance FromJSON MinimumHealthyHosts where parseJSON = withObject "MinimumHealthyHosts" (\ x -> MinimumHealthyHosts' <$> (x .:? "value") <*> (x .:? "type")) instance Hashable MinimumHealthyHosts instance NFData MinimumHealthyHosts instance ToJSON MinimumHealthyHosts where toJSON MinimumHealthyHosts'{..} = object (catMaybes [("value" .=) <$> _mhhValue, ("type" .=) <$> _mhhType]) -- | Information about an application revision. -- -- /See:/ 'revisionInfo' smart constructor. data RevisionInfo = RevisionInfo' { _riGenericRevisionInfo :: !(Maybe GenericRevisionInfo) , _riRevisionLocation :: !(Maybe RevisionLocation) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'RevisionInfo' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'riGenericRevisionInfo' -- -- * 'riRevisionLocation' revisionInfo :: RevisionInfo revisionInfo = RevisionInfo' { _riGenericRevisionInfo = Nothing , _riRevisionLocation = Nothing } -- | Undocumented member. riGenericRevisionInfo :: Lens' RevisionInfo (Maybe GenericRevisionInfo) riGenericRevisionInfo = lens _riGenericRevisionInfo (\ s a -> s{_riGenericRevisionInfo = a}); -- | Undocumented member. riRevisionLocation :: Lens' RevisionInfo (Maybe RevisionLocation) riRevisionLocation = lens _riRevisionLocation (\ s a -> s{_riRevisionLocation = a}); instance FromJSON RevisionInfo where parseJSON = withObject "RevisionInfo" (\ x -> RevisionInfo' <$> (x .:? "genericRevisionInfo") <*> (x .:? "revisionLocation")) instance Hashable RevisionInfo instance NFData RevisionInfo -- | Information about the location of an application revision. -- -- /See:/ 'revisionLocation' smart constructor. data RevisionLocation = RevisionLocation' { _rlRevisionType :: !(Maybe RevisionLocationType) , _rlS3Location :: !(Maybe S3Location) , _rlGitHubLocation :: !(Maybe GitHubLocation) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'RevisionLocation' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'rlRevisionType' -- -- * 'rlS3Location' -- -- * 'rlGitHubLocation' revisionLocation :: RevisionLocation revisionLocation = RevisionLocation' { _rlRevisionType = Nothing , _rlS3Location = Nothing , _rlGitHubLocation = Nothing } -- | The type of application revision: -- -- - S3: An application revision stored in Amazon S3. -- - GitHub: An application revision stored in GitHub. rlRevisionType :: Lens' RevisionLocation (Maybe RevisionLocationType) rlRevisionType = lens _rlRevisionType (\ s a -> s{_rlRevisionType = a}); -- | Undocumented member. rlS3Location :: Lens' RevisionLocation (Maybe S3Location) rlS3Location = lens _rlS3Location (\ s a -> s{_rlS3Location = a}); -- | Undocumented member. rlGitHubLocation :: Lens' RevisionLocation (Maybe GitHubLocation) rlGitHubLocation = lens _rlGitHubLocation (\ s a -> s{_rlGitHubLocation = a}); instance FromJSON RevisionLocation where parseJSON = withObject "RevisionLocation" (\ x -> RevisionLocation' <$> (x .:? "revisionType") <*> (x .:? "s3Location") <*> (x .:? "gitHubLocation")) instance Hashable RevisionLocation instance NFData RevisionLocation instance ToJSON RevisionLocation where toJSON RevisionLocation'{..} = object (catMaybes [("revisionType" .=) <$> _rlRevisionType, ("s3Location" .=) <$> _rlS3Location, ("gitHubLocation" .=) <$> _rlGitHubLocation]) -- | Information about the location of application artifacts stored in Amazon S3. -- -- /See:/ 's3Location' smart constructor. data S3Location = S3Location' { _slBundleType :: !(Maybe BundleType) , _slETag :: !(Maybe Text) , _slBucket :: !(Maybe Text) , _slKey :: !(Maybe Text) , _slVersion :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'S3Location' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'slBundleType' -- -- * 'slETag' -- -- * 'slBucket' -- -- * 'slKey' -- -- * 'slVersion' s3Location :: S3Location s3Location = S3Location' { _slBundleType = Nothing , _slETag = Nothing , _slBucket = Nothing , _slKey = Nothing , _slVersion = Nothing } -- | The file type of the application revision. Must be one of the following: -- -- - tar: A tar archive file. -- - tgz: A compressed tar archive file. -- - zip: A zip archive file. slBundleType :: Lens' S3Location (Maybe BundleType) slBundleType = lens _slBundleType (\ s a -> s{_slBundleType = a}); -- | The ETag of the Amazon S3 object that represents the bundled artifacts for the application revision. -- -- If the ETag is not specified as an input parameter, ETag validation of the object will be skipped. slETag :: Lens' S3Location (Maybe Text) slETag = lens _slETag (\ s a -> s{_slETag = a}); -- | The name of the Amazon S3 bucket where the application revision is stored. slBucket :: Lens' S3Location (Maybe Text) slBucket = lens _slBucket (\ s a -> s{_slBucket = a}); -- | The name of the Amazon S3 object that represents the bundled artifacts for the application revision. slKey :: Lens' S3Location (Maybe Text) slKey = lens _slKey (\ s a -> s{_slKey = a}); -- | A specific version of the Amazon S3 object that represents the bundled artifacts for the application revision. -- -- If the version is not specified, the system will use the most recent version by default. slVersion :: Lens' S3Location (Maybe Text) slVersion = lens _slVersion (\ s a -> s{_slVersion = a}); instance FromJSON S3Location where parseJSON = withObject "S3Location" (\ x -> S3Location' <$> (x .:? "bundleType") <*> (x .:? "eTag") <*> (x .:? "bucket") <*> (x .:? "key") <*> (x .:? "version")) instance Hashable S3Location instance NFData S3Location instance ToJSON S3Location where toJSON S3Location'{..} = object (catMaybes [("bundleType" .=) <$> _slBundleType, ("eTag" .=) <$> _slETag, ("bucket" .=) <$> _slBucket, ("key" .=) <$> _slKey, ("version" .=) <$> _slVersion]) -- | Information about a tag. -- -- /See:/ 'tag' smart constructor. data Tag = Tag' { _tagValue :: !(Maybe Text) , _tagKey :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'Tag' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'tagValue' -- -- * 'tagKey' tag :: Tag tag = Tag' { _tagValue = Nothing , _tagKey = Nothing } -- | The tag\'s value. tagValue :: Lens' Tag (Maybe Text) tagValue = lens _tagValue (\ s a -> s{_tagValue = a}); -- | The tag\'s key. tagKey :: Lens' Tag (Maybe Text) tagKey = lens _tagKey (\ s a -> s{_tagKey = a}); instance FromJSON Tag where parseJSON = withObject "Tag" (\ x -> Tag' <$> (x .:? "Value") <*> (x .:? "Key")) instance Hashable Tag instance NFData Tag instance ToJSON Tag where toJSON Tag'{..} = object (catMaybes [("Value" .=) <$> _tagValue, ("Key" .=) <$> _tagKey]) -- | Information about an on-premises instance tag filter. -- -- /See:/ 'tagFilter' smart constructor. data TagFilter = TagFilter' { _tfValue :: !(Maybe Text) , _tfKey :: !(Maybe Text) , _tfType :: !(Maybe TagFilterType) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'TagFilter' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'tfValue' -- -- * 'tfKey' -- -- * 'tfType' tagFilter :: TagFilter tagFilter = TagFilter' { _tfValue = Nothing , _tfKey = Nothing , _tfType = Nothing } -- | The on-premises instance tag filter value. tfValue :: Lens' TagFilter (Maybe Text) tfValue = lens _tfValue (\ s a -> s{_tfValue = a}); -- | The on-premises instance tag filter key. tfKey :: Lens' TagFilter (Maybe Text) tfKey = lens _tfKey (\ s a -> s{_tfKey = a}); -- | The on-premises instance tag filter type: -- -- - KEY_ONLY: Key only. -- - VALUE_ONLY: Value only. -- - KEY_AND_VALUE: Key and value. tfType :: Lens' TagFilter (Maybe TagFilterType) tfType = lens _tfType (\ s a -> s{_tfType = a}); instance FromJSON TagFilter where parseJSON = withObject "TagFilter" (\ x -> TagFilter' <$> (x .:? "Value") <*> (x .:? "Key") <*> (x .:? "Type")) instance Hashable TagFilter instance NFData TagFilter instance ToJSON TagFilter where toJSON TagFilter'{..} = object (catMaybes [("Value" .=) <$> _tfValue, ("Key" .=) <$> _tfKey, ("Type" .=) <$> _tfType]) -- | Information about a time range. -- -- /See:/ 'timeRange' smart constructor. data TimeRange = TimeRange' { _trStart :: !(Maybe POSIX) , _trEnd :: !(Maybe POSIX) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'TimeRange' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'trStart' -- -- * 'trEnd' timeRange :: TimeRange timeRange = TimeRange' { _trStart = Nothing , _trEnd = Nothing } -- | The start time of the time range. -- -- Specify null to leave the start time open-ended. trStart :: Lens' TimeRange (Maybe UTCTime) trStart = lens _trStart (\ s a -> s{_trStart = a}) . mapping _Time; -- | The end time of the time range. -- -- Specify null to leave the end time open-ended. trEnd :: Lens' TimeRange (Maybe UTCTime) trEnd = lens _trEnd (\ s a -> s{_trEnd = a}) . mapping _Time; instance Hashable TimeRange instance NFData TimeRange instance ToJSON TimeRange where toJSON TimeRange'{..} = object (catMaybes [("start" .=) <$> _trStart, ("end" .=) <$> _trEnd]) -- | Information about notification triggers for the deployment group. -- -- /See:/ 'triggerConfig' smart constructor. data TriggerConfig = TriggerConfig' { _tcTriggerName :: !(Maybe Text) , _tcTriggerEvents :: !(Maybe [TriggerEventType]) , _tcTriggerTargetARN :: !(Maybe Text) } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'TriggerConfig' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'tcTriggerName' -- -- * 'tcTriggerEvents' -- -- * 'tcTriggerTargetARN' triggerConfig :: TriggerConfig triggerConfig = TriggerConfig' { _tcTriggerName = Nothing , _tcTriggerEvents = Nothing , _tcTriggerTargetARN = Nothing } -- | The name of the notification trigger. tcTriggerName :: Lens' TriggerConfig (Maybe Text) tcTriggerName = lens _tcTriggerName (\ s a -> s{_tcTriggerName = a}); -- | The event type or types for which notifications are triggered. -- -- The following event type values are supported: -- -- - DEPLOYMENT_START -- - DEPLOYMENT_SUCCESS -- - DEPLOYMENT_FAILURE -- - DEPLOYMENT_STOP -- - INSTANCE_START -- - INSTANCE_SUCCESS -- - INSTANCE_FAILURE tcTriggerEvents :: Lens' TriggerConfig [TriggerEventType] tcTriggerEvents = lens _tcTriggerEvents (\ s a -> s{_tcTriggerEvents = a}) . _Default . _Coerce; -- | The ARN of the Amazon Simple Notification Service topic through which notifications about deployment or instance events are sent. tcTriggerTargetARN :: Lens' TriggerConfig (Maybe Text) tcTriggerTargetARN = lens _tcTriggerTargetARN (\ s a -> s{_tcTriggerTargetARN = a}); instance FromJSON TriggerConfig where parseJSON = withObject "TriggerConfig" (\ x -> TriggerConfig' <$> (x .:? "triggerName") <*> (x .:? "triggerEvents" .!= mempty) <*> (x .:? "triggerTargetArn")) instance Hashable TriggerConfig instance NFData TriggerConfig instance ToJSON TriggerConfig where toJSON TriggerConfig'{..} = object (catMaybes [("triggerName" .=) <$> _tcTriggerName, ("triggerEvents" .=) <$> _tcTriggerEvents, ("triggerTargetArn" .=) <$> _tcTriggerTargetARN])