{-# 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.Comprehend.ContainsPiiEntities -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Analyzes input text for the presence of personally identifiable -- information (PII) and returns the labels of identified PII entity types -- such as name, address, bank account number, or phone number. module Amazonka.Comprehend.ContainsPiiEntities ( -- * Creating a Request ContainsPiiEntities (..), newContainsPiiEntities, -- * Request Lenses containsPiiEntities_text, containsPiiEntities_languageCode, -- * Destructuring the Response ContainsPiiEntitiesResponse (..), newContainsPiiEntitiesResponse, -- * Response Lenses containsPiiEntitiesResponse_labels, containsPiiEntitiesResponse_httpStatus, ) where import Amazonka.Comprehend.Types 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 -- | /See:/ 'newContainsPiiEntities' smart constructor. data ContainsPiiEntities = ContainsPiiEntities' { -- | A UTF-8 text string. The maximum string size is 100 KB. text :: Prelude.Text, -- | The language of the input documents. Currently, English is the only -- valid language. languageCode :: LanguageCode } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ContainsPiiEntities' 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: -- -- 'text', 'containsPiiEntities_text' - A UTF-8 text string. The maximum string size is 100 KB. -- -- 'languageCode', 'containsPiiEntities_languageCode' - The language of the input documents. Currently, English is the only -- valid language. newContainsPiiEntities :: -- | 'text' Prelude.Text -> -- | 'languageCode' LanguageCode -> ContainsPiiEntities newContainsPiiEntities pText_ pLanguageCode_ = ContainsPiiEntities' { text = pText_, languageCode = pLanguageCode_ } -- | A UTF-8 text string. The maximum string size is 100 KB. containsPiiEntities_text :: Lens.Lens' ContainsPiiEntities Prelude.Text containsPiiEntities_text = Lens.lens (\ContainsPiiEntities' {text} -> text) (\s@ContainsPiiEntities' {} a -> s {text = a} :: ContainsPiiEntities) -- | The language of the input documents. Currently, English is the only -- valid language. containsPiiEntities_languageCode :: Lens.Lens' ContainsPiiEntities LanguageCode containsPiiEntities_languageCode = Lens.lens (\ContainsPiiEntities' {languageCode} -> languageCode) (\s@ContainsPiiEntities' {} a -> s {languageCode = a} :: ContainsPiiEntities) instance Core.AWSRequest ContainsPiiEntities where type AWSResponse ContainsPiiEntities = ContainsPiiEntitiesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ContainsPiiEntitiesResponse' Prelude.<$> (x Data..?> "Labels" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ContainsPiiEntities where hashWithSalt _salt ContainsPiiEntities' {..} = _salt `Prelude.hashWithSalt` text `Prelude.hashWithSalt` languageCode instance Prelude.NFData ContainsPiiEntities where rnf ContainsPiiEntities' {..} = Prelude.rnf text `Prelude.seq` Prelude.rnf languageCode instance Data.ToHeaders ContainsPiiEntities where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Comprehend_20171127.ContainsPiiEntities" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ContainsPiiEntities where toJSON ContainsPiiEntities' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("Text" Data..= text), Prelude.Just ("LanguageCode" Data..= languageCode) ] ) instance Data.ToPath ContainsPiiEntities where toPath = Prelude.const "/" instance Data.ToQuery ContainsPiiEntities where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newContainsPiiEntitiesResponse' smart constructor. data ContainsPiiEntitiesResponse = ContainsPiiEntitiesResponse' { -- | The labels used in the document being analyzed. Individual labels -- represent personally identifiable information (PII) entity types. labels :: Prelude.Maybe [EntityLabel], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ContainsPiiEntitiesResponse' 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: -- -- 'labels', 'containsPiiEntitiesResponse_labels' - The labels used in the document being analyzed. Individual labels -- represent personally identifiable information (PII) entity types. -- -- 'httpStatus', 'containsPiiEntitiesResponse_httpStatus' - The response's http status code. newContainsPiiEntitiesResponse :: -- | 'httpStatus' Prelude.Int -> ContainsPiiEntitiesResponse newContainsPiiEntitiesResponse pHttpStatus_ = ContainsPiiEntitiesResponse' { labels = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The labels used in the document being analyzed. Individual labels -- represent personally identifiable information (PII) entity types. containsPiiEntitiesResponse_labels :: Lens.Lens' ContainsPiiEntitiesResponse (Prelude.Maybe [EntityLabel]) containsPiiEntitiesResponse_labels = Lens.lens (\ContainsPiiEntitiesResponse' {labels} -> labels) (\s@ContainsPiiEntitiesResponse' {} a -> s {labels = a} :: ContainsPiiEntitiesResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. containsPiiEntitiesResponse_httpStatus :: Lens.Lens' ContainsPiiEntitiesResponse Prelude.Int containsPiiEntitiesResponse_httpStatus = Lens.lens (\ContainsPiiEntitiesResponse' {httpStatus} -> httpStatus) (\s@ContainsPiiEntitiesResponse' {} a -> s {httpStatus = a} :: ContainsPiiEntitiesResponse) instance Prelude.NFData ContainsPiiEntitiesResponse where rnf ContainsPiiEntitiesResponse' {..} = Prelude.rnf labels `Prelude.seq` Prelude.rnf httpStatus