{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}

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

-- |
-- Module      : Amazonka.CodeCommit.PutRepositoryTriggers
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Replaces all triggers for a repository. Used to create or delete
-- triggers.
module Amazonka.CodeCommit.PutRepositoryTriggers
  ( -- * Creating a Request
    PutRepositoryTriggers (..),
    newPutRepositoryTriggers,

    -- * Request Lenses
    putRepositoryTriggers_repositoryName,
    putRepositoryTriggers_triggers,

    -- * Destructuring the Response
    PutRepositoryTriggersResponse (..),
    newPutRepositoryTriggersResponse,

    -- * Response Lenses
    putRepositoryTriggersResponse_configurationId,
    putRepositoryTriggersResponse_httpStatus,
  )
where

import Amazonka.CodeCommit.Types
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | Represents the input of a put repository triggers operation.
--
-- /See:/ 'newPutRepositoryTriggers' smart constructor.
data PutRepositoryTriggers = PutRepositoryTriggers'
  { -- | The name of the repository where you want to create or update the
    -- trigger.
    PutRepositoryTriggers -> Text
repositoryName :: Prelude.Text,
    -- | The JSON block of configuration information for each trigger.
    PutRepositoryTriggers -> [RepositoryTrigger]
triggers :: [RepositoryTrigger]
  }
  deriving (PutRepositoryTriggers -> PutRepositoryTriggers -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PutRepositoryTriggers -> PutRepositoryTriggers -> Bool
$c/= :: PutRepositoryTriggers -> PutRepositoryTriggers -> Bool
== :: PutRepositoryTriggers -> PutRepositoryTriggers -> Bool
$c== :: PutRepositoryTriggers -> PutRepositoryTriggers -> Bool
Prelude.Eq, ReadPrec [PutRepositoryTriggers]
ReadPrec PutRepositoryTriggers
Int -> ReadS PutRepositoryTriggers
ReadS [PutRepositoryTriggers]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [PutRepositoryTriggers]
$creadListPrec :: ReadPrec [PutRepositoryTriggers]
readPrec :: ReadPrec PutRepositoryTriggers
$creadPrec :: ReadPrec PutRepositoryTriggers
readList :: ReadS [PutRepositoryTriggers]
$creadList :: ReadS [PutRepositoryTriggers]
readsPrec :: Int -> ReadS PutRepositoryTriggers
$creadsPrec :: Int -> ReadS PutRepositoryTriggers
Prelude.Read, Int -> PutRepositoryTriggers -> ShowS
[PutRepositoryTriggers] -> ShowS
PutRepositoryTriggers -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PutRepositoryTriggers] -> ShowS
$cshowList :: [PutRepositoryTriggers] -> ShowS
show :: PutRepositoryTriggers -> String
$cshow :: PutRepositoryTriggers -> String
showsPrec :: Int -> PutRepositoryTriggers -> ShowS
$cshowsPrec :: Int -> PutRepositoryTriggers -> ShowS
Prelude.Show, forall x. Rep PutRepositoryTriggers x -> PutRepositoryTriggers
forall x. PutRepositoryTriggers -> Rep PutRepositoryTriggers x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep PutRepositoryTriggers x -> PutRepositoryTriggers
$cfrom :: forall x. PutRepositoryTriggers -> Rep PutRepositoryTriggers x
Prelude.Generic)

-- |
-- Create a value of 'PutRepositoryTriggers' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'repositoryName', 'putRepositoryTriggers_repositoryName' - The name of the repository where you want to create or update the
-- trigger.
--
-- 'triggers', 'putRepositoryTriggers_triggers' - The JSON block of configuration information for each trigger.
newPutRepositoryTriggers ::
  -- | 'repositoryName'
  Prelude.Text ->
  PutRepositoryTriggers
newPutRepositoryTriggers :: Text -> PutRepositoryTriggers
newPutRepositoryTriggers Text
pRepositoryName_ =
  PutRepositoryTriggers'
    { $sel:repositoryName:PutRepositoryTriggers' :: Text
repositoryName =
        Text
pRepositoryName_,
      $sel:triggers:PutRepositoryTriggers' :: [RepositoryTrigger]
triggers = forall a. Monoid a => a
Prelude.mempty
    }

-- | The name of the repository where you want to create or update the
-- trigger.
putRepositoryTriggers_repositoryName :: Lens.Lens' PutRepositoryTriggers Prelude.Text
putRepositoryTriggers_repositoryName :: Lens' PutRepositoryTriggers Text
putRepositoryTriggers_repositoryName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PutRepositoryTriggers' {Text
repositoryName :: Text
$sel:repositoryName:PutRepositoryTriggers' :: PutRepositoryTriggers -> Text
repositoryName} -> Text
repositoryName) (\s :: PutRepositoryTriggers
s@PutRepositoryTriggers' {} Text
a -> PutRepositoryTriggers
s {$sel:repositoryName:PutRepositoryTriggers' :: Text
repositoryName = Text
a} :: PutRepositoryTriggers)

-- | The JSON block of configuration information for each trigger.
putRepositoryTriggers_triggers :: Lens.Lens' PutRepositoryTriggers [RepositoryTrigger]
putRepositoryTriggers_triggers :: Lens' PutRepositoryTriggers [RepositoryTrigger]
putRepositoryTriggers_triggers = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PutRepositoryTriggers' {[RepositoryTrigger]
triggers :: [RepositoryTrigger]
$sel:triggers:PutRepositoryTriggers' :: PutRepositoryTriggers -> [RepositoryTrigger]
triggers} -> [RepositoryTrigger]
triggers) (\s :: PutRepositoryTriggers
s@PutRepositoryTriggers' {} [RepositoryTrigger]
a -> PutRepositoryTriggers
s {$sel:triggers:PutRepositoryTriggers' :: [RepositoryTrigger]
triggers = [RepositoryTrigger]
a} :: PutRepositoryTriggers) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance Core.AWSRequest PutRepositoryTriggers where
  type
    AWSResponse PutRepositoryTriggers =
      PutRepositoryTriggersResponse
  request :: (Service -> Service)
-> PutRepositoryTriggers -> Request PutRepositoryTriggers
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy PutRepositoryTriggers
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse PutRepositoryTriggers)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Maybe Text -> Int -> PutRepositoryTriggersResponse
PutRepositoryTriggersResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"configurationId")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance Prelude.Hashable PutRepositoryTriggers where
  hashWithSalt :: Int -> PutRepositoryTriggers -> Int
hashWithSalt Int
_salt PutRepositoryTriggers' {[RepositoryTrigger]
Text
triggers :: [RepositoryTrigger]
repositoryName :: Text
$sel:triggers:PutRepositoryTriggers' :: PutRepositoryTriggers -> [RepositoryTrigger]
$sel:repositoryName:PutRepositoryTriggers' :: PutRepositoryTriggers -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
repositoryName
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [RepositoryTrigger]
triggers

instance Prelude.NFData PutRepositoryTriggers where
  rnf :: PutRepositoryTriggers -> ()
rnf PutRepositoryTriggers' {[RepositoryTrigger]
Text
triggers :: [RepositoryTrigger]
repositoryName :: Text
$sel:triggers:PutRepositoryTriggers' :: PutRepositoryTriggers -> [RepositoryTrigger]
$sel:repositoryName:PutRepositoryTriggers' :: PutRepositoryTriggers -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
repositoryName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [RepositoryTrigger]
triggers

instance Data.ToHeaders PutRepositoryTriggers where
  toHeaders :: PutRepositoryTriggers -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"CodeCommit_20150413.PutRepositoryTriggers" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON PutRepositoryTriggers where
  toJSON :: PutRepositoryTriggers -> Value
toJSON PutRepositoryTriggers' {[RepositoryTrigger]
Text
triggers :: [RepositoryTrigger]
repositoryName :: Text
$sel:triggers:PutRepositoryTriggers' :: PutRepositoryTriggers -> [RepositoryTrigger]
$sel:repositoryName:PutRepositoryTriggers' :: PutRepositoryTriggers -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just
              (Key
"repositoryName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
repositoryName),
            forall a. a -> Maybe a
Prelude.Just (Key
"triggers" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= [RepositoryTrigger]
triggers)
          ]
      )

instance Data.ToPath PutRepositoryTriggers where
  toPath :: PutRepositoryTriggers -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery PutRepositoryTriggers where
  toQuery :: PutRepositoryTriggers -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | Represents the output of a put repository triggers operation.
--
-- /See:/ 'newPutRepositoryTriggersResponse' smart constructor.
data PutRepositoryTriggersResponse = PutRepositoryTriggersResponse'
  { -- | The system-generated unique ID for the create or update operation.
    PutRepositoryTriggersResponse -> Maybe Text
configurationId :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    PutRepositoryTriggersResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (PutRepositoryTriggersResponse
-> PutRepositoryTriggersResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PutRepositoryTriggersResponse
-> PutRepositoryTriggersResponse -> Bool
$c/= :: PutRepositoryTriggersResponse
-> PutRepositoryTriggersResponse -> Bool
== :: PutRepositoryTriggersResponse
-> PutRepositoryTriggersResponse -> Bool
$c== :: PutRepositoryTriggersResponse
-> PutRepositoryTriggersResponse -> Bool
Prelude.Eq, ReadPrec [PutRepositoryTriggersResponse]
ReadPrec PutRepositoryTriggersResponse
Int -> ReadS PutRepositoryTriggersResponse
ReadS [PutRepositoryTriggersResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [PutRepositoryTriggersResponse]
$creadListPrec :: ReadPrec [PutRepositoryTriggersResponse]
readPrec :: ReadPrec PutRepositoryTriggersResponse
$creadPrec :: ReadPrec PutRepositoryTriggersResponse
readList :: ReadS [PutRepositoryTriggersResponse]
$creadList :: ReadS [PutRepositoryTriggersResponse]
readsPrec :: Int -> ReadS PutRepositoryTriggersResponse
$creadsPrec :: Int -> ReadS PutRepositoryTriggersResponse
Prelude.Read, Int -> PutRepositoryTriggersResponse -> ShowS
[PutRepositoryTriggersResponse] -> ShowS
PutRepositoryTriggersResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PutRepositoryTriggersResponse] -> ShowS
$cshowList :: [PutRepositoryTriggersResponse] -> ShowS
show :: PutRepositoryTriggersResponse -> String
$cshow :: PutRepositoryTriggersResponse -> String
showsPrec :: Int -> PutRepositoryTriggersResponse -> ShowS
$cshowsPrec :: Int -> PutRepositoryTriggersResponse -> ShowS
Prelude.Show, forall x.
Rep PutRepositoryTriggersResponse x
-> PutRepositoryTriggersResponse
forall x.
PutRepositoryTriggersResponse
-> Rep PutRepositoryTriggersResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep PutRepositoryTriggersResponse x
-> PutRepositoryTriggersResponse
$cfrom :: forall x.
PutRepositoryTriggersResponse
-> Rep PutRepositoryTriggersResponse x
Prelude.Generic)

-- |
-- Create a value of 'PutRepositoryTriggersResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'configurationId', 'putRepositoryTriggersResponse_configurationId' - The system-generated unique ID for the create or update operation.
--
-- 'httpStatus', 'putRepositoryTriggersResponse_httpStatus' - The response's http status code.
newPutRepositoryTriggersResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  PutRepositoryTriggersResponse
newPutRepositoryTriggersResponse :: Int -> PutRepositoryTriggersResponse
newPutRepositoryTriggersResponse Int
pHttpStatus_ =
  PutRepositoryTriggersResponse'
    { $sel:configurationId:PutRepositoryTriggersResponse' :: Maybe Text
configurationId =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:PutRepositoryTriggersResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The system-generated unique ID for the create or update operation.
putRepositoryTriggersResponse_configurationId :: Lens.Lens' PutRepositoryTriggersResponse (Prelude.Maybe Prelude.Text)
putRepositoryTriggersResponse_configurationId :: Lens' PutRepositoryTriggersResponse (Maybe Text)
putRepositoryTriggersResponse_configurationId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PutRepositoryTriggersResponse' {Maybe Text
configurationId :: Maybe Text
$sel:configurationId:PutRepositoryTriggersResponse' :: PutRepositoryTriggersResponse -> Maybe Text
configurationId} -> Maybe Text
configurationId) (\s :: PutRepositoryTriggersResponse
s@PutRepositoryTriggersResponse' {} Maybe Text
a -> PutRepositoryTriggersResponse
s {$sel:configurationId:PutRepositoryTriggersResponse' :: Maybe Text
configurationId = Maybe Text
a} :: PutRepositoryTriggersResponse)

-- | The response's http status code.
putRepositoryTriggersResponse_httpStatus :: Lens.Lens' PutRepositoryTriggersResponse Prelude.Int
putRepositoryTriggersResponse_httpStatus :: Lens' PutRepositoryTriggersResponse Int
putRepositoryTriggersResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PutRepositoryTriggersResponse' {Int
httpStatus :: Int
$sel:httpStatus:PutRepositoryTriggersResponse' :: PutRepositoryTriggersResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: PutRepositoryTriggersResponse
s@PutRepositoryTriggersResponse' {} Int
a -> PutRepositoryTriggersResponse
s {$sel:httpStatus:PutRepositoryTriggersResponse' :: Int
httpStatus = Int
a} :: PutRepositoryTriggersResponse)

instance Prelude.NFData PutRepositoryTriggersResponse where
  rnf :: PutRepositoryTriggersResponse -> ()
rnf PutRepositoryTriggersResponse' {Int
Maybe Text
httpStatus :: Int
configurationId :: Maybe Text
$sel:httpStatus:PutRepositoryTriggersResponse' :: PutRepositoryTriggersResponse -> Int
$sel:configurationId:PutRepositoryTriggersResponse' :: PutRepositoryTriggersResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
configurationId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus