{-# 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.DeleteLoadBalancerTlsCertificate -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deletes an SSL\/TLS certificate associated with a Lightsail load -- balancer. -- -- The @DeleteLoadBalancerTlsCertificate@ operation supports tag-based -- access control via resource tags applied to the resource identified by -- @load balancer name@. For more information, see the -- . module Amazonka.Lightsail.DeleteLoadBalancerTlsCertificate ( -- * Creating a Request DeleteLoadBalancerTlsCertificate (..), newDeleteLoadBalancerTlsCertificate, -- * Request Lenses deleteLoadBalancerTlsCertificate_force, deleteLoadBalancerTlsCertificate_loadBalancerName, deleteLoadBalancerTlsCertificate_certificateName, -- * Destructuring the Response DeleteLoadBalancerTlsCertificateResponse (..), newDeleteLoadBalancerTlsCertificateResponse, -- * Response Lenses deleteLoadBalancerTlsCertificateResponse_operations, deleteLoadBalancerTlsCertificateResponse_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:/ 'newDeleteLoadBalancerTlsCertificate' smart constructor. data DeleteLoadBalancerTlsCertificate = DeleteLoadBalancerTlsCertificate' { -- | When @true@, forces the deletion of an SSL\/TLS certificate. -- -- There can be two certificates associated with a Lightsail load balancer: -- the primary and the backup. The @force@ parameter is required when the -- primary SSL\/TLS certificate is in use by an instance attached to the -- load balancer. force :: Prelude.Maybe Prelude.Bool, -- | The load balancer name. loadBalancerName :: Prelude.Text, -- | The SSL\/TLS certificate name. certificateName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteLoadBalancerTlsCertificate' 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: -- -- 'force', 'deleteLoadBalancerTlsCertificate_force' - When @true@, forces the deletion of an SSL\/TLS certificate. -- -- There can be two certificates associated with a Lightsail load balancer: -- the primary and the backup. The @force@ parameter is required when the -- primary SSL\/TLS certificate is in use by an instance attached to the -- load balancer. -- -- 'loadBalancerName', 'deleteLoadBalancerTlsCertificate_loadBalancerName' - The load balancer name. -- -- 'certificateName', 'deleteLoadBalancerTlsCertificate_certificateName' - The SSL\/TLS certificate name. newDeleteLoadBalancerTlsCertificate :: -- | 'loadBalancerName' Prelude.Text -> -- | 'certificateName' Prelude.Text -> DeleteLoadBalancerTlsCertificate newDeleteLoadBalancerTlsCertificate pLoadBalancerName_ pCertificateName_ = DeleteLoadBalancerTlsCertificate' { force = Prelude.Nothing, loadBalancerName = pLoadBalancerName_, certificateName = pCertificateName_ } -- | When @true@, forces the deletion of an SSL\/TLS certificate. -- -- There can be two certificates associated with a Lightsail load balancer: -- the primary and the backup. The @force@ parameter is required when the -- primary SSL\/TLS certificate is in use by an instance attached to the -- load balancer. deleteLoadBalancerTlsCertificate_force :: Lens.Lens' DeleteLoadBalancerTlsCertificate (Prelude.Maybe Prelude.Bool) deleteLoadBalancerTlsCertificate_force = Lens.lens (\DeleteLoadBalancerTlsCertificate' {force} -> force) (\s@DeleteLoadBalancerTlsCertificate' {} a -> s {force = a} :: DeleteLoadBalancerTlsCertificate) -- | The load balancer name. deleteLoadBalancerTlsCertificate_loadBalancerName :: Lens.Lens' DeleteLoadBalancerTlsCertificate Prelude.Text deleteLoadBalancerTlsCertificate_loadBalancerName = Lens.lens (\DeleteLoadBalancerTlsCertificate' {loadBalancerName} -> loadBalancerName) (\s@DeleteLoadBalancerTlsCertificate' {} a -> s {loadBalancerName = a} :: DeleteLoadBalancerTlsCertificate) -- | The SSL\/TLS certificate name. deleteLoadBalancerTlsCertificate_certificateName :: Lens.Lens' DeleteLoadBalancerTlsCertificate Prelude.Text deleteLoadBalancerTlsCertificate_certificateName = Lens.lens (\DeleteLoadBalancerTlsCertificate' {certificateName} -> certificateName) (\s@DeleteLoadBalancerTlsCertificate' {} a -> s {certificateName = a} :: DeleteLoadBalancerTlsCertificate) instance Core.AWSRequest DeleteLoadBalancerTlsCertificate where type AWSResponse DeleteLoadBalancerTlsCertificate = DeleteLoadBalancerTlsCertificateResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeleteLoadBalancerTlsCertificateResponse' Prelude.<$> (x Data..?> "operations" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteLoadBalancerTlsCertificate where hashWithSalt _salt DeleteLoadBalancerTlsCertificate' {..} = _salt `Prelude.hashWithSalt` force `Prelude.hashWithSalt` loadBalancerName `Prelude.hashWithSalt` certificateName instance Prelude.NFData DeleteLoadBalancerTlsCertificate where rnf DeleteLoadBalancerTlsCertificate' {..} = Prelude.rnf force `Prelude.seq` Prelude.rnf loadBalancerName `Prelude.seq` Prelude.rnf certificateName instance Data.ToHeaders DeleteLoadBalancerTlsCertificate where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Lightsail_20161128.DeleteLoadBalancerTlsCertificate" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteLoadBalancerTlsCertificate where toJSON DeleteLoadBalancerTlsCertificate' {..} = Data.object ( Prelude.catMaybes [ ("force" Data..=) Prelude.<$> force, Prelude.Just ("loadBalancerName" Data..= loadBalancerName), Prelude.Just ("certificateName" Data..= certificateName) ] ) instance Data.ToPath DeleteLoadBalancerTlsCertificate where toPath = Prelude.const "/" instance Data.ToQuery DeleteLoadBalancerTlsCertificate where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteLoadBalancerTlsCertificateResponse' smart constructor. data DeleteLoadBalancerTlsCertificateResponse = DeleteLoadBalancerTlsCertificateResponse' { -- | 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. operations :: 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 'DeleteLoadBalancerTlsCertificateResponse' 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: -- -- 'operations', 'deleteLoadBalancerTlsCertificateResponse_operations' - 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', 'deleteLoadBalancerTlsCertificateResponse_httpStatus' - The response's http status code. newDeleteLoadBalancerTlsCertificateResponse :: -- | 'httpStatus' Prelude.Int -> DeleteLoadBalancerTlsCertificateResponse newDeleteLoadBalancerTlsCertificateResponse pHttpStatus_ = DeleteLoadBalancerTlsCertificateResponse' { operations = 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. deleteLoadBalancerTlsCertificateResponse_operations :: Lens.Lens' DeleteLoadBalancerTlsCertificateResponse (Prelude.Maybe [Operation]) deleteLoadBalancerTlsCertificateResponse_operations = Lens.lens (\DeleteLoadBalancerTlsCertificateResponse' {operations} -> operations) (\s@DeleteLoadBalancerTlsCertificateResponse' {} a -> s {operations = a} :: DeleteLoadBalancerTlsCertificateResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. deleteLoadBalancerTlsCertificateResponse_httpStatus :: Lens.Lens' DeleteLoadBalancerTlsCertificateResponse Prelude.Int deleteLoadBalancerTlsCertificateResponse_httpStatus = Lens.lens (\DeleteLoadBalancerTlsCertificateResponse' {httpStatus} -> httpStatus) (\s@DeleteLoadBalancerTlsCertificateResponse' {} a -> s {httpStatus = a} :: DeleteLoadBalancerTlsCertificateResponse) instance Prelude.NFData DeleteLoadBalancerTlsCertificateResponse where rnf DeleteLoadBalancerTlsCertificateResponse' {..} = Prelude.rnf operations `Prelude.seq` Prelude.rnf httpStatus