{-# 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.AutoScaling.Types.LaunchTemplateSpecification -- 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.AutoScaling.Types.LaunchTemplateSpecification where 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 -- | Describes the launch template and the version of the launch template -- that Amazon EC2 Auto Scaling uses to launch Amazon EC2 instances. For -- more information about launch templates, see -- -- in the /Amazon EC2 Auto Scaling User Guide/. -- -- /See:/ 'newLaunchTemplateSpecification' smart constructor. data LaunchTemplateSpecification = LaunchTemplateSpecification' { -- | The ID of the launch template. To get the template ID, use the Amazon -- EC2 -- -- API operation. New launch templates can be created using the Amazon EC2 -- -- API. -- -- Conditional: You must specify either a @LaunchTemplateId@ or a -- @LaunchTemplateName@. launchTemplateId :: Prelude.Maybe Prelude.Text, -- | The name of the launch template. To get the template name, use the -- Amazon EC2 -- -- API operation. New launch templates can be created using the Amazon EC2 -- -- API. -- -- Conditional: You must specify either a @LaunchTemplateId@ or a -- @LaunchTemplateName@. launchTemplateName :: Prelude.Maybe Prelude.Text, -- | The version number, @$Latest@, or @$Default@. To get the version number, -- use the Amazon EC2 -- -- API operation. New launch template versions can be created using the -- Amazon EC2 -- -- API. If the value is @$Latest@, Amazon EC2 Auto Scaling selects the -- latest version of the launch template when launching instances. If the -- value is @$Default@, Amazon EC2 Auto Scaling selects the default version -- of the launch template when launching instances. The default value is -- @$Default@. version :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'LaunchTemplateSpecification' 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: -- -- 'launchTemplateId', 'launchTemplateSpecification_launchTemplateId' - The ID of the launch template. To get the template ID, use the Amazon -- EC2 -- -- API operation. New launch templates can be created using the Amazon EC2 -- -- API. -- -- Conditional: You must specify either a @LaunchTemplateId@ or a -- @LaunchTemplateName@. -- -- 'launchTemplateName', 'launchTemplateSpecification_launchTemplateName' - The name of the launch template. To get the template name, use the -- Amazon EC2 -- -- API operation. New launch templates can be created using the Amazon EC2 -- -- API. -- -- Conditional: You must specify either a @LaunchTemplateId@ or a -- @LaunchTemplateName@. -- -- 'version', 'launchTemplateSpecification_version' - The version number, @$Latest@, or @$Default@. To get the version number, -- use the Amazon EC2 -- -- API operation. New launch template versions can be created using the -- Amazon EC2 -- -- API. If the value is @$Latest@, Amazon EC2 Auto Scaling selects the -- latest version of the launch template when launching instances. If the -- value is @$Default@, Amazon EC2 Auto Scaling selects the default version -- of the launch template when launching instances. The default value is -- @$Default@. newLaunchTemplateSpecification :: LaunchTemplateSpecification newLaunchTemplateSpecification = LaunchTemplateSpecification' { launchTemplateId = Prelude.Nothing, launchTemplateName = Prelude.Nothing, version = Prelude.Nothing } -- | The ID of the launch template. To get the template ID, use the Amazon -- EC2 -- -- API operation. New launch templates can be created using the Amazon EC2 -- -- API. -- -- Conditional: You must specify either a @LaunchTemplateId@ or a -- @LaunchTemplateName@. launchTemplateSpecification_launchTemplateId :: Lens.Lens' LaunchTemplateSpecification (Prelude.Maybe Prelude.Text) launchTemplateSpecification_launchTemplateId = Lens.lens (\LaunchTemplateSpecification' {launchTemplateId} -> launchTemplateId) (\s@LaunchTemplateSpecification' {} a -> s {launchTemplateId = a} :: LaunchTemplateSpecification) -- | The name of the launch template. To get the template name, use the -- Amazon EC2 -- -- API operation. New launch templates can be created using the Amazon EC2 -- -- API. -- -- Conditional: You must specify either a @LaunchTemplateId@ or a -- @LaunchTemplateName@. launchTemplateSpecification_launchTemplateName :: Lens.Lens' LaunchTemplateSpecification (Prelude.Maybe Prelude.Text) launchTemplateSpecification_launchTemplateName = Lens.lens (\LaunchTemplateSpecification' {launchTemplateName} -> launchTemplateName) (\s@LaunchTemplateSpecification' {} a -> s {launchTemplateName = a} :: LaunchTemplateSpecification) -- | The version number, @$Latest@, or @$Default@. To get the version number, -- use the Amazon EC2 -- -- API operation. New launch template versions can be created using the -- Amazon EC2 -- -- API. If the value is @$Latest@, Amazon EC2 Auto Scaling selects the -- latest version of the launch template when launching instances. If the -- value is @$Default@, Amazon EC2 Auto Scaling selects the default version -- of the launch template when launching instances. The default value is -- @$Default@. launchTemplateSpecification_version :: Lens.Lens' LaunchTemplateSpecification (Prelude.Maybe Prelude.Text) launchTemplateSpecification_version = Lens.lens (\LaunchTemplateSpecification' {version} -> version) (\s@LaunchTemplateSpecification' {} a -> s {version = a} :: LaunchTemplateSpecification) instance Data.FromXML LaunchTemplateSpecification where parseXML x = LaunchTemplateSpecification' Prelude.<$> (x Data..@? "LaunchTemplateId") Prelude.<*> (x Data..@? "LaunchTemplateName") Prelude.<*> (x Data..@? "Version") instance Prelude.Hashable LaunchTemplateSpecification where hashWithSalt _salt LaunchTemplateSpecification' {..} = _salt `Prelude.hashWithSalt` launchTemplateId `Prelude.hashWithSalt` launchTemplateName `Prelude.hashWithSalt` version instance Prelude.NFData LaunchTemplateSpecification where rnf LaunchTemplateSpecification' {..} = Prelude.rnf launchTemplateId `Prelude.seq` Prelude.rnf launchTemplateName `Prelude.seq` Prelude.rnf version instance Data.ToQuery LaunchTemplateSpecification where toQuery LaunchTemplateSpecification' {..} = Prelude.mconcat [ "LaunchTemplateId" Data.=: launchTemplateId, "LaunchTemplateName" Data.=: launchTemplateName, "Version" Data.=: version ]