{-# 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.SESV2.GetContactList -- 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 contact list metadata. It does not return any information about -- the contacts present in the list. module Amazonka.SESV2.GetContactList ( -- * Creating a Request GetContactList (..), newGetContactList, -- * Request Lenses getContactList_contactListName, -- * Destructuring the Response GetContactListResponse (..), newGetContactListResponse, -- * Response Lenses getContactListResponse_contactListName, getContactListResponse_createdTimestamp, getContactListResponse_description, getContactListResponse_lastUpdatedTimestamp, getContactListResponse_tags, getContactListResponse_topics, getContactListResponse_httpStatus, ) 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 qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.SESV2.Types -- | /See:/ 'newGetContactList' smart constructor. data GetContactList = GetContactList' { -- | The name of the contact list. contactListName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetContactList' 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: -- -- 'contactListName', 'getContactList_contactListName' - The name of the contact list. newGetContactList :: -- | 'contactListName' Prelude.Text -> GetContactList newGetContactList pContactListName_ = GetContactList' { contactListName = pContactListName_ } -- | The name of the contact list. getContactList_contactListName :: Lens.Lens' GetContactList Prelude.Text getContactList_contactListName = Lens.lens (\GetContactList' {contactListName} -> contactListName) (\s@GetContactList' {} a -> s {contactListName = a} :: GetContactList) instance Core.AWSRequest GetContactList where type AWSResponse GetContactList = GetContactListResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetContactListResponse' Prelude.<$> (x Data..?> "ContactListName") Prelude.<*> (x Data..?> "CreatedTimestamp") Prelude.<*> (x Data..?> "Description") Prelude.<*> (x Data..?> "LastUpdatedTimestamp") Prelude.<*> (x Data..?> "Tags" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "Topics" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetContactList where hashWithSalt _salt GetContactList' {..} = _salt `Prelude.hashWithSalt` contactListName instance Prelude.NFData GetContactList where rnf GetContactList' {..} = Prelude.rnf contactListName instance Data.ToHeaders GetContactList where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath GetContactList where toPath GetContactList' {..} = Prelude.mconcat [ "/v2/email/contact-lists/", Data.toBS contactListName ] instance Data.ToQuery GetContactList where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetContactListResponse' smart constructor. data GetContactListResponse = GetContactListResponse' { -- | The name of the contact list. contactListName :: Prelude.Maybe Prelude.Text, -- | A timestamp noting when the contact list was created. createdTimestamp :: Prelude.Maybe Data.POSIX, -- | A description of what the contact list is about. description :: Prelude.Maybe Prelude.Text, -- | A timestamp noting the last time the contact list was updated. lastUpdatedTimestamp :: Prelude.Maybe Data.POSIX, -- | The tags associated with a contact list. tags :: Prelude.Maybe [Tag], -- | An interest group, theme, or label within a list. A contact list can -- have multiple topics. topics :: Prelude.Maybe [Topic], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetContactListResponse' 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: -- -- 'contactListName', 'getContactListResponse_contactListName' - The name of the contact list. -- -- 'createdTimestamp', 'getContactListResponse_createdTimestamp' - A timestamp noting when the contact list was created. -- -- 'description', 'getContactListResponse_description' - A description of what the contact list is about. -- -- 'lastUpdatedTimestamp', 'getContactListResponse_lastUpdatedTimestamp' - A timestamp noting the last time the contact list was updated. -- -- 'tags', 'getContactListResponse_tags' - The tags associated with a contact list. -- -- 'topics', 'getContactListResponse_topics' - An interest group, theme, or label within a list. A contact list can -- have multiple topics. -- -- 'httpStatus', 'getContactListResponse_httpStatus' - The response's http status code. newGetContactListResponse :: -- | 'httpStatus' Prelude.Int -> GetContactListResponse newGetContactListResponse pHttpStatus_ = GetContactListResponse' { contactListName = Prelude.Nothing, createdTimestamp = Prelude.Nothing, description = Prelude.Nothing, lastUpdatedTimestamp = Prelude.Nothing, tags = Prelude.Nothing, topics = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The name of the contact list. getContactListResponse_contactListName :: Lens.Lens' GetContactListResponse (Prelude.Maybe Prelude.Text) getContactListResponse_contactListName = Lens.lens (\GetContactListResponse' {contactListName} -> contactListName) (\s@GetContactListResponse' {} a -> s {contactListName = a} :: GetContactListResponse) -- | A timestamp noting when the contact list was created. getContactListResponse_createdTimestamp :: Lens.Lens' GetContactListResponse (Prelude.Maybe Prelude.UTCTime) getContactListResponse_createdTimestamp = Lens.lens (\GetContactListResponse' {createdTimestamp} -> createdTimestamp) (\s@GetContactListResponse' {} a -> s {createdTimestamp = a} :: GetContactListResponse) Prelude.. Lens.mapping Data._Time -- | A description of what the contact list is about. getContactListResponse_description :: Lens.Lens' GetContactListResponse (Prelude.Maybe Prelude.Text) getContactListResponse_description = Lens.lens (\GetContactListResponse' {description} -> description) (\s@GetContactListResponse' {} a -> s {description = a} :: GetContactListResponse) -- | A timestamp noting the last time the contact list was updated. getContactListResponse_lastUpdatedTimestamp :: Lens.Lens' GetContactListResponse (Prelude.Maybe Prelude.UTCTime) getContactListResponse_lastUpdatedTimestamp = Lens.lens (\GetContactListResponse' {lastUpdatedTimestamp} -> lastUpdatedTimestamp) (\s@GetContactListResponse' {} a -> s {lastUpdatedTimestamp = a} :: GetContactListResponse) Prelude.. Lens.mapping Data._Time -- | The tags associated with a contact list. getContactListResponse_tags :: Lens.Lens' GetContactListResponse (Prelude.Maybe [Tag]) getContactListResponse_tags = Lens.lens (\GetContactListResponse' {tags} -> tags) (\s@GetContactListResponse' {} a -> s {tags = a} :: GetContactListResponse) Prelude.. Lens.mapping Lens.coerced -- | An interest group, theme, or label within a list. A contact list can -- have multiple topics. getContactListResponse_topics :: Lens.Lens' GetContactListResponse (Prelude.Maybe [Topic]) getContactListResponse_topics = Lens.lens (\GetContactListResponse' {topics} -> topics) (\s@GetContactListResponse' {} a -> s {topics = a} :: GetContactListResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. getContactListResponse_httpStatus :: Lens.Lens' GetContactListResponse Prelude.Int getContactListResponse_httpStatus = Lens.lens (\GetContactListResponse' {httpStatus} -> httpStatus) (\s@GetContactListResponse' {} a -> s {httpStatus = a} :: GetContactListResponse) instance Prelude.NFData GetContactListResponse where rnf GetContactListResponse' {..} = Prelude.rnf contactListName `Prelude.seq` Prelude.rnf createdTimestamp `Prelude.seq` Prelude.rnf description `Prelude.seq` Prelude.rnf lastUpdatedTimestamp `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf topics `Prelude.seq` Prelude.rnf httpStatus