{-# 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.Route53AutoNaming.UpdateService -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Submits a request to perform the following operations: -- -- - Update the TTL setting for existing @DnsRecords@ configurations -- -- - Add, update, or delete @HealthCheckConfig@ for a specified service -- -- You can\'t add, update, or delete a @HealthCheckCustomConfig@ -- configuration. -- -- For public and private DNS namespaces, note the following: -- -- - If you omit any existing @DnsRecords@ or @HealthCheckConfig@ -- configurations from an @UpdateService@ request, the configurations -- are deleted from the service. -- -- - If you omit an existing @HealthCheckCustomConfig@ configuration from -- an @UpdateService@ request, the configuration isn\'t deleted from -- the service. -- -- When you update settings for a service, Cloud Map also updates the -- corresponding settings in all the records and health checks that were -- created by using the specified service. module Amazonka.Route53AutoNaming.UpdateService ( -- * Creating a Request UpdateService (..), newUpdateService, -- * Request Lenses updateService_id, updateService_service, -- * Destructuring the Response UpdateServiceResponse (..), newUpdateServiceResponse, -- * Response Lenses updateServiceResponse_operationId, updateServiceResponse_httpStatus, ) 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 qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.Route53AutoNaming.Types -- | /See:/ 'newUpdateService' smart constructor. data UpdateService = UpdateService' { -- | The ID of the service that you want to update. id :: Prelude.Text, -- | A complex type that contains the new settings for the service. service :: ServiceChange } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateService' 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: -- -- 'id', 'updateService_id' - The ID of the service that you want to update. -- -- 'service', 'updateService_service' - A complex type that contains the new settings for the service. newUpdateService :: -- | 'id' Prelude.Text -> -- | 'service' ServiceChange -> UpdateService newUpdateService pId_ pService_ = UpdateService' {id = pId_, service = pService_} -- | The ID of the service that you want to update. updateService_id :: Lens.Lens' UpdateService Prelude.Text updateService_id = Lens.lens (\UpdateService' {id} -> id) (\s@UpdateService' {} a -> s {id = a} :: UpdateService) -- | A complex type that contains the new settings for the service. updateService_service :: Lens.Lens' UpdateService ServiceChange updateService_service = Lens.lens (\UpdateService' {service} -> service) (\s@UpdateService' {} a -> s {service = a} :: UpdateService) instance Core.AWSRequest UpdateService where type AWSResponse UpdateService = UpdateServiceResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateServiceResponse' Prelude.<$> (x Data..?> "OperationId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateService where hashWithSalt _salt UpdateService' {..} = _salt `Prelude.hashWithSalt` id `Prelude.hashWithSalt` service instance Prelude.NFData UpdateService where rnf UpdateService' {..} = Prelude.rnf id `Prelude.seq` Prelude.rnf service instance Data.ToHeaders UpdateService where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Route53AutoNaming_v20170314.UpdateService" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateService where toJSON UpdateService' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("Id" Data..= id), Prelude.Just ("Service" Data..= service) ] ) instance Data.ToPath UpdateService where toPath = Prelude.const "/" instance Data.ToQuery UpdateService where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateServiceResponse' smart constructor. data UpdateServiceResponse = UpdateServiceResponse' { -- | A value that you can use to determine whether the request completed -- successfully. To get the status of the operation, see -- . operationId :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateServiceResponse' 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: -- -- 'operationId', 'updateServiceResponse_operationId' - A value that you can use to determine whether the request completed -- successfully. To get the status of the operation, see -- . -- -- 'httpStatus', 'updateServiceResponse_httpStatus' - The response's http status code. newUpdateServiceResponse :: -- | 'httpStatus' Prelude.Int -> UpdateServiceResponse newUpdateServiceResponse pHttpStatus_ = UpdateServiceResponse' { operationId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A value that you can use to determine whether the request completed -- successfully. To get the status of the operation, see -- . updateServiceResponse_operationId :: Lens.Lens' UpdateServiceResponse (Prelude.Maybe Prelude.Text) updateServiceResponse_operationId = Lens.lens (\UpdateServiceResponse' {operationId} -> operationId) (\s@UpdateServiceResponse' {} a -> s {operationId = a} :: UpdateServiceResponse) -- | The response's http status code. updateServiceResponse_httpStatus :: Lens.Lens' UpdateServiceResponse Prelude.Int updateServiceResponse_httpStatus = Lens.lens (\UpdateServiceResponse' {httpStatus} -> httpStatus) (\s@UpdateServiceResponse' {} a -> s {httpStatus = a} :: UpdateServiceResponse) instance Prelude.NFData UpdateServiceResponse where rnf UpdateServiceResponse' {..} = Prelude.rnf operationId `Prelude.seq` Prelude.rnf httpStatus