{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.CloudSearch.Types.ScalingParameters -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.CloudSearch.Types.ScalingParameters where import Amazonka.CloudSearch.Types.PartitionInstanceType 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 -- | The desired instance type and desired number of replicas of each index -- partition. -- -- /See:/ 'newScalingParameters' smart constructor. data ScalingParameters = ScalingParameters' { -- | The instance type that you want to preconfigure for your domain. For -- example, @search.m1.small@. desiredInstanceType :: Prelude.Maybe PartitionInstanceType, -- | The number of partitions you want to preconfigure for your domain. Only -- valid when you select @m2.2xlarge@ as the desired instance type. desiredPartitionCount :: Prelude.Maybe Prelude.Natural, -- | The number of replicas you want to preconfigure for each index -- partition. desiredReplicationCount :: Prelude.Maybe Prelude.Natural } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ScalingParameters' 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: -- -- 'desiredInstanceType', 'scalingParameters_desiredInstanceType' - The instance type that you want to preconfigure for your domain. For -- example, @search.m1.small@. -- -- 'desiredPartitionCount', 'scalingParameters_desiredPartitionCount' - The number of partitions you want to preconfigure for your domain. Only -- valid when you select @m2.2xlarge@ as the desired instance type. -- -- 'desiredReplicationCount', 'scalingParameters_desiredReplicationCount' - The number of replicas you want to preconfigure for each index -- partition. newScalingParameters :: ScalingParameters newScalingParameters = ScalingParameters' { desiredInstanceType = Prelude.Nothing, desiredPartitionCount = Prelude.Nothing, desiredReplicationCount = Prelude.Nothing } -- | The instance type that you want to preconfigure for your domain. For -- example, @search.m1.small@. scalingParameters_desiredInstanceType :: Lens.Lens' ScalingParameters (Prelude.Maybe PartitionInstanceType) scalingParameters_desiredInstanceType = Lens.lens (\ScalingParameters' {desiredInstanceType} -> desiredInstanceType) (\s@ScalingParameters' {} a -> s {desiredInstanceType = a} :: ScalingParameters) -- | The number of partitions you want to preconfigure for your domain. Only -- valid when you select @m2.2xlarge@ as the desired instance type. scalingParameters_desiredPartitionCount :: Lens.Lens' ScalingParameters (Prelude.Maybe Prelude.Natural) scalingParameters_desiredPartitionCount = Lens.lens (\ScalingParameters' {desiredPartitionCount} -> desiredPartitionCount) (\s@ScalingParameters' {} a -> s {desiredPartitionCount = a} :: ScalingParameters) -- | The number of replicas you want to preconfigure for each index -- partition. scalingParameters_desiredReplicationCount :: Lens.Lens' ScalingParameters (Prelude.Maybe Prelude.Natural) scalingParameters_desiredReplicationCount = Lens.lens (\ScalingParameters' {desiredReplicationCount} -> desiredReplicationCount) (\s@ScalingParameters' {} a -> s {desiredReplicationCount = a} :: ScalingParameters) instance Data.FromXML ScalingParameters where parseXML x = ScalingParameters' Prelude.<$> (x Data..@? "DesiredInstanceType") Prelude.<*> (x Data..@? "DesiredPartitionCount") Prelude.<*> (x Data..@? "DesiredReplicationCount") instance Prelude.Hashable ScalingParameters where hashWithSalt _salt ScalingParameters' {..} = _salt `Prelude.hashWithSalt` desiredInstanceType `Prelude.hashWithSalt` desiredPartitionCount `Prelude.hashWithSalt` desiredReplicationCount instance Prelude.NFData ScalingParameters where rnf ScalingParameters' {..} = Prelude.rnf desiredInstanceType `Prelude.seq` Prelude.rnf desiredPartitionCount `Prelude.seq` Prelude.rnf desiredReplicationCount instance Data.ToQuery ScalingParameters where toQuery ScalingParameters' {..} = Prelude.mconcat [ "DesiredInstanceType" Data.=: desiredInstanceType, "DesiredPartitionCount" Data.=: desiredPartitionCount, "DesiredReplicationCount" Data.=: desiredReplicationCount ]