{-# 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.AppIntegrationS.GetDataIntegration -- 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 DataIntegration. -- -- You cannot create a DataIntegration association for a DataIntegration -- that has been previously associated. Use a different DataIntegration, or -- recreate the DataIntegration using the -- -- API. module Amazonka.AppIntegrationS.GetDataIntegration ( -- * Creating a Request GetDataIntegration (..), newGetDataIntegration, -- * Request Lenses getDataIntegration_identifier, -- * Destructuring the Response GetDataIntegrationResponse (..), newGetDataIntegrationResponse, -- * Response Lenses getDataIntegrationResponse_arn, getDataIntegrationResponse_description, getDataIntegrationResponse_id, getDataIntegrationResponse_kmsKey, getDataIntegrationResponse_name, getDataIntegrationResponse_scheduleConfiguration, getDataIntegrationResponse_sourceURI, getDataIntegrationResponse_tags, getDataIntegrationResponse_httpStatus, ) where import Amazonka.AppIntegrationS.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:/ 'newGetDataIntegration' smart constructor. data GetDataIntegration = GetDataIntegration' { -- | A unique identifier. identifier :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetDataIntegration' 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: -- -- 'identifier', 'getDataIntegration_identifier' - A unique identifier. newGetDataIntegration :: -- | 'identifier' Prelude.Text -> GetDataIntegration newGetDataIntegration pIdentifier_ = GetDataIntegration' {identifier = pIdentifier_} -- | A unique identifier. getDataIntegration_identifier :: Lens.Lens' GetDataIntegration Prelude.Text getDataIntegration_identifier = Lens.lens (\GetDataIntegration' {identifier} -> identifier) (\s@GetDataIntegration' {} a -> s {identifier = a} :: GetDataIntegration) instance Core.AWSRequest GetDataIntegration where type AWSResponse GetDataIntegration = GetDataIntegrationResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetDataIntegrationResponse' Prelude.<$> (x Data..?> "Arn") Prelude.<*> (x Data..?> "Description") Prelude.<*> (x Data..?> "Id") Prelude.<*> (x Data..?> "KmsKey") Prelude.<*> (x Data..?> "Name") Prelude.<*> (x Data..?> "ScheduleConfiguration") Prelude.<*> (x Data..?> "SourceURI") Prelude.<*> (x Data..?> "Tags" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetDataIntegration where hashWithSalt _salt GetDataIntegration' {..} = _salt `Prelude.hashWithSalt` identifier instance Prelude.NFData GetDataIntegration where rnf GetDataIntegration' {..} = Prelude.rnf identifier instance Data.ToHeaders GetDataIntegration where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath GetDataIntegration where toPath GetDataIntegration' {..} = Prelude.mconcat ["/dataIntegrations/", Data.toBS identifier] instance Data.ToQuery GetDataIntegration where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetDataIntegrationResponse' smart constructor. data GetDataIntegrationResponse = GetDataIntegrationResponse' { -- | The Amazon Resource Name (ARN) for the DataIntegration. arn :: Prelude.Maybe Prelude.Text, -- | The KMS key for the DataIntegration. description :: Prelude.Maybe Prelude.Text, -- | A unique identifier. id :: Prelude.Maybe Prelude.Text, -- | The KMS key for the DataIntegration. kmsKey :: Prelude.Maybe Prelude.Text, -- | The name of the DataIntegration. name :: Prelude.Maybe Prelude.Text, -- | The name of the data and how often it should be pulled from the source. scheduleConfiguration :: Prelude.Maybe ScheduleConfiguration, -- | The URI of the data source. sourceURI :: Prelude.Maybe Prelude.Text, -- | One or more tags. tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetDataIntegrationResponse' 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: -- -- 'arn', 'getDataIntegrationResponse_arn' - The Amazon Resource Name (ARN) for the DataIntegration. -- -- 'description', 'getDataIntegrationResponse_description' - The KMS key for the DataIntegration. -- -- 'id', 'getDataIntegrationResponse_id' - A unique identifier. -- -- 'kmsKey', 'getDataIntegrationResponse_kmsKey' - The KMS key for the DataIntegration. -- -- 'name', 'getDataIntegrationResponse_name' - The name of the DataIntegration. -- -- 'scheduleConfiguration', 'getDataIntegrationResponse_scheduleConfiguration' - The name of the data and how often it should be pulled from the source. -- -- 'sourceURI', 'getDataIntegrationResponse_sourceURI' - The URI of the data source. -- -- 'tags', 'getDataIntegrationResponse_tags' - One or more tags. -- -- 'httpStatus', 'getDataIntegrationResponse_httpStatus' - The response's http status code. newGetDataIntegrationResponse :: -- | 'httpStatus' Prelude.Int -> GetDataIntegrationResponse newGetDataIntegrationResponse pHttpStatus_ = GetDataIntegrationResponse' { arn = Prelude.Nothing, description = Prelude.Nothing, id = Prelude.Nothing, kmsKey = Prelude.Nothing, name = Prelude.Nothing, scheduleConfiguration = Prelude.Nothing, sourceURI = Prelude.Nothing, tags = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The Amazon Resource Name (ARN) for the DataIntegration. getDataIntegrationResponse_arn :: Lens.Lens' GetDataIntegrationResponse (Prelude.Maybe Prelude.Text) getDataIntegrationResponse_arn = Lens.lens (\GetDataIntegrationResponse' {arn} -> arn) (\s@GetDataIntegrationResponse' {} a -> s {arn = a} :: GetDataIntegrationResponse) -- | The KMS key for the DataIntegration. getDataIntegrationResponse_description :: Lens.Lens' GetDataIntegrationResponse (Prelude.Maybe Prelude.Text) getDataIntegrationResponse_description = Lens.lens (\GetDataIntegrationResponse' {description} -> description) (\s@GetDataIntegrationResponse' {} a -> s {description = a} :: GetDataIntegrationResponse) -- | A unique identifier. getDataIntegrationResponse_id :: Lens.Lens' GetDataIntegrationResponse (Prelude.Maybe Prelude.Text) getDataIntegrationResponse_id = Lens.lens (\GetDataIntegrationResponse' {id} -> id) (\s@GetDataIntegrationResponse' {} a -> s {id = a} :: GetDataIntegrationResponse) -- | The KMS key for the DataIntegration. getDataIntegrationResponse_kmsKey :: Lens.Lens' GetDataIntegrationResponse (Prelude.Maybe Prelude.Text) getDataIntegrationResponse_kmsKey = Lens.lens (\GetDataIntegrationResponse' {kmsKey} -> kmsKey) (\s@GetDataIntegrationResponse' {} a -> s {kmsKey = a} :: GetDataIntegrationResponse) -- | The name of the DataIntegration. getDataIntegrationResponse_name :: Lens.Lens' GetDataIntegrationResponse (Prelude.Maybe Prelude.Text) getDataIntegrationResponse_name = Lens.lens (\GetDataIntegrationResponse' {name} -> name) (\s@GetDataIntegrationResponse' {} a -> s {name = a} :: GetDataIntegrationResponse) -- | The name of the data and how often it should be pulled from the source. getDataIntegrationResponse_scheduleConfiguration :: Lens.Lens' GetDataIntegrationResponse (Prelude.Maybe ScheduleConfiguration) getDataIntegrationResponse_scheduleConfiguration = Lens.lens (\GetDataIntegrationResponse' {scheduleConfiguration} -> scheduleConfiguration) (\s@GetDataIntegrationResponse' {} a -> s {scheduleConfiguration = a} :: GetDataIntegrationResponse) -- | The URI of the data source. getDataIntegrationResponse_sourceURI :: Lens.Lens' GetDataIntegrationResponse (Prelude.Maybe Prelude.Text) getDataIntegrationResponse_sourceURI = Lens.lens (\GetDataIntegrationResponse' {sourceURI} -> sourceURI) (\s@GetDataIntegrationResponse' {} a -> s {sourceURI = a} :: GetDataIntegrationResponse) -- | One or more tags. getDataIntegrationResponse_tags :: Lens.Lens' GetDataIntegrationResponse (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) getDataIntegrationResponse_tags = Lens.lens (\GetDataIntegrationResponse' {tags} -> tags) (\s@GetDataIntegrationResponse' {} a -> s {tags = a} :: GetDataIntegrationResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. getDataIntegrationResponse_httpStatus :: Lens.Lens' GetDataIntegrationResponse Prelude.Int getDataIntegrationResponse_httpStatus = Lens.lens (\GetDataIntegrationResponse' {httpStatus} -> httpStatus) (\s@GetDataIntegrationResponse' {} a -> s {httpStatus = a} :: GetDataIntegrationResponse) instance Prelude.NFData GetDataIntegrationResponse where rnf GetDataIntegrationResponse' {..} = Prelude.rnf arn `Prelude.seq` Prelude.rnf description `Prelude.seq` Prelude.rnf id `Prelude.seq` Prelude.rnf kmsKey `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf scheduleConfiguration `Prelude.seq` Prelude.rnf sourceURI `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf httpStatus