{-# 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.App -- 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.App 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 -- | An individual Firewall Manager application. -- -- /See:/ 'newApp' smart constructor. data App = App' { -- | The application\'s name. appName :: Prelude.Text, -- | The IP protocol name or number. The name can be one of @tcp@, @udp@, or -- @icmp@. For information on possible numbers, see -- . protocol :: Prelude.Text, -- | The application\'s port number, for example @80@. port :: Prelude.Natural } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'App' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'appName', 'app_appName' - The application\'s name. -- -- 'protocol', 'app_protocol' - The IP protocol name or number. The name can be one of @tcp@, @udp@, or -- @icmp@. For information on possible numbers, see -- . -- -- 'port', 'app_port' - The application\'s port number, for example @80@. newApp :: -- | 'appName' Prelude.Text -> -- | 'protocol' Prelude.Text -> -- | 'port' Prelude.Natural -> App newApp pAppName_ pProtocol_ pPort_ = App' { appName = pAppName_, protocol = pProtocol_, port = pPort_ } -- | The application\'s name. app_appName :: Lens.Lens' App Prelude.Text app_appName = Lens.lens (\App' {appName} -> appName) (\s@App' {} a -> s {appName = a} :: App) -- | The IP protocol name or number. The name can be one of @tcp@, @udp@, or -- @icmp@. For information on possible numbers, see -- . app_protocol :: Lens.Lens' App Prelude.Text app_protocol = Lens.lens (\App' {protocol} -> protocol) (\s@App' {} a -> s {protocol = a} :: App) -- | The application\'s port number, for example @80@. app_port :: Lens.Lens' App Prelude.Natural app_port = Lens.lens (\App' {port} -> port) (\s@App' {} a -> s {port = a} :: App) instance Data.FromJSON App where parseJSON = Data.withObject "App" ( \x -> App' Prelude.<$> (x Data..: "AppName") Prelude.<*> (x Data..: "Protocol") Prelude.<*> (x Data..: "Port") ) instance Prelude.Hashable App where hashWithSalt _salt App' {..} = _salt `Prelude.hashWithSalt` appName `Prelude.hashWithSalt` protocol `Prelude.hashWithSalt` port instance Prelude.NFData App where rnf App' {..} = Prelude.rnf appName `Prelude.seq` Prelude.rnf protocol `Prelude.seq` Prelude.rnf port instance Data.ToJSON App where toJSON App' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("AppName" Data..= appName), Prelude.Just ("Protocol" Data..= protocol), Prelude.Just ("Port" Data..= port) ] )