{-# 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.EC2.Types.ScheduledInstancesEbs -- 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.EC2.Types.ScheduledInstancesEbs where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.EC2.Internal import qualified Amazonka.Prelude as Prelude -- | Describes an EBS volume for a Scheduled Instance. -- -- /See:/ 'newScheduledInstancesEbs' smart constructor. data ScheduledInstancesEbs = ScheduledInstancesEbs' { -- | Indicates whether the volume is deleted on instance termination. deleteOnTermination :: Prelude.Maybe Prelude.Bool, -- | Indicates whether the volume is encrypted. You can attached encrypted -- volumes only to instances that support them. encrypted :: Prelude.Maybe Prelude.Bool, -- | The number of I\/O operations per second (IOPS) to provision for an -- @io1@ or @io2@ volume, with a maximum ratio of 50 IOPS\/GiB for @io1@, -- and 500 IOPS\/GiB for @io2@. Range is 100 to 64,000 IOPS for volumes in -- most Regions. Maximum IOPS of 64,000 is guaranteed only on -- . -- Other instance families guarantee performance up to 32,000 IOPS. For -- more information, see -- -- in the /Amazon EC2 User Guide/. -- -- This parameter is valid only for Provisioned IOPS SSD (@io1@ and @io2@) -- volumes. iops :: Prelude.Maybe Prelude.Int, -- | The ID of the snapshot. snapshotId :: Prelude.Maybe Prelude.Text, -- | The size of the volume, in GiB. -- -- Default: If you\'re creating the volume from a snapshot and don\'t -- specify a volume size, the default is the snapshot size. volumeSize :: Prelude.Maybe Prelude.Int, -- | The volume type. @gp2@ for General Purpose SSD, @io1@ or @ io2@ for -- Provisioned IOPS SSD, Throughput Optimized HDD for @st1@, Cold HDD for -- @sc1@, or @standard@ for Magnetic. -- -- Default: @gp2@ volumeType :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ScheduledInstancesEbs' 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: -- -- 'deleteOnTermination', 'scheduledInstancesEbs_deleteOnTermination' - Indicates whether the volume is deleted on instance termination. -- -- 'encrypted', 'scheduledInstancesEbs_encrypted' - Indicates whether the volume is encrypted. You can attached encrypted -- volumes only to instances that support them. -- -- 'iops', 'scheduledInstancesEbs_iops' - The number of I\/O operations per second (IOPS) to provision for an -- @io1@ or @io2@ volume, with a maximum ratio of 50 IOPS\/GiB for @io1@, -- and 500 IOPS\/GiB for @io2@. Range is 100 to 64,000 IOPS for volumes in -- most Regions. Maximum IOPS of 64,000 is guaranteed only on -- . -- Other instance families guarantee performance up to 32,000 IOPS. For -- more information, see -- -- in the /Amazon EC2 User Guide/. -- -- This parameter is valid only for Provisioned IOPS SSD (@io1@ and @io2@) -- volumes. -- -- 'snapshotId', 'scheduledInstancesEbs_snapshotId' - The ID of the snapshot. -- -- 'volumeSize', 'scheduledInstancesEbs_volumeSize' - The size of the volume, in GiB. -- -- Default: If you\'re creating the volume from a snapshot and don\'t -- specify a volume size, the default is the snapshot size. -- -- 'volumeType', 'scheduledInstancesEbs_volumeType' - The volume type. @gp2@ for General Purpose SSD, @io1@ or @ io2@ for -- Provisioned IOPS SSD, Throughput Optimized HDD for @st1@, Cold HDD for -- @sc1@, or @standard@ for Magnetic. -- -- Default: @gp2@ newScheduledInstancesEbs :: ScheduledInstancesEbs newScheduledInstancesEbs = ScheduledInstancesEbs' { deleteOnTermination = Prelude.Nothing, encrypted = Prelude.Nothing, iops = Prelude.Nothing, snapshotId = Prelude.Nothing, volumeSize = Prelude.Nothing, volumeType = Prelude.Nothing } -- | Indicates whether the volume is deleted on instance termination. scheduledInstancesEbs_deleteOnTermination :: Lens.Lens' ScheduledInstancesEbs (Prelude.Maybe Prelude.Bool) scheduledInstancesEbs_deleteOnTermination = Lens.lens (\ScheduledInstancesEbs' {deleteOnTermination} -> deleteOnTermination) (\s@ScheduledInstancesEbs' {} a -> s {deleteOnTermination = a} :: ScheduledInstancesEbs) -- | Indicates whether the volume is encrypted. You can attached encrypted -- volumes only to instances that support them. scheduledInstancesEbs_encrypted :: Lens.Lens' ScheduledInstancesEbs (Prelude.Maybe Prelude.Bool) scheduledInstancesEbs_encrypted = Lens.lens (\ScheduledInstancesEbs' {encrypted} -> encrypted) (\s@ScheduledInstancesEbs' {} a -> s {encrypted = a} :: ScheduledInstancesEbs) -- | The number of I\/O operations per second (IOPS) to provision for an -- @io1@ or @io2@ volume, with a maximum ratio of 50 IOPS\/GiB for @io1@, -- and 500 IOPS\/GiB for @io2@. Range is 100 to 64,000 IOPS for volumes in -- most Regions. Maximum IOPS of 64,000 is guaranteed only on -- . -- Other instance families guarantee performance up to 32,000 IOPS. For -- more information, see -- -- in the /Amazon EC2 User Guide/. -- -- This parameter is valid only for Provisioned IOPS SSD (@io1@ and @io2@) -- volumes. scheduledInstancesEbs_iops :: Lens.Lens' ScheduledInstancesEbs (Prelude.Maybe Prelude.Int) scheduledInstancesEbs_iops = Lens.lens (\ScheduledInstancesEbs' {iops} -> iops) (\s@ScheduledInstancesEbs' {} a -> s {iops = a} :: ScheduledInstancesEbs) -- | The ID of the snapshot. scheduledInstancesEbs_snapshotId :: Lens.Lens' ScheduledInstancesEbs (Prelude.Maybe Prelude.Text) scheduledInstancesEbs_snapshotId = Lens.lens (\ScheduledInstancesEbs' {snapshotId} -> snapshotId) (\s@ScheduledInstancesEbs' {} a -> s {snapshotId = a} :: ScheduledInstancesEbs) -- | The size of the volume, in GiB. -- -- Default: If you\'re creating the volume from a snapshot and don\'t -- specify a volume size, the default is the snapshot size. scheduledInstancesEbs_volumeSize :: Lens.Lens' ScheduledInstancesEbs (Prelude.Maybe Prelude.Int) scheduledInstancesEbs_volumeSize = Lens.lens (\ScheduledInstancesEbs' {volumeSize} -> volumeSize) (\s@ScheduledInstancesEbs' {} a -> s {volumeSize = a} :: ScheduledInstancesEbs) -- | The volume type. @gp2@ for General Purpose SSD, @io1@ or @ io2@ for -- Provisioned IOPS SSD, Throughput Optimized HDD for @st1@, Cold HDD for -- @sc1@, or @standard@ for Magnetic. -- -- Default: @gp2@ scheduledInstancesEbs_volumeType :: Lens.Lens' ScheduledInstancesEbs (Prelude.Maybe Prelude.Text) scheduledInstancesEbs_volumeType = Lens.lens (\ScheduledInstancesEbs' {volumeType} -> volumeType) (\s@ScheduledInstancesEbs' {} a -> s {volumeType = a} :: ScheduledInstancesEbs) instance Prelude.Hashable ScheduledInstancesEbs where hashWithSalt _salt ScheduledInstancesEbs' {..} = _salt `Prelude.hashWithSalt` deleteOnTermination `Prelude.hashWithSalt` encrypted `Prelude.hashWithSalt` iops `Prelude.hashWithSalt` snapshotId `Prelude.hashWithSalt` volumeSize `Prelude.hashWithSalt` volumeType instance Prelude.NFData ScheduledInstancesEbs where rnf ScheduledInstancesEbs' {..} = Prelude.rnf deleteOnTermination `Prelude.seq` Prelude.rnf encrypted `Prelude.seq` Prelude.rnf iops `Prelude.seq` Prelude.rnf snapshotId `Prelude.seq` Prelude.rnf volumeSize `Prelude.seq` Prelude.rnf volumeType instance Data.ToQuery ScheduledInstancesEbs where toQuery ScheduledInstancesEbs' {..} = Prelude.mconcat [ "DeleteOnTermination" Data.=: deleteOnTermination, "Encrypted" Data.=: encrypted, "Iops" Data.=: iops, "SnapshotId" Data.=: snapshotId, "VolumeSize" Data.=: volumeSize, "VolumeType" Data.=: volumeType ]