{-# 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.GroundStation.Types.SocketAddress -- 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.GroundStation.Types.SocketAddress 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 -- | Information about the socket address. -- -- /See:/ 'newSocketAddress' smart constructor. data SocketAddress = SocketAddress' { -- | Name of a socket address. name :: Prelude.Text, -- | Port of a socket address. port :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SocketAddress' 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: -- -- 'name', 'socketAddress_name' - Name of a socket address. -- -- 'port', 'socketAddress_port' - Port of a socket address. newSocketAddress :: -- | 'name' Prelude.Text -> -- | 'port' Prelude.Int -> SocketAddress newSocketAddress pName_ pPort_ = SocketAddress' {name = pName_, port = pPort_} -- | Name of a socket address. socketAddress_name :: Lens.Lens' SocketAddress Prelude.Text socketAddress_name = Lens.lens (\SocketAddress' {name} -> name) (\s@SocketAddress' {} a -> s {name = a} :: SocketAddress) -- | Port of a socket address. socketAddress_port :: Lens.Lens' SocketAddress Prelude.Int socketAddress_port = Lens.lens (\SocketAddress' {port} -> port) (\s@SocketAddress' {} a -> s {port = a} :: SocketAddress) instance Data.FromJSON SocketAddress where parseJSON = Data.withObject "SocketAddress" ( \x -> SocketAddress' Prelude.<$> (x Data..: "name") Prelude.<*> (x Data..: "port") ) instance Prelude.Hashable SocketAddress where hashWithSalt _salt SocketAddress' {..} = _salt `Prelude.hashWithSalt` name `Prelude.hashWithSalt` port instance Prelude.NFData SocketAddress where rnf SocketAddress' {..} = Prelude.rnf name `Prelude.seq` Prelude.rnf port instance Data.ToJSON SocketAddress where toJSON SocketAddress' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("name" Data..= name), Prelude.Just ("port" Data..= port) ] )