{-# 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.ECS.Types.MountPoint -- 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.ECS.Types.MountPoint 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 -- | Details for a volume mount point that\'s used in a container definition. -- -- /See:/ 'newMountPoint' smart constructor. data MountPoint = MountPoint' { -- | The path on the container to mount the host volume at. containerPath :: Prelude.Maybe Prelude.Text, -- | If this value is @true@, the container has read-only access to the -- volume. If this value is @false@, then the container can write to the -- volume. The default value is @false@. readOnly :: Prelude.Maybe Prelude.Bool, -- | The name of the volume to mount. Must be a volume name referenced in the -- @name@ parameter of task definition @volume@. sourceVolume :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'MountPoint' 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: -- -- 'containerPath', 'mountPoint_containerPath' - The path on the container to mount the host volume at. -- -- 'readOnly', 'mountPoint_readOnly' - If this value is @true@, the container has read-only access to the -- volume. If this value is @false@, then the container can write to the -- volume. The default value is @false@. -- -- 'sourceVolume', 'mountPoint_sourceVolume' - The name of the volume to mount. Must be a volume name referenced in the -- @name@ parameter of task definition @volume@. newMountPoint :: MountPoint newMountPoint = MountPoint' { containerPath = Prelude.Nothing, readOnly = Prelude.Nothing, sourceVolume = Prelude.Nothing } -- | The path on the container to mount the host volume at. mountPoint_containerPath :: Lens.Lens' MountPoint (Prelude.Maybe Prelude.Text) mountPoint_containerPath = Lens.lens (\MountPoint' {containerPath} -> containerPath) (\s@MountPoint' {} a -> s {containerPath = a} :: MountPoint) -- | If this value is @true@, the container has read-only access to the -- volume. If this value is @false@, then the container can write to the -- volume. The default value is @false@. mountPoint_readOnly :: Lens.Lens' MountPoint (Prelude.Maybe Prelude.Bool) mountPoint_readOnly = Lens.lens (\MountPoint' {readOnly} -> readOnly) (\s@MountPoint' {} a -> s {readOnly = a} :: MountPoint) -- | The name of the volume to mount. Must be a volume name referenced in the -- @name@ parameter of task definition @volume@. mountPoint_sourceVolume :: Lens.Lens' MountPoint (Prelude.Maybe Prelude.Text) mountPoint_sourceVolume = Lens.lens (\MountPoint' {sourceVolume} -> sourceVolume) (\s@MountPoint' {} a -> s {sourceVolume = a} :: MountPoint) instance Data.FromJSON MountPoint where parseJSON = Data.withObject "MountPoint" ( \x -> MountPoint' Prelude.<$> (x Data..:? "containerPath") Prelude.<*> (x Data..:? "readOnly") Prelude.<*> (x Data..:? "sourceVolume") ) instance Prelude.Hashable MountPoint where hashWithSalt _salt MountPoint' {..} = _salt `Prelude.hashWithSalt` containerPath `Prelude.hashWithSalt` readOnly `Prelude.hashWithSalt` sourceVolume instance Prelude.NFData MountPoint where rnf MountPoint' {..} = Prelude.rnf containerPath `Prelude.seq` Prelude.rnf readOnly `Prelude.seq` Prelude.rnf sourceVolume instance Data.ToJSON MountPoint where toJSON MountPoint' {..} = Data.object ( Prelude.catMaybes [ ("containerPath" Data..=) Prelude.<$> containerPath, ("readOnly" Data..=) Prelude.<$> readOnly, ("sourceVolume" Data..=) Prelude.<$> sourceVolume ] )