{-# LANGUAGE DataKinds #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE FlexibleInstances #-} {-# LANGUAGE GeneralizedNewtypeDeriving #-} {-# LANGUAGE LambdaCase #-} {-# LANGUAGE NoImplicitPrelude #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE TypeFamilies #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} -- Module : Network.AWS.OpsWorks.DescribeServiceErrors -- Copyright : (c) 2013-2014 Brendan Hay -- License : This Source Code Form is subject to the terms of -- the Mozilla Public License, v. 2.0. -- A copy of the MPL can be found in the LICENSE file or -- you can obtain it at http://mozilla.org/MPL/2.0/. -- Maintainer : Brendan Hay -- Stability : experimental -- Portability : non-portable (GHC extensions) -- -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | Describes AWS OpsWorks service errors. -- -- Required Permissions: To use this action, an IAM user must have a Show, -- Deploy, or Manage permissions level for the stack, or an attached policy that -- explicitly grants permissions. For more information on user permissions, see . -- -- module Network.AWS.OpsWorks.DescribeServiceErrors ( -- * Request DescribeServiceErrors -- ** Request constructor , describeServiceErrors -- ** Request lenses , dseInstanceId , dseServiceErrorIds , dseStackId -- * Response , DescribeServiceErrorsResponse -- ** Response constructor , describeServiceErrorsResponse -- ** Response lenses , dserServiceErrors ) where import Network.AWS.Prelude import Network.AWS.Request.JSON import Network.AWS.OpsWorks.Types import qualified GHC.Exts data DescribeServiceErrors = DescribeServiceErrors { _dseInstanceId :: Maybe Text , _dseServiceErrorIds :: List "ServiceErrorIds" Text , _dseStackId :: Maybe Text } deriving (Eq, Ord, Read, Show) -- | 'DescribeServiceErrors' constructor. -- -- The fields accessible through corresponding lenses are: -- -- * 'dseInstanceId' @::@ 'Maybe' 'Text' -- -- * 'dseServiceErrorIds' @::@ ['Text'] -- -- * 'dseStackId' @::@ 'Maybe' 'Text' -- describeServiceErrors :: DescribeServiceErrors describeServiceErrors = DescribeServiceErrors { _dseStackId = Nothing , _dseInstanceId = Nothing , _dseServiceErrorIds = mempty } -- | The instance ID. If you use this parameter, 'DescribeServiceErrors' returns -- descriptions of the errors associated with the specified instance. dseInstanceId :: Lens' DescribeServiceErrors (Maybe Text) dseInstanceId = lens _dseInstanceId (\s a -> s { _dseInstanceId = a }) -- | An array of service error IDs. If you use this parameter, 'DescribeServiceErrors' returns descriptions of the specified errors. Otherwise, it returns a -- description of every error. dseServiceErrorIds :: Lens' DescribeServiceErrors [Text] dseServiceErrorIds = lens _dseServiceErrorIds (\s a -> s { _dseServiceErrorIds = a }) . _List -- | The stack ID. If you use this parameter, 'DescribeServiceErrors' returns -- descriptions of the errors associated with the specified stack. dseStackId :: Lens' DescribeServiceErrors (Maybe Text) dseStackId = lens _dseStackId (\s a -> s { _dseStackId = a }) newtype DescribeServiceErrorsResponse = DescribeServiceErrorsResponse { _dserServiceErrors :: List "ServiceErrors" ServiceError' } deriving (Eq, Read, Show, Monoid, Semigroup) instance GHC.Exts.IsList DescribeServiceErrorsResponse where type Item DescribeServiceErrorsResponse = ServiceError' fromList = DescribeServiceErrorsResponse . GHC.Exts.fromList toList = GHC.Exts.toList . _dserServiceErrors -- | 'DescribeServiceErrorsResponse' constructor. -- -- The fields accessible through corresponding lenses are: -- -- * 'dserServiceErrors' @::@ ['ServiceError''] -- describeServiceErrorsResponse :: DescribeServiceErrorsResponse describeServiceErrorsResponse = DescribeServiceErrorsResponse { _dserServiceErrors = mempty } -- | An array of 'ServiceError' objects that describe the specified service errors. dserServiceErrors :: Lens' DescribeServiceErrorsResponse [ServiceError'] dserServiceErrors = lens _dserServiceErrors (\s a -> s { _dserServiceErrors = a }) . _List instance ToPath DescribeServiceErrors where toPath = const "/" instance ToQuery DescribeServiceErrors where toQuery = const mempty instance ToHeaders DescribeServiceErrors instance ToJSON DescribeServiceErrors where toJSON DescribeServiceErrors{..} = object [ "StackId" .= _dseStackId , "InstanceId" .= _dseInstanceId , "ServiceErrorIds" .= _dseServiceErrorIds ] instance AWSRequest DescribeServiceErrors where type Sv DescribeServiceErrors = OpsWorks type Rs DescribeServiceErrors = DescribeServiceErrorsResponse request = post "DescribeServiceErrors" response = jsonResponse instance FromJSON DescribeServiceErrorsResponse where parseJSON = withObject "DescribeServiceErrorsResponse" $ \o -> DescribeServiceErrorsResponse <$> o .:? "ServiceErrors" .!= mempty