{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveGeneric      #-}
{-# LANGUAGE OverloadedStrings  #-}
{-# LANGUAGE RecordWildCards    #-}
{-# LANGUAGE TypeFamilies       #-}

{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-binds   #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Network.AWS.IoTAnalytics.CreatePipeline
-- Copyright   : (c) 2013-2018 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay <brendan.g.hay+amazonka@gmail.com>
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Creates a pipeline. A pipeline consumes messages from one or more channels and allows you to process the messages before storing them in a data store.
--
--
module Network.AWS.IoTAnalytics.CreatePipeline
    (
    -- * Creating a Request
      createPipeline
    , CreatePipeline
    -- * Request Lenses
    , cpPipelineName
    , cpPipelineActivities

    -- * Destructuring the Response
    , createPipelineResponse
    , CreatePipelineResponse
    -- * Response Lenses
    , cprsPipelineName
    , cprsPipelineARN
    , cprsResponseStatus
    ) where

import Network.AWS.IoTAnalytics.Types
import Network.AWS.IoTAnalytics.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response

-- | /See:/ 'createPipeline' smart constructor.
data CreatePipeline = CreatePipeline'
  { _cpPipelineName       :: !Text
  , _cpPipelineActivities :: !(List1 PipelineActivity)
  } deriving (Eq, Read, Show, Data, Typeable, Generic)


-- | Creates a value of 'CreatePipeline' with the minimum fields required to make a request.
--
-- Use one of the following lenses to modify other fields as desired:
--
-- * 'cpPipelineName' - The name of the pipeline.
--
-- * 'cpPipelineActivities' - A list of pipeline activities. The list can be 1-25 __PipelineActivity__ objects. Activities perform transformations on your messages, such as removing, renaming, or adding message attributes; filtering messages based on attribute values; invoking your Lambda functions on messages for advanced processing; or performing mathematical transformations to normalize device data.
createPipeline
    :: Text -- ^ 'cpPipelineName'
    -> NonEmpty PipelineActivity -- ^ 'cpPipelineActivities'
    -> CreatePipeline
createPipeline pPipelineName_ pPipelineActivities_ =
  CreatePipeline'
    { _cpPipelineName = pPipelineName_
    , _cpPipelineActivities = _List1 # pPipelineActivities_
    }


-- | The name of the pipeline.
cpPipelineName :: Lens' CreatePipeline Text
cpPipelineName = lens _cpPipelineName (\ s a -> s{_cpPipelineName = a})

-- | A list of pipeline activities. The list can be 1-25 __PipelineActivity__ objects. Activities perform transformations on your messages, such as removing, renaming, or adding message attributes; filtering messages based on attribute values; invoking your Lambda functions on messages for advanced processing; or performing mathematical transformations to normalize device data.
cpPipelineActivities :: Lens' CreatePipeline (NonEmpty PipelineActivity)
cpPipelineActivities = lens _cpPipelineActivities (\ s a -> s{_cpPipelineActivities = a}) . _List1

instance AWSRequest CreatePipeline where
        type Rs CreatePipeline = CreatePipelineResponse
        request = postJSON ioTAnalytics
        response
          = receiveJSON
              (\ s h x ->
                 CreatePipelineResponse' <$>
                   (x .?> "pipelineName") <*> (x .?> "pipelineArn") <*>
                     (pure (fromEnum s)))

instance Hashable CreatePipeline where

instance NFData CreatePipeline where

instance ToHeaders CreatePipeline where
        toHeaders = const mempty

instance ToJSON CreatePipeline where
        toJSON CreatePipeline'{..}
          = object
              (catMaybes
                 [Just ("pipelineName" .= _cpPipelineName),
                  Just
                    ("pipelineActivities" .= _cpPipelineActivities)])

instance ToPath CreatePipeline where
        toPath = const "/pipelines"

instance ToQuery CreatePipeline where
        toQuery = const mempty

-- | /See:/ 'createPipelineResponse' smart constructor.
data CreatePipelineResponse = CreatePipelineResponse'
  { _cprsPipelineName   :: !(Maybe Text)
  , _cprsPipelineARN    :: !(Maybe Text)
  , _cprsResponseStatus :: !Int
  } deriving (Eq, Read, Show, Data, Typeable, Generic)


-- | Creates a value of 'CreatePipelineResponse' with the minimum fields required to make a request.
--
-- Use one of the following lenses to modify other fields as desired:
--
-- * 'cprsPipelineName' - The name of the pipeline.
--
-- * 'cprsPipelineARN' - The ARN of the pipeline.
--
-- * 'cprsResponseStatus' - -- | The response status code.
createPipelineResponse
    :: Int -- ^ 'cprsResponseStatus'
    -> CreatePipelineResponse
createPipelineResponse pResponseStatus_ =
  CreatePipelineResponse'
    { _cprsPipelineName = Nothing
    , _cprsPipelineARN = Nothing
    , _cprsResponseStatus = pResponseStatus_
    }


-- | The name of the pipeline.
cprsPipelineName :: Lens' CreatePipelineResponse (Maybe Text)
cprsPipelineName = lens _cprsPipelineName (\ s a -> s{_cprsPipelineName = a})

-- | The ARN of the pipeline.
cprsPipelineARN :: Lens' CreatePipelineResponse (Maybe Text)
cprsPipelineARN = lens _cprsPipelineARN (\ s a -> s{_cprsPipelineARN = a})

-- | -- | The response status code.
cprsResponseStatus :: Lens' CreatePipelineResponse Int
cprsResponseStatus = lens _cprsResponseStatus (\ s a -> s{_cprsResponseStatus = a})

instance NFData CreatePipelineResponse where