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

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

-- |
-- Module      : Amazonka.Transfer.Types.DescribedAgreement
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
module Amazonka.Transfer.Types.DescribedAgreement where

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 Amazonka.Transfer.Types.AgreementStatusType
import Amazonka.Transfer.Types.Tag

-- | Describes the properties of an agreement.
--
-- /See:/ 'newDescribedAgreement' smart constructor.
data DescribedAgreement = DescribedAgreement'
  { -- | With AS2, you can send files by calling @StartFileTransfer@ and
    -- specifying the file paths in the request parameter, @SendFilePaths@. We
    -- use the file’s parent directory (for example, for
    -- @--send-file-paths \/bucket\/dir\/file.txt@, parent directory is
    -- @\/bucket\/dir\/@) to temporarily store a processed AS2 message file,
    -- store the MDN when we receive them from the partner, and write a final
    -- JSON file containing relevant metadata of the transmission. So, the
    -- @AccessRole@ needs to provide read and write access to the parent
    -- directory of the file location used in the @StartFileTransfer@ request.
    -- Additionally, you need to provide read and write access to the parent
    -- directory of the files that you intend to send with @StartFileTransfer@.
    DescribedAgreement -> Maybe Text
accessRole :: Prelude.Maybe Prelude.Text,
    -- | A unique identifier for the agreement. This identifier is returned when
    -- you create an agreement.
    DescribedAgreement -> Maybe Text
agreementId :: Prelude.Maybe Prelude.Text,
    -- | The landing directory (folder) for files that are transferred by using
    -- the AS2 protocol.
    DescribedAgreement -> Maybe Text
baseDirectory :: Prelude.Maybe Prelude.Text,
    -- | The name or short description that\'s used to identify the agreement.
    DescribedAgreement -> Maybe Text
description :: Prelude.Maybe Prelude.Text,
    -- | A unique identifier for the AS2 local profile.
    DescribedAgreement -> Maybe Text
localProfileId :: Prelude.Maybe Prelude.Text,
    -- | A unique identifier for the partner profile used in the agreement.
    DescribedAgreement -> Maybe Text
partnerProfileId :: Prelude.Maybe Prelude.Text,
    -- | A system-assigned unique identifier for a server instance. This
    -- identifier indicates the specific server that the agreement uses.
    DescribedAgreement -> Maybe Text
serverId :: Prelude.Maybe Prelude.Text,
    -- | The current status of the agreement, either @ACTIVE@ or @INACTIVE@.
    DescribedAgreement -> Maybe AgreementStatusType
status :: Prelude.Maybe AgreementStatusType,
    -- | Key-value pairs that can be used to group and search for agreements.
    DescribedAgreement -> Maybe (NonEmpty Tag)
tags :: Prelude.Maybe (Prelude.NonEmpty Tag),
    -- | The unique Amazon Resource Name (ARN) for the agreement.
    DescribedAgreement -> Text
arn :: Prelude.Text
  }
  deriving (DescribedAgreement -> DescribedAgreement -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribedAgreement -> DescribedAgreement -> Bool
$c/= :: DescribedAgreement -> DescribedAgreement -> Bool
== :: DescribedAgreement -> DescribedAgreement -> Bool
$c== :: DescribedAgreement -> DescribedAgreement -> Bool
Prelude.Eq, ReadPrec [DescribedAgreement]
ReadPrec DescribedAgreement
Int -> ReadS DescribedAgreement
ReadS [DescribedAgreement]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribedAgreement]
$creadListPrec :: ReadPrec [DescribedAgreement]
readPrec :: ReadPrec DescribedAgreement
$creadPrec :: ReadPrec DescribedAgreement
readList :: ReadS [DescribedAgreement]
$creadList :: ReadS [DescribedAgreement]
readsPrec :: Int -> ReadS DescribedAgreement
$creadsPrec :: Int -> ReadS DescribedAgreement
Prelude.Read, Int -> DescribedAgreement -> ShowS
[DescribedAgreement] -> ShowS
DescribedAgreement -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribedAgreement] -> ShowS
$cshowList :: [DescribedAgreement] -> ShowS
show :: DescribedAgreement -> String
$cshow :: DescribedAgreement -> String
showsPrec :: Int -> DescribedAgreement -> ShowS
$cshowsPrec :: Int -> DescribedAgreement -> ShowS
Prelude.Show, forall x. Rep DescribedAgreement x -> DescribedAgreement
forall x. DescribedAgreement -> Rep DescribedAgreement x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribedAgreement x -> DescribedAgreement
$cfrom :: forall x. DescribedAgreement -> Rep DescribedAgreement x
Prelude.Generic)

-- |
-- Create a value of 'DescribedAgreement' 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:
--
-- 'accessRole', 'describedAgreement_accessRole' - With AS2, you can send files by calling @StartFileTransfer@ and
-- specifying the file paths in the request parameter, @SendFilePaths@. We
-- use the file’s parent directory (for example, for
-- @--send-file-paths \/bucket\/dir\/file.txt@, parent directory is
-- @\/bucket\/dir\/@) to temporarily store a processed AS2 message file,
-- store the MDN when we receive them from the partner, and write a final
-- JSON file containing relevant metadata of the transmission. So, the
-- @AccessRole@ needs to provide read and write access to the parent
-- directory of the file location used in the @StartFileTransfer@ request.
-- Additionally, you need to provide read and write access to the parent
-- directory of the files that you intend to send with @StartFileTransfer@.
--
-- 'agreementId', 'describedAgreement_agreementId' - A unique identifier for the agreement. This identifier is returned when
-- you create an agreement.
--
-- 'baseDirectory', 'describedAgreement_baseDirectory' - The landing directory (folder) for files that are transferred by using
-- the AS2 protocol.
--
-- 'description', 'describedAgreement_description' - The name or short description that\'s used to identify the agreement.
--
-- 'localProfileId', 'describedAgreement_localProfileId' - A unique identifier for the AS2 local profile.
--
-- 'partnerProfileId', 'describedAgreement_partnerProfileId' - A unique identifier for the partner profile used in the agreement.
--
-- 'serverId', 'describedAgreement_serverId' - A system-assigned unique identifier for a server instance. This
-- identifier indicates the specific server that the agreement uses.
--
-- 'status', 'describedAgreement_status' - The current status of the agreement, either @ACTIVE@ or @INACTIVE@.
--
-- 'tags', 'describedAgreement_tags' - Key-value pairs that can be used to group and search for agreements.
--
-- 'arn', 'describedAgreement_arn' - The unique Amazon Resource Name (ARN) for the agreement.
newDescribedAgreement ::
  -- | 'arn'
  Prelude.Text ->
  DescribedAgreement
newDescribedAgreement :: Text -> DescribedAgreement
newDescribedAgreement Text
pArn_ =
  DescribedAgreement'
    { $sel:accessRole:DescribedAgreement' :: Maybe Text
accessRole = forall a. Maybe a
Prelude.Nothing,
      $sel:agreementId:DescribedAgreement' :: Maybe Text
agreementId = forall a. Maybe a
Prelude.Nothing,
      $sel:baseDirectory:DescribedAgreement' :: Maybe Text
baseDirectory = forall a. Maybe a
Prelude.Nothing,
      $sel:description:DescribedAgreement' :: Maybe Text
description = forall a. Maybe a
Prelude.Nothing,
      $sel:localProfileId:DescribedAgreement' :: Maybe Text
localProfileId = forall a. Maybe a
Prelude.Nothing,
      $sel:partnerProfileId:DescribedAgreement' :: Maybe Text
partnerProfileId = forall a. Maybe a
Prelude.Nothing,
      $sel:serverId:DescribedAgreement' :: Maybe Text
serverId = forall a. Maybe a
Prelude.Nothing,
      $sel:status:DescribedAgreement' :: Maybe AgreementStatusType
status = forall a. Maybe a
Prelude.Nothing,
      $sel:tags:DescribedAgreement' :: Maybe (NonEmpty Tag)
tags = forall a. Maybe a
Prelude.Nothing,
      $sel:arn:DescribedAgreement' :: Text
arn = Text
pArn_
    }

-- | With AS2, you can send files by calling @StartFileTransfer@ and
-- specifying the file paths in the request parameter, @SendFilePaths@. We
-- use the file’s parent directory (for example, for
-- @--send-file-paths \/bucket\/dir\/file.txt@, parent directory is
-- @\/bucket\/dir\/@) to temporarily store a processed AS2 message file,
-- store the MDN when we receive them from the partner, and write a final
-- JSON file containing relevant metadata of the transmission. So, the
-- @AccessRole@ needs to provide read and write access to the parent
-- directory of the file location used in the @StartFileTransfer@ request.
-- Additionally, you need to provide read and write access to the parent
-- directory of the files that you intend to send with @StartFileTransfer@.
describedAgreement_accessRole :: Lens.Lens' DescribedAgreement (Prelude.Maybe Prelude.Text)
describedAgreement_accessRole :: Lens' DescribedAgreement (Maybe Text)
describedAgreement_accessRole = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe Text
accessRole :: Maybe Text
$sel:accessRole:DescribedAgreement' :: DescribedAgreement -> Maybe Text
accessRole} -> Maybe Text
accessRole) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe Text
a -> DescribedAgreement
s {$sel:accessRole:DescribedAgreement' :: Maybe Text
accessRole = Maybe Text
a} :: DescribedAgreement)

-- | A unique identifier for the agreement. This identifier is returned when
-- you create an agreement.
describedAgreement_agreementId :: Lens.Lens' DescribedAgreement (Prelude.Maybe Prelude.Text)
describedAgreement_agreementId :: Lens' DescribedAgreement (Maybe Text)
describedAgreement_agreementId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe Text
agreementId :: Maybe Text
$sel:agreementId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
agreementId} -> Maybe Text
agreementId) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe Text
a -> DescribedAgreement
s {$sel:agreementId:DescribedAgreement' :: Maybe Text
agreementId = Maybe Text
a} :: DescribedAgreement)

-- | The landing directory (folder) for files that are transferred by using
-- the AS2 protocol.
describedAgreement_baseDirectory :: Lens.Lens' DescribedAgreement (Prelude.Maybe Prelude.Text)
describedAgreement_baseDirectory :: Lens' DescribedAgreement (Maybe Text)
describedAgreement_baseDirectory = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe Text
baseDirectory :: Maybe Text
$sel:baseDirectory:DescribedAgreement' :: DescribedAgreement -> Maybe Text
baseDirectory} -> Maybe Text
baseDirectory) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe Text
a -> DescribedAgreement
s {$sel:baseDirectory:DescribedAgreement' :: Maybe Text
baseDirectory = Maybe Text
a} :: DescribedAgreement)

-- | The name or short description that\'s used to identify the agreement.
describedAgreement_description :: Lens.Lens' DescribedAgreement (Prelude.Maybe Prelude.Text)
describedAgreement_description :: Lens' DescribedAgreement (Maybe Text)
describedAgreement_description = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe Text
description :: Maybe Text
$sel:description:DescribedAgreement' :: DescribedAgreement -> Maybe Text
description} -> Maybe Text
description) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe Text
a -> DescribedAgreement
s {$sel:description:DescribedAgreement' :: Maybe Text
description = Maybe Text
a} :: DescribedAgreement)

-- | A unique identifier for the AS2 local profile.
describedAgreement_localProfileId :: Lens.Lens' DescribedAgreement (Prelude.Maybe Prelude.Text)
describedAgreement_localProfileId :: Lens' DescribedAgreement (Maybe Text)
describedAgreement_localProfileId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe Text
localProfileId :: Maybe Text
$sel:localProfileId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
localProfileId} -> Maybe Text
localProfileId) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe Text
a -> DescribedAgreement
s {$sel:localProfileId:DescribedAgreement' :: Maybe Text
localProfileId = Maybe Text
a} :: DescribedAgreement)

-- | A unique identifier for the partner profile used in the agreement.
describedAgreement_partnerProfileId :: Lens.Lens' DescribedAgreement (Prelude.Maybe Prelude.Text)
describedAgreement_partnerProfileId :: Lens' DescribedAgreement (Maybe Text)
describedAgreement_partnerProfileId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe Text
partnerProfileId :: Maybe Text
$sel:partnerProfileId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
partnerProfileId} -> Maybe Text
partnerProfileId) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe Text
a -> DescribedAgreement
s {$sel:partnerProfileId:DescribedAgreement' :: Maybe Text
partnerProfileId = Maybe Text
a} :: DescribedAgreement)

-- | A system-assigned unique identifier for a server instance. This
-- identifier indicates the specific server that the agreement uses.
describedAgreement_serverId :: Lens.Lens' DescribedAgreement (Prelude.Maybe Prelude.Text)
describedAgreement_serverId :: Lens' DescribedAgreement (Maybe Text)
describedAgreement_serverId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe Text
serverId :: Maybe Text
$sel:serverId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
serverId} -> Maybe Text
serverId) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe Text
a -> DescribedAgreement
s {$sel:serverId:DescribedAgreement' :: Maybe Text
serverId = Maybe Text
a} :: DescribedAgreement)

-- | The current status of the agreement, either @ACTIVE@ or @INACTIVE@.
describedAgreement_status :: Lens.Lens' DescribedAgreement (Prelude.Maybe AgreementStatusType)
describedAgreement_status :: Lens' DescribedAgreement (Maybe AgreementStatusType)
describedAgreement_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe AgreementStatusType
status :: Maybe AgreementStatusType
$sel:status:DescribedAgreement' :: DescribedAgreement -> Maybe AgreementStatusType
status} -> Maybe AgreementStatusType
status) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe AgreementStatusType
a -> DescribedAgreement
s {$sel:status:DescribedAgreement' :: Maybe AgreementStatusType
status = Maybe AgreementStatusType
a} :: DescribedAgreement)

-- | Key-value pairs that can be used to group and search for agreements.
describedAgreement_tags :: Lens.Lens' DescribedAgreement (Prelude.Maybe (Prelude.NonEmpty Tag))
describedAgreement_tags :: Lens' DescribedAgreement (Maybe (NonEmpty Tag))
describedAgreement_tags = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Maybe (NonEmpty Tag)
tags :: Maybe (NonEmpty Tag)
$sel:tags:DescribedAgreement' :: DescribedAgreement -> Maybe (NonEmpty Tag)
tags} -> Maybe (NonEmpty Tag)
tags) (\s :: DescribedAgreement
s@DescribedAgreement' {} Maybe (NonEmpty Tag)
a -> DescribedAgreement
s {$sel:tags:DescribedAgreement' :: Maybe (NonEmpty Tag)
tags = Maybe (NonEmpty Tag)
a} :: DescribedAgreement) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | The unique Amazon Resource Name (ARN) for the agreement.
describedAgreement_arn :: Lens.Lens' DescribedAgreement Prelude.Text
describedAgreement_arn :: Lens' DescribedAgreement Text
describedAgreement_arn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribedAgreement' {Text
arn :: Text
$sel:arn:DescribedAgreement' :: DescribedAgreement -> Text
arn} -> Text
arn) (\s :: DescribedAgreement
s@DescribedAgreement' {} Text
a -> DescribedAgreement
s {$sel:arn:DescribedAgreement' :: Text
arn = Text
a} :: DescribedAgreement)

instance Data.FromJSON DescribedAgreement where
  parseJSON :: Value -> Parser DescribedAgreement
parseJSON =
    forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
      String
"DescribedAgreement"
      ( \Object
x ->
          Maybe Text
-> Maybe Text
-> Maybe Text
-> Maybe Text
-> Maybe Text
-> Maybe Text
-> Maybe Text
-> Maybe AgreementStatusType
-> Maybe (NonEmpty Tag)
-> Text
-> DescribedAgreement
DescribedAgreement'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"AccessRole")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"AgreementId")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"BaseDirectory")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"Description")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"LocalProfileId")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"PartnerProfileId")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"ServerId")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"Status")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"Tags")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser a
Data..: Key
"Arn")
      )

instance Prelude.Hashable DescribedAgreement where
  hashWithSalt :: Int -> DescribedAgreement -> Int
hashWithSalt Int
_salt DescribedAgreement' {Maybe (NonEmpty Tag)
Maybe Text
Maybe AgreementStatusType
Text
arn :: Text
tags :: Maybe (NonEmpty Tag)
status :: Maybe AgreementStatusType
serverId :: Maybe Text
partnerProfileId :: Maybe Text
localProfileId :: Maybe Text
description :: Maybe Text
baseDirectory :: Maybe Text
agreementId :: Maybe Text
accessRole :: Maybe Text
$sel:arn:DescribedAgreement' :: DescribedAgreement -> Text
$sel:tags:DescribedAgreement' :: DescribedAgreement -> Maybe (NonEmpty Tag)
$sel:status:DescribedAgreement' :: DescribedAgreement -> Maybe AgreementStatusType
$sel:serverId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:partnerProfileId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:localProfileId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:description:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:baseDirectory:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:agreementId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:accessRole:DescribedAgreement' :: DescribedAgreement -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
accessRole
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
agreementId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
baseDirectory
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
description
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
localProfileId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
partnerProfileId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
serverId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe AgreementStatusType
status
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe (NonEmpty Tag)
tags
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
arn

instance Prelude.NFData DescribedAgreement where
  rnf :: DescribedAgreement -> ()
rnf DescribedAgreement' {Maybe (NonEmpty Tag)
Maybe Text
Maybe AgreementStatusType
Text
arn :: Text
tags :: Maybe (NonEmpty Tag)
status :: Maybe AgreementStatusType
serverId :: Maybe Text
partnerProfileId :: Maybe Text
localProfileId :: Maybe Text
description :: Maybe Text
baseDirectory :: Maybe Text
agreementId :: Maybe Text
accessRole :: Maybe Text
$sel:arn:DescribedAgreement' :: DescribedAgreement -> Text
$sel:tags:DescribedAgreement' :: DescribedAgreement -> Maybe (NonEmpty Tag)
$sel:status:DescribedAgreement' :: DescribedAgreement -> Maybe AgreementStatusType
$sel:serverId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:partnerProfileId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:localProfileId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:description:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:baseDirectory:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:agreementId:DescribedAgreement' :: DescribedAgreement -> Maybe Text
$sel:accessRole:DescribedAgreement' :: DescribedAgreement -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
accessRole
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
agreementId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
baseDirectory
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
description
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
localProfileId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
partnerProfileId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
serverId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe AgreementStatusType
status
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe (NonEmpty Tag)
tags
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
arn