{-# 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.DataPipeline.Types.InstanceIdentity -- 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.DataPipeline.Types.InstanceIdentity 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 -- | Identity information for the EC2 instance that is hosting the task -- runner. You can get this value by calling a metadata URI from the EC2 -- instance. For more information, see -- -- in the /Amazon Elastic Compute Cloud User Guide./ Passing in this value -- proves that your task runner is running on an EC2 instance, and ensures -- the proper AWS Data Pipeline service charges are applied to your -- pipeline. -- -- /See:/ 'newInstanceIdentity' smart constructor. data InstanceIdentity = InstanceIdentity' { -- | A description of an EC2 instance that is generated when the instance is -- launched and exposed to the instance via the instance metadata service -- in the form of a JSON representation of an object. document :: Prelude.Maybe Prelude.Text, -- | A signature which can be used to verify the accuracy and authenticity of -- the information provided in the instance identity document. signature :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'InstanceIdentity' 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: -- -- 'document', 'instanceIdentity_document' - A description of an EC2 instance that is generated when the instance is -- launched and exposed to the instance via the instance metadata service -- in the form of a JSON representation of an object. -- -- 'signature', 'instanceIdentity_signature' - A signature which can be used to verify the accuracy and authenticity of -- the information provided in the instance identity document. newInstanceIdentity :: InstanceIdentity newInstanceIdentity = InstanceIdentity' { document = Prelude.Nothing, signature = Prelude.Nothing } -- | A description of an EC2 instance that is generated when the instance is -- launched and exposed to the instance via the instance metadata service -- in the form of a JSON representation of an object. instanceIdentity_document :: Lens.Lens' InstanceIdentity (Prelude.Maybe Prelude.Text) instanceIdentity_document = Lens.lens (\InstanceIdentity' {document} -> document) (\s@InstanceIdentity' {} a -> s {document = a} :: InstanceIdentity) -- | A signature which can be used to verify the accuracy and authenticity of -- the information provided in the instance identity document. instanceIdentity_signature :: Lens.Lens' InstanceIdentity (Prelude.Maybe Prelude.Text) instanceIdentity_signature = Lens.lens (\InstanceIdentity' {signature} -> signature) (\s@InstanceIdentity' {} a -> s {signature = a} :: InstanceIdentity) instance Prelude.Hashable InstanceIdentity where hashWithSalt _salt InstanceIdentity' {..} = _salt `Prelude.hashWithSalt` document `Prelude.hashWithSalt` signature instance Prelude.NFData InstanceIdentity where rnf InstanceIdentity' {..} = Prelude.rnf document `Prelude.seq` Prelude.rnf signature instance Data.ToJSON InstanceIdentity where toJSON InstanceIdentity' {..} = Data.object ( Prelude.catMaybes [ ("document" Data..=) Prelude.<$> document, ("signature" Data..=) Prelude.<$> signature ] )