{-# 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.Synthetics.Types.CanaryScheduleOutput -- 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.Synthetics.Types.CanaryScheduleOutput 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 -- | How long, in seconds, for the canary to continue making regular runs -- according to the schedule in the @Expression@ value. -- -- /See:/ 'newCanaryScheduleOutput' smart constructor. data CanaryScheduleOutput = CanaryScheduleOutput' { -- | How long, in seconds, for the canary to continue making regular runs -- after it was created. The runs are performed according to the schedule -- in the @Expression@ value. durationInSeconds :: Prelude.Maybe Prelude.Natural, -- | A @rate@ expression or a @cron@ expression that defines how often the -- canary is to run. -- -- For a rate expression, The syntax is @rate(@/@number unit@/@)@. /unit/ -- can be @minute@, @minutes@, or @hour@. -- -- For example, @rate(1 minute)@ runs the canary once a minute, -- @rate(10 minutes)@ runs it once every 10 minutes, and @rate(1 hour)@ -- runs it once every hour. You can specify a frequency between -- @rate(1 minute)@ and @rate(1 hour)@. -- -- Specifying @rate(0 minute)@ or @rate(0 hour)@ is a special value that -- causes the canary to run only once when it is started. -- -- Use @cron(@/@expression@/@)@ to specify a cron expression. For -- information about the syntax for cron expressions, see -- . expression :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CanaryScheduleOutput' 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: -- -- 'durationInSeconds', 'canaryScheduleOutput_durationInSeconds' - How long, in seconds, for the canary to continue making regular runs -- after it was created. The runs are performed according to the schedule -- in the @Expression@ value. -- -- 'expression', 'canaryScheduleOutput_expression' - A @rate@ expression or a @cron@ expression that defines how often the -- canary is to run. -- -- For a rate expression, The syntax is @rate(@/@number unit@/@)@. /unit/ -- can be @minute@, @minutes@, or @hour@. -- -- For example, @rate(1 minute)@ runs the canary once a minute, -- @rate(10 minutes)@ runs it once every 10 minutes, and @rate(1 hour)@ -- runs it once every hour. You can specify a frequency between -- @rate(1 minute)@ and @rate(1 hour)@. -- -- Specifying @rate(0 minute)@ or @rate(0 hour)@ is a special value that -- causes the canary to run only once when it is started. -- -- Use @cron(@/@expression@/@)@ to specify a cron expression. For -- information about the syntax for cron expressions, see -- . newCanaryScheduleOutput :: CanaryScheduleOutput newCanaryScheduleOutput = CanaryScheduleOutput' { durationInSeconds = Prelude.Nothing, expression = Prelude.Nothing } -- | How long, in seconds, for the canary to continue making regular runs -- after it was created. The runs are performed according to the schedule -- in the @Expression@ value. canaryScheduleOutput_durationInSeconds :: Lens.Lens' CanaryScheduleOutput (Prelude.Maybe Prelude.Natural) canaryScheduleOutput_durationInSeconds = Lens.lens (\CanaryScheduleOutput' {durationInSeconds} -> durationInSeconds) (\s@CanaryScheduleOutput' {} a -> s {durationInSeconds = a} :: CanaryScheduleOutput) -- | A @rate@ expression or a @cron@ expression that defines how often the -- canary is to run. -- -- For a rate expression, The syntax is @rate(@/@number unit@/@)@. /unit/ -- can be @minute@, @minutes@, or @hour@. -- -- For example, @rate(1 minute)@ runs the canary once a minute, -- @rate(10 minutes)@ runs it once every 10 minutes, and @rate(1 hour)@ -- runs it once every hour. You can specify a frequency between -- @rate(1 minute)@ and @rate(1 hour)@. -- -- Specifying @rate(0 minute)@ or @rate(0 hour)@ is a special value that -- causes the canary to run only once when it is started. -- -- Use @cron(@/@expression@/@)@ to specify a cron expression. For -- information about the syntax for cron expressions, see -- . canaryScheduleOutput_expression :: Lens.Lens' CanaryScheduleOutput (Prelude.Maybe Prelude.Text) canaryScheduleOutput_expression = Lens.lens (\CanaryScheduleOutput' {expression} -> expression) (\s@CanaryScheduleOutput' {} a -> s {expression = a} :: CanaryScheduleOutput) instance Data.FromJSON CanaryScheduleOutput where parseJSON = Data.withObject "CanaryScheduleOutput" ( \x -> CanaryScheduleOutput' Prelude.<$> (x Data..:? "DurationInSeconds") Prelude.<*> (x Data..:? "Expression") ) instance Prelude.Hashable CanaryScheduleOutput where hashWithSalt _salt CanaryScheduleOutput' {..} = _salt `Prelude.hashWithSalt` durationInSeconds `Prelude.hashWithSalt` expression instance Prelude.NFData CanaryScheduleOutput where rnf CanaryScheduleOutput' {..} = Prelude.rnf durationInSeconds `Prelude.seq` Prelude.rnf expression