{-# 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.Rekognition.Types.FaceDetection -- 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.Rekognition.Types.FaceDetection 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.Rekognition.Types.FaceDetail -- | Information about a face detected in a video analysis request and the -- time the face was detected in the video. -- -- /See:/ 'newFaceDetection' smart constructor. data FaceDetection = FaceDetection' { -- | The face properties for the detected face. face :: Prelude.Maybe FaceDetail, -- | Time, in milliseconds from the start of the video, that the face was -- detected. Note that @Timestamp@ is not guaranteed to be accurate to the -- individual frame where the face first appears. timestamp :: Prelude.Maybe Prelude.Integer } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'FaceDetection' 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: -- -- 'face', 'faceDetection_face' - The face properties for the detected face. -- -- 'timestamp', 'faceDetection_timestamp' - Time, in milliseconds from the start of the video, that the face was -- detected. Note that @Timestamp@ is not guaranteed to be accurate to the -- individual frame where the face first appears. newFaceDetection :: FaceDetection newFaceDetection = FaceDetection' { face = Prelude.Nothing, timestamp = Prelude.Nothing } -- | The face properties for the detected face. faceDetection_face :: Lens.Lens' FaceDetection (Prelude.Maybe FaceDetail) faceDetection_face = Lens.lens (\FaceDetection' {face} -> face) (\s@FaceDetection' {} a -> s {face = a} :: FaceDetection) -- | Time, in milliseconds from the start of the video, that the face was -- detected. Note that @Timestamp@ is not guaranteed to be accurate to the -- individual frame where the face first appears. faceDetection_timestamp :: Lens.Lens' FaceDetection (Prelude.Maybe Prelude.Integer) faceDetection_timestamp = Lens.lens (\FaceDetection' {timestamp} -> timestamp) (\s@FaceDetection' {} a -> s {timestamp = a} :: FaceDetection) instance Data.FromJSON FaceDetection where parseJSON = Data.withObject "FaceDetection" ( \x -> FaceDetection' Prelude.<$> (x Data..:? "Face") Prelude.<*> (x Data..:? "Timestamp") ) instance Prelude.Hashable FaceDetection where hashWithSalt _salt FaceDetection' {..} = _salt `Prelude.hashWithSalt` face `Prelude.hashWithSalt` timestamp instance Prelude.NFData FaceDetection where rnf FaceDetection' {..} = Prelude.rnf face `Prelude.seq` Prelude.rnf timestamp