{-# 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.FMS.Types.NetworkFirewallPolicyModifiedViolation
-- 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.FMS.Types.NetworkFirewallPolicyModifiedViolation where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.FMS.Types.NetworkFirewallPolicyDescription
import qualified Amazonka.Prelude as Prelude

-- | Violation detail for Network Firewall for a firewall policy that has a
-- different NetworkFirewallPolicyDescription than is required by the
-- Firewall Manager policy.
--
-- /See:/ 'newNetworkFirewallPolicyModifiedViolation' smart constructor.
data NetworkFirewallPolicyModifiedViolation = NetworkFirewallPolicyModifiedViolation'
  { -- | The policy that\'s currently in use in the individual account.
    NetworkFirewallPolicyModifiedViolation
-> Maybe NetworkFirewallPolicyDescription
currentPolicyDescription :: Prelude.Maybe NetworkFirewallPolicyDescription,
    -- | The policy that should be in use in the individual account in order to
    -- be compliant.
    NetworkFirewallPolicyModifiedViolation
-> Maybe NetworkFirewallPolicyDescription
expectedPolicyDescription :: Prelude.Maybe NetworkFirewallPolicyDescription,
    -- | The ID of the Network Firewall or VPC resource that\'s in violation.
    NetworkFirewallPolicyModifiedViolation -> Maybe Text
violationTarget :: Prelude.Maybe Prelude.Text
  }
  deriving (NetworkFirewallPolicyModifiedViolation
-> NetworkFirewallPolicyModifiedViolation -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: NetworkFirewallPolicyModifiedViolation
-> NetworkFirewallPolicyModifiedViolation -> Bool
$c/= :: NetworkFirewallPolicyModifiedViolation
-> NetworkFirewallPolicyModifiedViolation -> Bool
== :: NetworkFirewallPolicyModifiedViolation
-> NetworkFirewallPolicyModifiedViolation -> Bool
$c== :: NetworkFirewallPolicyModifiedViolation
-> NetworkFirewallPolicyModifiedViolation -> Bool
Prelude.Eq, ReadPrec [NetworkFirewallPolicyModifiedViolation]
ReadPrec NetworkFirewallPolicyModifiedViolation
Int -> ReadS NetworkFirewallPolicyModifiedViolation
ReadS [NetworkFirewallPolicyModifiedViolation]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [NetworkFirewallPolicyModifiedViolation]
$creadListPrec :: ReadPrec [NetworkFirewallPolicyModifiedViolation]
readPrec :: ReadPrec NetworkFirewallPolicyModifiedViolation
$creadPrec :: ReadPrec NetworkFirewallPolicyModifiedViolation
readList :: ReadS [NetworkFirewallPolicyModifiedViolation]
$creadList :: ReadS [NetworkFirewallPolicyModifiedViolation]
readsPrec :: Int -> ReadS NetworkFirewallPolicyModifiedViolation
$creadsPrec :: Int -> ReadS NetworkFirewallPolicyModifiedViolation
Prelude.Read, Int -> NetworkFirewallPolicyModifiedViolation -> ShowS
[NetworkFirewallPolicyModifiedViolation] -> ShowS
NetworkFirewallPolicyModifiedViolation -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [NetworkFirewallPolicyModifiedViolation] -> ShowS
$cshowList :: [NetworkFirewallPolicyModifiedViolation] -> ShowS
show :: NetworkFirewallPolicyModifiedViolation -> String
$cshow :: NetworkFirewallPolicyModifiedViolation -> String
showsPrec :: Int -> NetworkFirewallPolicyModifiedViolation -> ShowS
$cshowsPrec :: Int -> NetworkFirewallPolicyModifiedViolation -> ShowS
Prelude.Show, forall x.
Rep NetworkFirewallPolicyModifiedViolation x
-> NetworkFirewallPolicyModifiedViolation
forall x.
NetworkFirewallPolicyModifiedViolation
-> Rep NetworkFirewallPolicyModifiedViolation x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep NetworkFirewallPolicyModifiedViolation x
-> NetworkFirewallPolicyModifiedViolation
$cfrom :: forall x.
NetworkFirewallPolicyModifiedViolation
-> Rep NetworkFirewallPolicyModifiedViolation x
Prelude.Generic)

-- |
-- Create a value of 'NetworkFirewallPolicyModifiedViolation' 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:
--
-- 'currentPolicyDescription', 'networkFirewallPolicyModifiedViolation_currentPolicyDescription' - The policy that\'s currently in use in the individual account.
--
-- 'expectedPolicyDescription', 'networkFirewallPolicyModifiedViolation_expectedPolicyDescription' - The policy that should be in use in the individual account in order to
-- be compliant.
--
-- 'violationTarget', 'networkFirewallPolicyModifiedViolation_violationTarget' - The ID of the Network Firewall or VPC resource that\'s in violation.
newNetworkFirewallPolicyModifiedViolation ::
  NetworkFirewallPolicyModifiedViolation
newNetworkFirewallPolicyModifiedViolation :: NetworkFirewallPolicyModifiedViolation
newNetworkFirewallPolicyModifiedViolation =
  NetworkFirewallPolicyModifiedViolation'
    { $sel:currentPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: Maybe NetworkFirewallPolicyDescription
currentPolicyDescription =
        forall a. Maybe a
Prelude.Nothing,
      $sel:expectedPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: Maybe NetworkFirewallPolicyDescription
expectedPolicyDescription =
        forall a. Maybe a
Prelude.Nothing,
      $sel:violationTarget:NetworkFirewallPolicyModifiedViolation' :: Maybe Text
violationTarget = forall a. Maybe a
Prelude.Nothing
    }

-- | The policy that\'s currently in use in the individual account.
networkFirewallPolicyModifiedViolation_currentPolicyDescription :: Lens.Lens' NetworkFirewallPolicyModifiedViolation (Prelude.Maybe NetworkFirewallPolicyDescription)
networkFirewallPolicyModifiedViolation_currentPolicyDescription :: Lens'
  NetworkFirewallPolicyModifiedViolation
  (Maybe NetworkFirewallPolicyDescription)
networkFirewallPolicyModifiedViolation_currentPolicyDescription = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\NetworkFirewallPolicyModifiedViolation' {Maybe NetworkFirewallPolicyDescription
currentPolicyDescription :: Maybe NetworkFirewallPolicyDescription
$sel:currentPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation
-> Maybe NetworkFirewallPolicyDescription
currentPolicyDescription} -> Maybe NetworkFirewallPolicyDescription
currentPolicyDescription) (\s :: NetworkFirewallPolicyModifiedViolation
s@NetworkFirewallPolicyModifiedViolation' {} Maybe NetworkFirewallPolicyDescription
a -> NetworkFirewallPolicyModifiedViolation
s {$sel:currentPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: Maybe NetworkFirewallPolicyDescription
currentPolicyDescription = Maybe NetworkFirewallPolicyDescription
a} :: NetworkFirewallPolicyModifiedViolation)

-- | The policy that should be in use in the individual account in order to
-- be compliant.
networkFirewallPolicyModifiedViolation_expectedPolicyDescription :: Lens.Lens' NetworkFirewallPolicyModifiedViolation (Prelude.Maybe NetworkFirewallPolicyDescription)
networkFirewallPolicyModifiedViolation_expectedPolicyDescription :: Lens'
  NetworkFirewallPolicyModifiedViolation
  (Maybe NetworkFirewallPolicyDescription)
networkFirewallPolicyModifiedViolation_expectedPolicyDescription = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\NetworkFirewallPolicyModifiedViolation' {Maybe NetworkFirewallPolicyDescription
expectedPolicyDescription :: Maybe NetworkFirewallPolicyDescription
$sel:expectedPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation
-> Maybe NetworkFirewallPolicyDescription
expectedPolicyDescription} -> Maybe NetworkFirewallPolicyDescription
expectedPolicyDescription) (\s :: NetworkFirewallPolicyModifiedViolation
s@NetworkFirewallPolicyModifiedViolation' {} Maybe NetworkFirewallPolicyDescription
a -> NetworkFirewallPolicyModifiedViolation
s {$sel:expectedPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: Maybe NetworkFirewallPolicyDescription
expectedPolicyDescription = Maybe NetworkFirewallPolicyDescription
a} :: NetworkFirewallPolicyModifiedViolation)

-- | The ID of the Network Firewall or VPC resource that\'s in violation.
networkFirewallPolicyModifiedViolation_violationTarget :: Lens.Lens' NetworkFirewallPolicyModifiedViolation (Prelude.Maybe Prelude.Text)
networkFirewallPolicyModifiedViolation_violationTarget :: Lens' NetworkFirewallPolicyModifiedViolation (Maybe Text)
networkFirewallPolicyModifiedViolation_violationTarget = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\NetworkFirewallPolicyModifiedViolation' {Maybe Text
violationTarget :: Maybe Text
$sel:violationTarget:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation -> Maybe Text
violationTarget} -> Maybe Text
violationTarget) (\s :: NetworkFirewallPolicyModifiedViolation
s@NetworkFirewallPolicyModifiedViolation' {} Maybe Text
a -> NetworkFirewallPolicyModifiedViolation
s {$sel:violationTarget:NetworkFirewallPolicyModifiedViolation' :: Maybe Text
violationTarget = Maybe Text
a} :: NetworkFirewallPolicyModifiedViolation)

instance
  Data.FromJSON
    NetworkFirewallPolicyModifiedViolation
  where
  parseJSON :: Value -> Parser NetworkFirewallPolicyModifiedViolation
parseJSON =
    forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
      String
"NetworkFirewallPolicyModifiedViolation"
      ( \Object
x ->
          Maybe NetworkFirewallPolicyDescription
-> Maybe NetworkFirewallPolicyDescription
-> Maybe Text
-> NetworkFirewallPolicyModifiedViolation
NetworkFirewallPolicyModifiedViolation'
            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
"CurrentPolicyDescription")
            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
"ExpectedPolicyDescription")
            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
"ViolationTarget")
      )

instance
  Prelude.Hashable
    NetworkFirewallPolicyModifiedViolation
  where
  hashWithSalt :: Int -> NetworkFirewallPolicyModifiedViolation -> Int
hashWithSalt
    Int
_salt
    NetworkFirewallPolicyModifiedViolation' {Maybe Text
Maybe NetworkFirewallPolicyDescription
violationTarget :: Maybe Text
expectedPolicyDescription :: Maybe NetworkFirewallPolicyDescription
currentPolicyDescription :: Maybe NetworkFirewallPolicyDescription
$sel:violationTarget:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation -> Maybe Text
$sel:expectedPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation
-> Maybe NetworkFirewallPolicyDescription
$sel:currentPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation
-> Maybe NetworkFirewallPolicyDescription
..} =
      Int
_salt
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe NetworkFirewallPolicyDescription
currentPolicyDescription
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe NetworkFirewallPolicyDescription
expectedPolicyDescription
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
violationTarget

instance
  Prelude.NFData
    NetworkFirewallPolicyModifiedViolation
  where
  rnf :: NetworkFirewallPolicyModifiedViolation -> ()
rnf NetworkFirewallPolicyModifiedViolation' {Maybe Text
Maybe NetworkFirewallPolicyDescription
violationTarget :: Maybe Text
expectedPolicyDescription :: Maybe NetworkFirewallPolicyDescription
currentPolicyDescription :: Maybe NetworkFirewallPolicyDescription
$sel:violationTarget:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation -> Maybe Text
$sel:expectedPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation
-> Maybe NetworkFirewallPolicyDescription
$sel:currentPolicyDescription:NetworkFirewallPolicyModifiedViolation' :: NetworkFirewallPolicyModifiedViolation
-> Maybe NetworkFirewallPolicyDescription
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe NetworkFirewallPolicyDescription
currentPolicyDescription
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe NetworkFirewallPolicyDescription
expectedPolicyDescription
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
violationTarget