{-# 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.IoTWireless.Types.WirelessDeviceLogOption -- 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.IoTWireless.Types.WirelessDeviceLogOption where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoTWireless.Types.LogLevel import Amazonka.IoTWireless.Types.WirelessDeviceEventLogOption import Amazonka.IoTWireless.Types.WirelessDeviceType import qualified Amazonka.Prelude as Prelude -- | The log options for wireless devices and can be used to set log levels -- for a specific type of wireless device. -- -- /See:/ 'newWirelessDeviceLogOption' smart constructor. data WirelessDeviceLogOption = WirelessDeviceLogOption' { events :: Prelude.Maybe [WirelessDeviceEventLogOption], -- | The wireless device type. type' :: WirelessDeviceType, logLevel :: LogLevel } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'WirelessDeviceLogOption' 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: -- -- 'events', 'wirelessDeviceLogOption_events' - Undocumented member. -- -- 'type'', 'wirelessDeviceLogOption_type' - The wireless device type. -- -- 'logLevel', 'wirelessDeviceLogOption_logLevel' - Undocumented member. newWirelessDeviceLogOption :: -- | 'type'' WirelessDeviceType -> -- | 'logLevel' LogLevel -> WirelessDeviceLogOption newWirelessDeviceLogOption pType_ pLogLevel_ = WirelessDeviceLogOption' { events = Prelude.Nothing, type' = pType_, logLevel = pLogLevel_ } -- | Undocumented member. wirelessDeviceLogOption_events :: Lens.Lens' WirelessDeviceLogOption (Prelude.Maybe [WirelessDeviceEventLogOption]) wirelessDeviceLogOption_events = Lens.lens (\WirelessDeviceLogOption' {events} -> events) (\s@WirelessDeviceLogOption' {} a -> s {events = a} :: WirelessDeviceLogOption) Prelude.. Lens.mapping Lens.coerced -- | The wireless device type. wirelessDeviceLogOption_type :: Lens.Lens' WirelessDeviceLogOption WirelessDeviceType wirelessDeviceLogOption_type = Lens.lens (\WirelessDeviceLogOption' {type'} -> type') (\s@WirelessDeviceLogOption' {} a -> s {type' = a} :: WirelessDeviceLogOption) -- | Undocumented member. wirelessDeviceLogOption_logLevel :: Lens.Lens' WirelessDeviceLogOption LogLevel wirelessDeviceLogOption_logLevel = Lens.lens (\WirelessDeviceLogOption' {logLevel} -> logLevel) (\s@WirelessDeviceLogOption' {} a -> s {logLevel = a} :: WirelessDeviceLogOption) instance Data.FromJSON WirelessDeviceLogOption where parseJSON = Data.withObject "WirelessDeviceLogOption" ( \x -> WirelessDeviceLogOption' Prelude.<$> (x Data..:? "Events" Data..!= Prelude.mempty) Prelude.<*> (x Data..: "Type") Prelude.<*> (x Data..: "LogLevel") ) instance Prelude.Hashable WirelessDeviceLogOption where hashWithSalt _salt WirelessDeviceLogOption' {..} = _salt `Prelude.hashWithSalt` events `Prelude.hashWithSalt` type' `Prelude.hashWithSalt` logLevel instance Prelude.NFData WirelessDeviceLogOption where rnf WirelessDeviceLogOption' {..} = Prelude.rnf events `Prelude.seq` Prelude.rnf type' `Prelude.seq` Prelude.rnf logLevel instance Data.ToJSON WirelessDeviceLogOption where toJSON WirelessDeviceLogOption' {..} = Data.object ( Prelude.catMaybes [ ("Events" Data..=) Prelude.<$> events, Prelude.Just ("Type" Data..= type'), Prelude.Just ("LogLevel" Data..= logLevel) ] )