{-# 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.LaunchTemplateBlockDeviceMappingRequest -- 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.LaunchTemplateBlockDeviceMappingRequest 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 Amazonka.EC2.Types.LaunchTemplateEbsBlockDeviceRequest import qualified Amazonka.Prelude as Prelude -- | Describes a block device mapping. -- -- /See:/ 'newLaunchTemplateBlockDeviceMappingRequest' smart constructor. data LaunchTemplateBlockDeviceMappingRequest = LaunchTemplateBlockDeviceMappingRequest' { -- | The device name (for example, \/dev\/sdh or xvdh). deviceName :: Prelude.Maybe Prelude.Text, -- | Parameters used to automatically set up EBS volumes when the instance is -- launched. ebs :: Prelude.Maybe LaunchTemplateEbsBlockDeviceRequest, -- | To omit the device from the block device mapping, specify an empty -- string. noDevice :: Prelude.Maybe Prelude.Text, -- | The virtual device name (ephemeralN). Instance store volumes are -- numbered starting from 0. An instance type with 2 available instance -- store volumes can specify mappings for ephemeral0 and ephemeral1. The -- number of available instance store volumes depends on the instance type. -- After you connect to the instance, you must mount the volume. virtualName :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'LaunchTemplateBlockDeviceMappingRequest' 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: -- -- 'deviceName', 'launchTemplateBlockDeviceMappingRequest_deviceName' - The device name (for example, \/dev\/sdh or xvdh). -- -- 'ebs', 'launchTemplateBlockDeviceMappingRequest_ebs' - Parameters used to automatically set up EBS volumes when the instance is -- launched. -- -- 'noDevice', 'launchTemplateBlockDeviceMappingRequest_noDevice' - To omit the device from the block device mapping, specify an empty -- string. -- -- 'virtualName', 'launchTemplateBlockDeviceMappingRequest_virtualName' - The virtual device name (ephemeralN). Instance store volumes are -- numbered starting from 0. An instance type with 2 available instance -- store volumes can specify mappings for ephemeral0 and ephemeral1. The -- number of available instance store volumes depends on the instance type. -- After you connect to the instance, you must mount the volume. newLaunchTemplateBlockDeviceMappingRequest :: LaunchTemplateBlockDeviceMappingRequest newLaunchTemplateBlockDeviceMappingRequest = LaunchTemplateBlockDeviceMappingRequest' { deviceName = Prelude.Nothing, ebs = Prelude.Nothing, noDevice = Prelude.Nothing, virtualName = Prelude.Nothing } -- | The device name (for example, \/dev\/sdh or xvdh). launchTemplateBlockDeviceMappingRequest_deviceName :: Lens.Lens' LaunchTemplateBlockDeviceMappingRequest (Prelude.Maybe Prelude.Text) launchTemplateBlockDeviceMappingRequest_deviceName = Lens.lens (\LaunchTemplateBlockDeviceMappingRequest' {deviceName} -> deviceName) (\s@LaunchTemplateBlockDeviceMappingRequest' {} a -> s {deviceName = a} :: LaunchTemplateBlockDeviceMappingRequest) -- | Parameters used to automatically set up EBS volumes when the instance is -- launched. launchTemplateBlockDeviceMappingRequest_ebs :: Lens.Lens' LaunchTemplateBlockDeviceMappingRequest (Prelude.Maybe LaunchTemplateEbsBlockDeviceRequest) launchTemplateBlockDeviceMappingRequest_ebs = Lens.lens (\LaunchTemplateBlockDeviceMappingRequest' {ebs} -> ebs) (\s@LaunchTemplateBlockDeviceMappingRequest' {} a -> s {ebs = a} :: LaunchTemplateBlockDeviceMappingRequest) -- | To omit the device from the block device mapping, specify an empty -- string. launchTemplateBlockDeviceMappingRequest_noDevice :: Lens.Lens' LaunchTemplateBlockDeviceMappingRequest (Prelude.Maybe Prelude.Text) launchTemplateBlockDeviceMappingRequest_noDevice = Lens.lens (\LaunchTemplateBlockDeviceMappingRequest' {noDevice} -> noDevice) (\s@LaunchTemplateBlockDeviceMappingRequest' {} a -> s {noDevice = a} :: LaunchTemplateBlockDeviceMappingRequest) -- | The virtual device name (ephemeralN). Instance store volumes are -- numbered starting from 0. An instance type with 2 available instance -- store volumes can specify mappings for ephemeral0 and ephemeral1. The -- number of available instance store volumes depends on the instance type. -- After you connect to the instance, you must mount the volume. launchTemplateBlockDeviceMappingRequest_virtualName :: Lens.Lens' LaunchTemplateBlockDeviceMappingRequest (Prelude.Maybe Prelude.Text) launchTemplateBlockDeviceMappingRequest_virtualName = Lens.lens (\LaunchTemplateBlockDeviceMappingRequest' {virtualName} -> virtualName) (\s@LaunchTemplateBlockDeviceMappingRequest' {} a -> s {virtualName = a} :: LaunchTemplateBlockDeviceMappingRequest) instance Prelude.Hashable LaunchTemplateBlockDeviceMappingRequest where hashWithSalt _salt LaunchTemplateBlockDeviceMappingRequest' {..} = _salt `Prelude.hashWithSalt` deviceName `Prelude.hashWithSalt` ebs `Prelude.hashWithSalt` noDevice `Prelude.hashWithSalt` virtualName instance Prelude.NFData LaunchTemplateBlockDeviceMappingRequest where rnf LaunchTemplateBlockDeviceMappingRequest' {..} = Prelude.rnf deviceName `Prelude.seq` Prelude.rnf ebs `Prelude.seq` Prelude.rnf noDevice `Prelude.seq` Prelude.rnf virtualName instance Data.ToQuery LaunchTemplateBlockDeviceMappingRequest where toQuery LaunchTemplateBlockDeviceMappingRequest' {..} = Prelude.mconcat [ "DeviceName" Data.=: deviceName, "Ebs" Data.=: ebs, "NoDevice" Data.=: noDevice, "VirtualName" Data.=: virtualName ]