{-# 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.SageMakerGeoSpatial.Types.Property -- 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.SageMakerGeoSpatial.Types.Property 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 import Amazonka.SageMakerGeoSpatial.Types.EoCloudCoverInput import Amazonka.SageMakerGeoSpatial.Types.LandsatCloudCoverLandInput import Amazonka.SageMakerGeoSpatial.Types.PlatformInput import Amazonka.SageMakerGeoSpatial.Types.ViewOffNadirInput import Amazonka.SageMakerGeoSpatial.Types.ViewSunAzimuthInput import Amazonka.SageMakerGeoSpatial.Types.ViewSunElevationInput -- | -- -- /See:/ 'newProperty' smart constructor. data Property = Property' { eoCloudCover :: Prelude.Maybe EoCloudCoverInput, landsatCloudCoverLand :: Prelude.Maybe LandsatCloudCoverLandInput, platform :: Prelude.Maybe PlatformInput, viewOffNadir :: Prelude.Maybe ViewOffNadirInput, viewSunAzimuth :: Prelude.Maybe ViewSunAzimuthInput, viewSunElevation :: Prelude.Maybe ViewSunElevationInput } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'Property' 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: -- -- 'eoCloudCover', 'property_eoCloudCover' - -- -- 'landsatCloudCoverLand', 'property_landsatCloudCoverLand' - -- -- 'platform', 'property_platform' - -- -- 'viewOffNadir', 'property_viewOffNadir' - -- -- 'viewSunAzimuth', 'property_viewSunAzimuth' - -- -- 'viewSunElevation', 'property_viewSunElevation' - newProperty :: Property newProperty = Property' { eoCloudCover = Prelude.Nothing, landsatCloudCoverLand = Prelude.Nothing, platform = Prelude.Nothing, viewOffNadir = Prelude.Nothing, viewSunAzimuth = Prelude.Nothing, viewSunElevation = Prelude.Nothing } property_eoCloudCover :: Lens.Lens' Property (Prelude.Maybe EoCloudCoverInput) property_eoCloudCover = Lens.lens (\Property' {eoCloudCover} -> eoCloudCover) (\s@Property' {} a -> s {eoCloudCover = a} :: Property) property_landsatCloudCoverLand :: Lens.Lens' Property (Prelude.Maybe LandsatCloudCoverLandInput) property_landsatCloudCoverLand = Lens.lens (\Property' {landsatCloudCoverLand} -> landsatCloudCoverLand) (\s@Property' {} a -> s {landsatCloudCoverLand = a} :: Property) property_platform :: Lens.Lens' Property (Prelude.Maybe PlatformInput) property_platform = Lens.lens (\Property' {platform} -> platform) (\s@Property' {} a -> s {platform = a} :: Property) property_viewOffNadir :: Lens.Lens' Property (Prelude.Maybe ViewOffNadirInput) property_viewOffNadir = Lens.lens (\Property' {viewOffNadir} -> viewOffNadir) (\s@Property' {} a -> s {viewOffNadir = a} :: Property) property_viewSunAzimuth :: Lens.Lens' Property (Prelude.Maybe ViewSunAzimuthInput) property_viewSunAzimuth = Lens.lens (\Property' {viewSunAzimuth} -> viewSunAzimuth) (\s@Property' {} a -> s {viewSunAzimuth = a} :: Property) property_viewSunElevation :: Lens.Lens' Property (Prelude.Maybe ViewSunElevationInput) property_viewSunElevation = Lens.lens (\Property' {viewSunElevation} -> viewSunElevation) (\s@Property' {} a -> s {viewSunElevation = a} :: Property) instance Data.FromJSON Property where parseJSON = Data.withObject "Property" ( \x -> Property' Prelude.<$> (x Data..:? "EoCloudCover") Prelude.<*> (x Data..:? "LandsatCloudCoverLand") Prelude.<*> (x Data..:? "Platform") Prelude.<*> (x Data..:? "ViewOffNadir") Prelude.<*> (x Data..:? "ViewSunAzimuth") Prelude.<*> (x Data..:? "ViewSunElevation") ) instance Prelude.Hashable Property where hashWithSalt _salt Property' {..} = _salt `Prelude.hashWithSalt` eoCloudCover `Prelude.hashWithSalt` landsatCloudCoverLand `Prelude.hashWithSalt` platform `Prelude.hashWithSalt` viewOffNadir `Prelude.hashWithSalt` viewSunAzimuth `Prelude.hashWithSalt` viewSunElevation instance Prelude.NFData Property where rnf Property' {..} = Prelude.rnf eoCloudCover `Prelude.seq` Prelude.rnf landsatCloudCoverLand `Prelude.seq` Prelude.rnf platform `Prelude.seq` Prelude.rnf viewOffNadir `Prelude.seq` Prelude.rnf viewSunAzimuth `Prelude.seq` Prelude.rnf viewSunElevation instance Data.ToJSON Property where toJSON Property' {..} = Data.object ( Prelude.catMaybes [ ("EoCloudCover" Data..=) Prelude.<$> eoCloudCover, ("LandsatCloudCoverLand" Data..=) Prelude.<$> landsatCloudCoverLand, ("Platform" Data..=) Prelude.<$> platform, ("ViewOffNadir" Data..=) Prelude.<$> viewOffNadir, ("ViewSunAzimuth" Data..=) Prelude.<$> viewSunAzimuth, ("ViewSunElevation" Data..=) Prelude.<$> viewSunElevation ] )