{-# 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.AppMesh.UpdateVirtualRouter -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Updates an existing virtual router in a specified service mesh. module Amazonka.AppMesh.UpdateVirtualRouter ( -- * Creating a Request UpdateVirtualRouter (..), newUpdateVirtualRouter, -- * Request Lenses updateVirtualRouter_clientToken, updateVirtualRouter_meshOwner, updateVirtualRouter_meshName, updateVirtualRouter_spec, updateVirtualRouter_virtualRouterName, -- * Destructuring the Response UpdateVirtualRouterResponse (..), newUpdateVirtualRouterResponse, -- * Response Lenses updateVirtualRouterResponse_httpStatus, updateVirtualRouterResponse_virtualRouter, ) where import Amazonka.AppMesh.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:/ 'newUpdateVirtualRouter' smart constructor. data UpdateVirtualRouter = UpdateVirtualRouter' { -- | Unique, case-sensitive identifier that you provide to ensure the -- idempotency of the request. Up to 36 letters, numbers, hyphens, and -- underscores are allowed. clientToken :: Prelude.Maybe Prelude.Text, -- | The Amazon Web Services IAM account ID of the service mesh owner. If the -- account ID is not your own, then it\'s the ID of the account that shared -- the mesh with your account. For more information about mesh sharing, see -- . meshOwner :: Prelude.Maybe Prelude.Text, -- | The name of the service mesh that the virtual router resides in. meshName :: Prelude.Text, -- | The new virtual router specification to apply. This overwrites the -- existing data. spec :: VirtualRouterSpec, -- | The name of the virtual router to update. virtualRouterName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateVirtualRouter' 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: -- -- 'clientToken', 'updateVirtualRouter_clientToken' - Unique, case-sensitive identifier that you provide to ensure the -- idempotency of the request. Up to 36 letters, numbers, hyphens, and -- underscores are allowed. -- -- 'meshOwner', 'updateVirtualRouter_meshOwner' - The Amazon Web Services IAM account ID of the service mesh owner. If the -- account ID is not your own, then it\'s the ID of the account that shared -- the mesh with your account. For more information about mesh sharing, see -- . -- -- 'meshName', 'updateVirtualRouter_meshName' - The name of the service mesh that the virtual router resides in. -- -- 'spec', 'updateVirtualRouter_spec' - The new virtual router specification to apply. This overwrites the -- existing data. -- -- 'virtualRouterName', 'updateVirtualRouter_virtualRouterName' - The name of the virtual router to update. newUpdateVirtualRouter :: -- | 'meshName' Prelude.Text -> -- | 'spec' VirtualRouterSpec -> -- | 'virtualRouterName' Prelude.Text -> UpdateVirtualRouter newUpdateVirtualRouter pMeshName_ pSpec_ pVirtualRouterName_ = UpdateVirtualRouter' { clientToken = Prelude.Nothing, meshOwner = Prelude.Nothing, meshName = pMeshName_, spec = pSpec_, virtualRouterName = pVirtualRouterName_ } -- | Unique, case-sensitive identifier that you provide to ensure the -- idempotency of the request. Up to 36 letters, numbers, hyphens, and -- underscores are allowed. updateVirtualRouter_clientToken :: Lens.Lens' UpdateVirtualRouter (Prelude.Maybe Prelude.Text) updateVirtualRouter_clientToken = Lens.lens (\UpdateVirtualRouter' {clientToken} -> clientToken) (\s@UpdateVirtualRouter' {} a -> s {clientToken = a} :: UpdateVirtualRouter) -- | The Amazon Web Services IAM account ID of the service mesh owner. If the -- account ID is not your own, then it\'s the ID of the account that shared -- the mesh with your account. For more information about mesh sharing, see -- . updateVirtualRouter_meshOwner :: Lens.Lens' UpdateVirtualRouter (Prelude.Maybe Prelude.Text) updateVirtualRouter_meshOwner = Lens.lens (\UpdateVirtualRouter' {meshOwner} -> meshOwner) (\s@UpdateVirtualRouter' {} a -> s {meshOwner = a} :: UpdateVirtualRouter) -- | The name of the service mesh that the virtual router resides in. updateVirtualRouter_meshName :: Lens.Lens' UpdateVirtualRouter Prelude.Text updateVirtualRouter_meshName = Lens.lens (\UpdateVirtualRouter' {meshName} -> meshName) (\s@UpdateVirtualRouter' {} a -> s {meshName = a} :: UpdateVirtualRouter) -- | The new virtual router specification to apply. This overwrites the -- existing data. updateVirtualRouter_spec :: Lens.Lens' UpdateVirtualRouter VirtualRouterSpec updateVirtualRouter_spec = Lens.lens (\UpdateVirtualRouter' {spec} -> spec) (\s@UpdateVirtualRouter' {} a -> s {spec = a} :: UpdateVirtualRouter) -- | The name of the virtual router to update. updateVirtualRouter_virtualRouterName :: Lens.Lens' UpdateVirtualRouter Prelude.Text updateVirtualRouter_virtualRouterName = Lens.lens (\UpdateVirtualRouter' {virtualRouterName} -> virtualRouterName) (\s@UpdateVirtualRouter' {} a -> s {virtualRouterName = a} :: UpdateVirtualRouter) instance Core.AWSRequest UpdateVirtualRouter where type AWSResponse UpdateVirtualRouter = UpdateVirtualRouterResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateVirtualRouterResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (Data.eitherParseJSON x) ) instance Prelude.Hashable UpdateVirtualRouter where hashWithSalt _salt UpdateVirtualRouter' {..} = _salt `Prelude.hashWithSalt` clientToken `Prelude.hashWithSalt` meshOwner `Prelude.hashWithSalt` meshName `Prelude.hashWithSalt` spec `Prelude.hashWithSalt` virtualRouterName instance Prelude.NFData UpdateVirtualRouter where rnf UpdateVirtualRouter' {..} = Prelude.rnf clientToken `Prelude.seq` Prelude.rnf meshOwner `Prelude.seq` Prelude.rnf meshName `Prelude.seq` Prelude.rnf spec `Prelude.seq` Prelude.rnf virtualRouterName instance Data.ToHeaders UpdateVirtualRouter where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateVirtualRouter where toJSON UpdateVirtualRouter' {..} = Data.object ( Prelude.catMaybes [ ("clientToken" Data..=) Prelude.<$> clientToken, Prelude.Just ("spec" Data..= spec) ] ) instance Data.ToPath UpdateVirtualRouter where toPath UpdateVirtualRouter' {..} = Prelude.mconcat [ "/v20190125/meshes/", Data.toBS meshName, "/virtualRouters/", Data.toBS virtualRouterName ] instance Data.ToQuery UpdateVirtualRouter where toQuery UpdateVirtualRouter' {..} = Prelude.mconcat ["meshOwner" Data.=: meshOwner] -- | -- -- /See:/ 'newUpdateVirtualRouterResponse' smart constructor. data UpdateVirtualRouterResponse = UpdateVirtualRouterResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | A full description of the virtual router that was updated. virtualRouter :: VirtualRouterData } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateVirtualRouterResponse' 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: -- -- 'httpStatus', 'updateVirtualRouterResponse_httpStatus' - The response's http status code. -- -- 'virtualRouter', 'updateVirtualRouterResponse_virtualRouter' - A full description of the virtual router that was updated. newUpdateVirtualRouterResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'virtualRouter' VirtualRouterData -> UpdateVirtualRouterResponse newUpdateVirtualRouterResponse pHttpStatus_ pVirtualRouter_ = UpdateVirtualRouterResponse' { httpStatus = pHttpStatus_, virtualRouter = pVirtualRouter_ } -- | The response's http status code. updateVirtualRouterResponse_httpStatus :: Lens.Lens' UpdateVirtualRouterResponse Prelude.Int updateVirtualRouterResponse_httpStatus = Lens.lens (\UpdateVirtualRouterResponse' {httpStatus} -> httpStatus) (\s@UpdateVirtualRouterResponse' {} a -> s {httpStatus = a} :: UpdateVirtualRouterResponse) -- | A full description of the virtual router that was updated. updateVirtualRouterResponse_virtualRouter :: Lens.Lens' UpdateVirtualRouterResponse VirtualRouterData updateVirtualRouterResponse_virtualRouter = Lens.lens (\UpdateVirtualRouterResponse' {virtualRouter} -> virtualRouter) (\s@UpdateVirtualRouterResponse' {} a -> s {virtualRouter = a} :: UpdateVirtualRouterResponse) instance Prelude.NFData UpdateVirtualRouterResponse where rnf UpdateVirtualRouterResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf virtualRouter