{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.Lightsail.OpenInstancePublicPorts -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Opens ports for a specific Amazon Lightsail instance, and specifies the -- IP addresses allowed to connect to the instance through the ports, and -- the protocol. -- -- The @OpenInstancePublicPorts@ action supports tag-based access control -- via resource tags applied to the resource identified by @instanceName@. -- For more information, see the -- . module Amazonka.Lightsail.OpenInstancePublicPorts ( -- * Creating a Request OpenInstancePublicPorts (..), newOpenInstancePublicPorts, -- * Request Lenses openInstancePublicPorts_portInfo, openInstancePublicPorts_instanceName, -- * Destructuring the Response OpenInstancePublicPortsResponse (..), newOpenInstancePublicPortsResponse, -- * Response Lenses openInstancePublicPortsResponse_operation, openInstancePublicPortsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Lightsail.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newOpenInstancePublicPorts' smart constructor. data OpenInstancePublicPorts = OpenInstancePublicPorts' { -- | An object to describe the ports to open for the specified instance. portInfo :: PortInfo, -- | The name of the instance for which to open ports. instanceName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'OpenInstancePublicPorts' 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: -- -- 'portInfo', 'openInstancePublicPorts_portInfo' - An object to describe the ports to open for the specified instance. -- -- 'instanceName', 'openInstancePublicPorts_instanceName' - The name of the instance for which to open ports. newOpenInstancePublicPorts :: -- | 'portInfo' PortInfo -> -- | 'instanceName' Prelude.Text -> OpenInstancePublicPorts newOpenInstancePublicPorts pPortInfo_ pInstanceName_ = OpenInstancePublicPorts' { portInfo = pPortInfo_, instanceName = pInstanceName_ } -- | An object to describe the ports to open for the specified instance. openInstancePublicPorts_portInfo :: Lens.Lens' OpenInstancePublicPorts PortInfo openInstancePublicPorts_portInfo = Lens.lens (\OpenInstancePublicPorts' {portInfo} -> portInfo) (\s@OpenInstancePublicPorts' {} a -> s {portInfo = a} :: OpenInstancePublicPorts) -- | The name of the instance for which to open ports. openInstancePublicPorts_instanceName :: Lens.Lens' OpenInstancePublicPorts Prelude.Text openInstancePublicPorts_instanceName = Lens.lens (\OpenInstancePublicPorts' {instanceName} -> instanceName) (\s@OpenInstancePublicPorts' {} a -> s {instanceName = a} :: OpenInstancePublicPorts) instance Core.AWSRequest OpenInstancePublicPorts where type AWSResponse OpenInstancePublicPorts = OpenInstancePublicPortsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> OpenInstancePublicPortsResponse' Prelude.<$> (x Data..?> "operation") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable OpenInstancePublicPorts where hashWithSalt _salt OpenInstancePublicPorts' {..} = _salt `Prelude.hashWithSalt` portInfo `Prelude.hashWithSalt` instanceName instance Prelude.NFData OpenInstancePublicPorts where rnf OpenInstancePublicPorts' {..} = Prelude.rnf portInfo `Prelude.seq` Prelude.rnf instanceName instance Data.ToHeaders OpenInstancePublicPorts where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Lightsail_20161128.OpenInstancePublicPorts" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON OpenInstancePublicPorts where toJSON OpenInstancePublicPorts' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("portInfo" Data..= portInfo), Prelude.Just ("instanceName" Data..= instanceName) ] ) instance Data.ToPath OpenInstancePublicPorts where toPath = Prelude.const "/" instance Data.ToQuery OpenInstancePublicPorts where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newOpenInstancePublicPortsResponse' smart constructor. data OpenInstancePublicPortsResponse = OpenInstancePublicPortsResponse' { -- | An array of objects that describe the result of the action, such as the -- status of the request, the timestamp of the request, and the resources -- affected by the request. operation :: Prelude.Maybe Operation, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'OpenInstancePublicPortsResponse' 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: -- -- 'operation', 'openInstancePublicPortsResponse_operation' - An array of objects that describe the result of the action, such as the -- status of the request, the timestamp of the request, and the resources -- affected by the request. -- -- 'httpStatus', 'openInstancePublicPortsResponse_httpStatus' - The response's http status code. newOpenInstancePublicPortsResponse :: -- | 'httpStatus' Prelude.Int -> OpenInstancePublicPortsResponse newOpenInstancePublicPortsResponse pHttpStatus_ = OpenInstancePublicPortsResponse' { operation = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | An array of objects that describe the result of the action, such as the -- status of the request, the timestamp of the request, and the resources -- affected by the request. openInstancePublicPortsResponse_operation :: Lens.Lens' OpenInstancePublicPortsResponse (Prelude.Maybe Operation) openInstancePublicPortsResponse_operation = Lens.lens (\OpenInstancePublicPortsResponse' {operation} -> operation) (\s@OpenInstancePublicPortsResponse' {} a -> s {operation = a} :: OpenInstancePublicPortsResponse) -- | The response's http status code. openInstancePublicPortsResponse_httpStatus :: Lens.Lens' OpenInstancePublicPortsResponse Prelude.Int openInstancePublicPortsResponse_httpStatus = Lens.lens (\OpenInstancePublicPortsResponse' {httpStatus} -> httpStatus) (\s@OpenInstancePublicPortsResponse' {} a -> s {httpStatus = a} :: OpenInstancePublicPortsResponse) instance Prelude.NFData OpenInstancePublicPortsResponse where rnf OpenInstancePublicPortsResponse' {..} = Prelude.rnf operation `Prelude.seq` Prelude.rnf httpStatus