{-# 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.CloudFront.UpdatePublicKey -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Update public key information. Note that the only value you can change -- is the comment. module Amazonka.CloudFront.UpdatePublicKey ( -- * Creating a Request UpdatePublicKey (..), newUpdatePublicKey, -- * Request Lenses updatePublicKey_ifMatch, updatePublicKey_publicKeyConfig, updatePublicKey_id, -- * Destructuring the Response UpdatePublicKeyResponse (..), newUpdatePublicKeyResponse, -- * Response Lenses updatePublicKeyResponse_eTag, updatePublicKeyResponse_publicKey, updatePublicKeyResponse_httpStatus, ) where import Amazonka.CloudFront.Types 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 qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdatePublicKey' smart constructor. data UpdatePublicKey = UpdatePublicKey' { -- | The value of the @ETag@ header that you received when retrieving the -- public key to update. For example: @E2QWRUHAPOMQZL@. ifMatch :: Prelude.Maybe Prelude.Text, -- | A public key configuration. publicKeyConfig :: PublicKeyConfig, -- | The identifier of the public key that you are updating. id :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdatePublicKey' 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: -- -- 'ifMatch', 'updatePublicKey_ifMatch' - The value of the @ETag@ header that you received when retrieving the -- public key to update. For example: @E2QWRUHAPOMQZL@. -- -- 'publicKeyConfig', 'updatePublicKey_publicKeyConfig' - A public key configuration. -- -- 'id', 'updatePublicKey_id' - The identifier of the public key that you are updating. newUpdatePublicKey :: -- | 'publicKeyConfig' PublicKeyConfig -> -- | 'id' Prelude.Text -> UpdatePublicKey newUpdatePublicKey pPublicKeyConfig_ pId_ = UpdatePublicKey' { ifMatch = Prelude.Nothing, publicKeyConfig = pPublicKeyConfig_, id = pId_ } -- | The value of the @ETag@ header that you received when retrieving the -- public key to update. For example: @E2QWRUHAPOMQZL@. updatePublicKey_ifMatch :: Lens.Lens' UpdatePublicKey (Prelude.Maybe Prelude.Text) updatePublicKey_ifMatch = Lens.lens (\UpdatePublicKey' {ifMatch} -> ifMatch) (\s@UpdatePublicKey' {} a -> s {ifMatch = a} :: UpdatePublicKey) -- | A public key configuration. updatePublicKey_publicKeyConfig :: Lens.Lens' UpdatePublicKey PublicKeyConfig updatePublicKey_publicKeyConfig = Lens.lens (\UpdatePublicKey' {publicKeyConfig} -> publicKeyConfig) (\s@UpdatePublicKey' {} a -> s {publicKeyConfig = a} :: UpdatePublicKey) -- | The identifier of the public key that you are updating. updatePublicKey_id :: Lens.Lens' UpdatePublicKey Prelude.Text updatePublicKey_id = Lens.lens (\UpdatePublicKey' {id} -> id) (\s@UpdatePublicKey' {} a -> s {id = a} :: UpdatePublicKey) instance Core.AWSRequest UpdatePublicKey where type AWSResponse UpdatePublicKey = UpdatePublicKeyResponse request overrides = Request.putXML (overrides defaultService) response = Response.receiveXML ( \s h x -> UpdatePublicKeyResponse' Prelude.<$> (h Data..#? "ETag") Prelude.<*> (Data.parseXML x) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdatePublicKey where hashWithSalt _salt UpdatePublicKey' {..} = _salt `Prelude.hashWithSalt` ifMatch `Prelude.hashWithSalt` publicKeyConfig `Prelude.hashWithSalt` id instance Prelude.NFData UpdatePublicKey where rnf UpdatePublicKey' {..} = Prelude.rnf ifMatch `Prelude.seq` Prelude.rnf publicKeyConfig `Prelude.seq` Prelude.rnf id instance Data.ToElement UpdatePublicKey where toElement UpdatePublicKey' {..} = Data.mkElement "{http://cloudfront.amazonaws.com/doc/2020-05-31/}PublicKeyConfig" publicKeyConfig instance Data.ToHeaders UpdatePublicKey where toHeaders UpdatePublicKey' {..} = Prelude.mconcat ["If-Match" Data.=# ifMatch] instance Data.ToPath UpdatePublicKey where toPath UpdatePublicKey' {..} = Prelude.mconcat ["/2020-05-31/public-key/", Data.toBS id, "/config"] instance Data.ToQuery UpdatePublicKey where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdatePublicKeyResponse' smart constructor. data UpdatePublicKeyResponse = UpdatePublicKeyResponse' { -- | The identifier of the current version of the public key. eTag :: Prelude.Maybe Prelude.Text, -- | The public key. publicKey :: Prelude.Maybe PublicKey, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdatePublicKeyResponse' 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: -- -- 'eTag', 'updatePublicKeyResponse_eTag' - The identifier of the current version of the public key. -- -- 'publicKey', 'updatePublicKeyResponse_publicKey' - The public key. -- -- 'httpStatus', 'updatePublicKeyResponse_httpStatus' - The response's http status code. newUpdatePublicKeyResponse :: -- | 'httpStatus' Prelude.Int -> UpdatePublicKeyResponse newUpdatePublicKeyResponse pHttpStatus_ = UpdatePublicKeyResponse' { eTag = Prelude.Nothing, publicKey = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The identifier of the current version of the public key. updatePublicKeyResponse_eTag :: Lens.Lens' UpdatePublicKeyResponse (Prelude.Maybe Prelude.Text) updatePublicKeyResponse_eTag = Lens.lens (\UpdatePublicKeyResponse' {eTag} -> eTag) (\s@UpdatePublicKeyResponse' {} a -> s {eTag = a} :: UpdatePublicKeyResponse) -- | The public key. updatePublicKeyResponse_publicKey :: Lens.Lens' UpdatePublicKeyResponse (Prelude.Maybe PublicKey) updatePublicKeyResponse_publicKey = Lens.lens (\UpdatePublicKeyResponse' {publicKey} -> publicKey) (\s@UpdatePublicKeyResponse' {} a -> s {publicKey = a} :: UpdatePublicKeyResponse) -- | The response's http status code. updatePublicKeyResponse_httpStatus :: Lens.Lens' UpdatePublicKeyResponse Prelude.Int updatePublicKeyResponse_httpStatus = Lens.lens (\UpdatePublicKeyResponse' {httpStatus} -> httpStatus) (\s@UpdatePublicKeyResponse' {} a -> s {httpStatus = a} :: UpdatePublicKeyResponse) instance Prelude.NFData UpdatePublicKeyResponse where rnf UpdatePublicKeyResponse' {..} = Prelude.rnf eTag `Prelude.seq` Prelude.rnf publicKey `Prelude.seq` Prelude.rnf httpStatus