{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.Lightsail.GetContactMethods -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns information about the configured contact methods. Specify a -- protocol in your request to return information about a specific contact -- method. -- -- A contact method is used to send you notifications about your Amazon -- Lightsail resources. You can add one email address and one mobile phone -- number contact method in each Amazon Web Services Region. However, SMS -- text messaging is not supported in some Amazon Web Services Regions, and -- SMS text messages cannot be sent to some countries\/regions. For more -- information, see -- . module Amazonka.Lightsail.GetContactMethods ( -- * Creating a Request GetContactMethods (..), newGetContactMethods, -- * Request Lenses getContactMethods_protocols, -- * Destructuring the Response GetContactMethodsResponse (..), newGetContactMethodsResponse, -- * Response Lenses getContactMethodsResponse_contactMethods, getContactMethodsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Lightsail.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newGetContactMethods' smart constructor. data GetContactMethods = GetContactMethods' { -- | The protocols used to send notifications, such as @Email@, or @SMS@ -- (text messaging). -- -- Specify a protocol in your request to return information about a -- specific contact method protocol. protocols :: Prelude.Maybe [ContactProtocol] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetContactMethods' 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: -- -- 'protocols', 'getContactMethods_protocols' - The protocols used to send notifications, such as @Email@, or @SMS@ -- (text messaging). -- -- Specify a protocol in your request to return information about a -- specific contact method protocol. newGetContactMethods :: GetContactMethods newGetContactMethods = GetContactMethods' {protocols = Prelude.Nothing} -- | The protocols used to send notifications, such as @Email@, or @SMS@ -- (text messaging). -- -- Specify a protocol in your request to return information about a -- specific contact method protocol. getContactMethods_protocols :: Lens.Lens' GetContactMethods (Prelude.Maybe [ContactProtocol]) getContactMethods_protocols = Lens.lens (\GetContactMethods' {protocols} -> protocols) (\s@GetContactMethods' {} a -> s {protocols = a} :: GetContactMethods) Prelude.. Lens.mapping Lens.coerced instance Core.AWSRequest GetContactMethods where type AWSResponse GetContactMethods = GetContactMethodsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetContactMethodsResponse' Prelude.<$> (x Data..?> "contactMethods" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetContactMethods where hashWithSalt _salt GetContactMethods' {..} = _salt `Prelude.hashWithSalt` protocols instance Prelude.NFData GetContactMethods where rnf GetContactMethods' {..} = Prelude.rnf protocols instance Data.ToHeaders GetContactMethods where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Lightsail_20161128.GetContactMethods" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON GetContactMethods where toJSON GetContactMethods' {..} = Data.object ( Prelude.catMaybes [("protocols" Data..=) Prelude.<$> protocols] ) instance Data.ToPath GetContactMethods where toPath = Prelude.const "/" instance Data.ToQuery GetContactMethods where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetContactMethodsResponse' smart constructor. data GetContactMethodsResponse = GetContactMethodsResponse' { -- | An array of objects that describe the contact methods. contactMethods :: Prelude.Maybe [ContactMethod], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetContactMethodsResponse' 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: -- -- 'contactMethods', 'getContactMethodsResponse_contactMethods' - An array of objects that describe the contact methods. -- -- 'httpStatus', 'getContactMethodsResponse_httpStatus' - The response's http status code. newGetContactMethodsResponse :: -- | 'httpStatus' Prelude.Int -> GetContactMethodsResponse newGetContactMethodsResponse pHttpStatus_ = GetContactMethodsResponse' { contactMethods = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | An array of objects that describe the contact methods. getContactMethodsResponse_contactMethods :: Lens.Lens' GetContactMethodsResponse (Prelude.Maybe [ContactMethod]) getContactMethodsResponse_contactMethods = Lens.lens (\GetContactMethodsResponse' {contactMethods} -> contactMethods) (\s@GetContactMethodsResponse' {} a -> s {contactMethods = a} :: GetContactMethodsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. getContactMethodsResponse_httpStatus :: Lens.Lens' GetContactMethodsResponse Prelude.Int getContactMethodsResponse_httpStatus = Lens.lens (\GetContactMethodsResponse' {httpStatus} -> httpStatus) (\s@GetContactMethodsResponse' {} a -> s {httpStatus = a} :: GetContactMethodsResponse) instance Prelude.NFData GetContactMethodsResponse where rnf GetContactMethodsResponse' {..} = Prelude.rnf contactMethods `Prelude.seq` Prelude.rnf httpStatus