{-# 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.ElastiCache.CompleteMigration -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Complete the migration of data. module Amazonka.ElastiCache.CompleteMigration ( -- * Creating a Request CompleteMigration (..), newCompleteMigration, -- * Request Lenses completeMigration_force, completeMigration_replicationGroupId, -- * Destructuring the Response CompleteMigrationResponse (..), newCompleteMigrationResponse, -- * Response Lenses completeMigrationResponse_replicationGroup, completeMigrationResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.ElastiCache.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newCompleteMigration' smart constructor. data CompleteMigration = CompleteMigration' { -- | Forces the migration to stop without ensuring that data is in sync. It -- is recommended to use this option only to abort the migration and not -- recommended when application wants to continue migration to ElastiCache. force :: Prelude.Maybe Prelude.Bool, -- | The ID of the replication group to which data is being migrated. replicationGroupId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CompleteMigration' 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', 'completeMigration_force' - Forces the migration to stop without ensuring that data is in sync. It -- is recommended to use this option only to abort the migration and not -- recommended when application wants to continue migration to ElastiCache. -- -- 'replicationGroupId', 'completeMigration_replicationGroupId' - The ID of the replication group to which data is being migrated. newCompleteMigration :: -- | 'replicationGroupId' Prelude.Text -> CompleteMigration newCompleteMigration pReplicationGroupId_ = CompleteMigration' { force = Prelude.Nothing, replicationGroupId = pReplicationGroupId_ } -- | Forces the migration to stop without ensuring that data is in sync. It -- is recommended to use this option only to abort the migration and not -- recommended when application wants to continue migration to ElastiCache. completeMigration_force :: Lens.Lens' CompleteMigration (Prelude.Maybe Prelude.Bool) completeMigration_force = Lens.lens (\CompleteMigration' {force} -> force) (\s@CompleteMigration' {} a -> s {force = a} :: CompleteMigration) -- | The ID of the replication group to which data is being migrated. completeMigration_replicationGroupId :: Lens.Lens' CompleteMigration Prelude.Text completeMigration_replicationGroupId = Lens.lens (\CompleteMigration' {replicationGroupId} -> replicationGroupId) (\s@CompleteMigration' {} a -> s {replicationGroupId = a} :: CompleteMigration) instance Core.AWSRequest CompleteMigration where type AWSResponse CompleteMigration = CompleteMigrationResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "CompleteMigrationResult" ( \s h x -> CompleteMigrationResponse' Prelude.<$> (x Data..@? "ReplicationGroup") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CompleteMigration where hashWithSalt _salt CompleteMigration' {..} = _salt `Prelude.hashWithSalt` force `Prelude.hashWithSalt` replicationGroupId instance Prelude.NFData CompleteMigration where rnf CompleteMigration' {..} = Prelude.rnf force `Prelude.seq` Prelude.rnf replicationGroupId instance Data.ToHeaders CompleteMigration where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath CompleteMigration where toPath = Prelude.const "/" instance Data.ToQuery CompleteMigration where toQuery CompleteMigration' {..} = Prelude.mconcat [ "Action" Data.=: ("CompleteMigration" :: Prelude.ByteString), "Version" Data.=: ("2015-02-02" :: Prelude.ByteString), "Force" Data.=: force, "ReplicationGroupId" Data.=: replicationGroupId ] -- | /See:/ 'newCompleteMigrationResponse' smart constructor. data CompleteMigrationResponse = CompleteMigrationResponse' { replicationGroup :: Prelude.Maybe ReplicationGroup, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CompleteMigrationResponse' 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: -- -- 'replicationGroup', 'completeMigrationResponse_replicationGroup' - Undocumented member. -- -- 'httpStatus', 'completeMigrationResponse_httpStatus' - The response's http status code. newCompleteMigrationResponse :: -- | 'httpStatus' Prelude.Int -> CompleteMigrationResponse newCompleteMigrationResponse pHttpStatus_ = CompleteMigrationResponse' { replicationGroup = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Undocumented member. completeMigrationResponse_replicationGroup :: Lens.Lens' CompleteMigrationResponse (Prelude.Maybe ReplicationGroup) completeMigrationResponse_replicationGroup = Lens.lens (\CompleteMigrationResponse' {replicationGroup} -> replicationGroup) (\s@CompleteMigrationResponse' {} a -> s {replicationGroup = a} :: CompleteMigrationResponse) -- | The response's http status code. completeMigrationResponse_httpStatus :: Lens.Lens' CompleteMigrationResponse Prelude.Int completeMigrationResponse_httpStatus = Lens.lens (\CompleteMigrationResponse' {httpStatus} -> httpStatus) (\s@CompleteMigrationResponse' {} a -> s {httpStatus = a} :: CompleteMigrationResponse) instance Prelude.NFData CompleteMigrationResponse where rnf CompleteMigrationResponse' {..} = Prelude.rnf replicationGroup `Prelude.seq` Prelude.rnf httpStatus