{-# 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.Redshift.Types.Endpoint -- 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.Redshift.Types.Endpoint 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.Redshift.Internal import Amazonka.Redshift.Types.VpcEndpoint -- | Describes a connection endpoint. -- -- /See:/ 'newEndpoint' smart constructor. data Endpoint = Endpoint' { -- | The DNS address of the Cluster. address :: Prelude.Maybe Prelude.Text, -- | The port that the database engine is listening on. port :: Prelude.Maybe Prelude.Int, -- | Describes a connection endpoint. vpcEndpoints :: Prelude.Maybe [VpcEndpoint] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'Endpoint' 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: -- -- 'address', 'endpoint_address' - The DNS address of the Cluster. -- -- 'port', 'endpoint_port' - The port that the database engine is listening on. -- -- 'vpcEndpoints', 'endpoint_vpcEndpoints' - Describes a connection endpoint. newEndpoint :: Endpoint newEndpoint = Endpoint' { address = Prelude.Nothing, port = Prelude.Nothing, vpcEndpoints = Prelude.Nothing } -- | The DNS address of the Cluster. endpoint_address :: Lens.Lens' Endpoint (Prelude.Maybe Prelude.Text) endpoint_address = Lens.lens (\Endpoint' {address} -> address) (\s@Endpoint' {} a -> s {address = a} :: Endpoint) -- | The port that the database engine is listening on. endpoint_port :: Lens.Lens' Endpoint (Prelude.Maybe Prelude.Int) endpoint_port = Lens.lens (\Endpoint' {port} -> port) (\s@Endpoint' {} a -> s {port = a} :: Endpoint) -- | Describes a connection endpoint. endpoint_vpcEndpoints :: Lens.Lens' Endpoint (Prelude.Maybe [VpcEndpoint]) endpoint_vpcEndpoints = Lens.lens (\Endpoint' {vpcEndpoints} -> vpcEndpoints) (\s@Endpoint' {} a -> s {vpcEndpoints = a} :: Endpoint) Prelude.. Lens.mapping Lens.coerced instance Data.FromXML Endpoint where parseXML x = Endpoint' Prelude.<$> (x Data..@? "Address") Prelude.<*> (x Data..@? "Port") Prelude.<*> ( x Data..@? "VpcEndpoints" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "VpcEndpoint") ) instance Prelude.Hashable Endpoint where hashWithSalt _salt Endpoint' {..} = _salt `Prelude.hashWithSalt` address `Prelude.hashWithSalt` port `Prelude.hashWithSalt` vpcEndpoints instance Prelude.NFData Endpoint where rnf Endpoint' {..} = Prelude.rnf address `Prelude.seq` Prelude.rnf port `Prelude.seq` Prelude.rnf vpcEndpoints