{-# 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.LexV2Models.StartImport -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Starts importing a bot, bot locale, or custom vocabulary from a zip -- archive that you uploaded to an S3 bucket. module Amazonka.LexV2Models.StartImport ( -- * Creating a Request StartImport (..), newStartImport, -- * Request Lenses startImport_filePassword, startImport_importId, startImport_resourceSpecification, startImport_mergeStrategy, -- * Destructuring the Response StartImportResponse (..), newStartImportResponse, -- * Response Lenses startImportResponse_creationDateTime, startImportResponse_importId, startImportResponse_importStatus, startImportResponse_mergeStrategy, startImportResponse_resourceSpecification, startImportResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.LexV2Models.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newStartImport' smart constructor. data StartImport = StartImport' { -- | The password used to encrypt the zip archive that contains the resource -- definition. You should always encrypt the zip archive to protect it -- during transit between your site and Amazon Lex. filePassword :: Prelude.Maybe (Data.Sensitive Prelude.Text), -- | The unique identifier for the import. It is included in the response -- from the -- -- operation. importId :: Prelude.Text, -- | Parameters for creating the bot, bot locale or custom vocabulary. resourceSpecification :: ImportResourceSpecification, -- | The strategy to use when there is a name conflict between the imported -- resource and an existing resource. When the merge strategy is -- @FailOnConflict@ existing resources are not overwritten and the import -- fails. mergeStrategy :: MergeStrategy } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StartImport' 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: -- -- 'filePassword', 'startImport_filePassword' - The password used to encrypt the zip archive that contains the resource -- definition. You should always encrypt the zip archive to protect it -- during transit between your site and Amazon Lex. -- -- 'importId', 'startImport_importId' - The unique identifier for the import. It is included in the response -- from the -- -- operation. -- -- 'resourceSpecification', 'startImport_resourceSpecification' - Parameters for creating the bot, bot locale or custom vocabulary. -- -- 'mergeStrategy', 'startImport_mergeStrategy' - The strategy to use when there is a name conflict between the imported -- resource and an existing resource. When the merge strategy is -- @FailOnConflict@ existing resources are not overwritten and the import -- fails. newStartImport :: -- | 'importId' Prelude.Text -> -- | 'resourceSpecification' ImportResourceSpecification -> -- | 'mergeStrategy' MergeStrategy -> StartImport newStartImport pImportId_ pResourceSpecification_ pMergeStrategy_ = StartImport' { filePassword = Prelude.Nothing, importId = pImportId_, resourceSpecification = pResourceSpecification_, mergeStrategy = pMergeStrategy_ } -- | The password used to encrypt the zip archive that contains the resource -- definition. You should always encrypt the zip archive to protect it -- during transit between your site and Amazon Lex. startImport_filePassword :: Lens.Lens' StartImport (Prelude.Maybe Prelude.Text) startImport_filePassword = Lens.lens (\StartImport' {filePassword} -> filePassword) (\s@StartImport' {} a -> s {filePassword = a} :: StartImport) Prelude.. Lens.mapping Data._Sensitive -- | The unique identifier for the import. It is included in the response -- from the -- -- operation. startImport_importId :: Lens.Lens' StartImport Prelude.Text startImport_importId = Lens.lens (\StartImport' {importId} -> importId) (\s@StartImport' {} a -> s {importId = a} :: StartImport) -- | Parameters for creating the bot, bot locale or custom vocabulary. startImport_resourceSpecification :: Lens.Lens' StartImport ImportResourceSpecification startImport_resourceSpecification = Lens.lens (\StartImport' {resourceSpecification} -> resourceSpecification) (\s@StartImport' {} a -> s {resourceSpecification = a} :: StartImport) -- | The strategy to use when there is a name conflict between the imported -- resource and an existing resource. When the merge strategy is -- @FailOnConflict@ existing resources are not overwritten and the import -- fails. startImport_mergeStrategy :: Lens.Lens' StartImport MergeStrategy startImport_mergeStrategy = Lens.lens (\StartImport' {mergeStrategy} -> mergeStrategy) (\s@StartImport' {} a -> s {mergeStrategy = a} :: StartImport) instance Core.AWSRequest StartImport where type AWSResponse StartImport = StartImportResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> StartImportResponse' Prelude.<$> (x Data..?> "creationDateTime") Prelude.<*> (x Data..?> "importId") Prelude.<*> (x Data..?> "importStatus") Prelude.<*> (x Data..?> "mergeStrategy") Prelude.<*> (x Data..?> "resourceSpecification") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable StartImport where hashWithSalt _salt StartImport' {..} = _salt `Prelude.hashWithSalt` filePassword `Prelude.hashWithSalt` importId `Prelude.hashWithSalt` resourceSpecification `Prelude.hashWithSalt` mergeStrategy instance Prelude.NFData StartImport where rnf StartImport' {..} = Prelude.rnf filePassword `Prelude.seq` Prelude.rnf importId `Prelude.seq` Prelude.rnf resourceSpecification `Prelude.seq` Prelude.rnf mergeStrategy instance Data.ToHeaders StartImport where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON StartImport where toJSON StartImport' {..} = Data.object ( Prelude.catMaybes [ ("filePassword" Data..=) Prelude.<$> filePassword, Prelude.Just ("importId" Data..= importId), Prelude.Just ( "resourceSpecification" Data..= resourceSpecification ), Prelude.Just ("mergeStrategy" Data..= mergeStrategy) ] ) instance Data.ToPath StartImport where toPath = Prelude.const "/imports/" instance Data.ToQuery StartImport where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newStartImportResponse' smart constructor. data StartImportResponse = StartImportResponse' { -- | The date and time that the import request was created. creationDateTime :: Prelude.Maybe Data.POSIX, -- | A unique identifier for the import. importId :: Prelude.Maybe Prelude.Text, -- | The current status of the import. When the status is @Complete@ the bot, -- bot alias, or custom vocabulary is ready to use. importStatus :: Prelude.Maybe ImportStatus, -- | The strategy used when there was a name conflict between the imported -- resource and an existing resource. When the merge strategy is -- @FailOnConflict@ existing resources are not overwritten and the import -- fails. mergeStrategy :: Prelude.Maybe MergeStrategy, -- | The parameters used when importing the resource. resourceSpecification :: Prelude.Maybe ImportResourceSpecification, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StartImportResponse' 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: -- -- 'creationDateTime', 'startImportResponse_creationDateTime' - The date and time that the import request was created. -- -- 'importId', 'startImportResponse_importId' - A unique identifier for the import. -- -- 'importStatus', 'startImportResponse_importStatus' - The current status of the import. When the status is @Complete@ the bot, -- bot alias, or custom vocabulary is ready to use. -- -- 'mergeStrategy', 'startImportResponse_mergeStrategy' - The strategy used when there was a name conflict between the imported -- resource and an existing resource. When the merge strategy is -- @FailOnConflict@ existing resources are not overwritten and the import -- fails. -- -- 'resourceSpecification', 'startImportResponse_resourceSpecification' - The parameters used when importing the resource. -- -- 'httpStatus', 'startImportResponse_httpStatus' - The response's http status code. newStartImportResponse :: -- | 'httpStatus' Prelude.Int -> StartImportResponse newStartImportResponse pHttpStatus_ = StartImportResponse' { creationDateTime = Prelude.Nothing, importId = Prelude.Nothing, importStatus = Prelude.Nothing, mergeStrategy = Prelude.Nothing, resourceSpecification = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The date and time that the import request was created. startImportResponse_creationDateTime :: Lens.Lens' StartImportResponse (Prelude.Maybe Prelude.UTCTime) startImportResponse_creationDateTime = Lens.lens (\StartImportResponse' {creationDateTime} -> creationDateTime) (\s@StartImportResponse' {} a -> s {creationDateTime = a} :: StartImportResponse) Prelude.. Lens.mapping Data._Time -- | A unique identifier for the import. startImportResponse_importId :: Lens.Lens' StartImportResponse (Prelude.Maybe Prelude.Text) startImportResponse_importId = Lens.lens (\StartImportResponse' {importId} -> importId) (\s@StartImportResponse' {} a -> s {importId = a} :: StartImportResponse) -- | The current status of the import. When the status is @Complete@ the bot, -- bot alias, or custom vocabulary is ready to use. startImportResponse_importStatus :: Lens.Lens' StartImportResponse (Prelude.Maybe ImportStatus) startImportResponse_importStatus = Lens.lens (\StartImportResponse' {importStatus} -> importStatus) (\s@StartImportResponse' {} a -> s {importStatus = a} :: StartImportResponse) -- | The strategy used when there was a name conflict between the imported -- resource and an existing resource. When the merge strategy is -- @FailOnConflict@ existing resources are not overwritten and the import -- fails. startImportResponse_mergeStrategy :: Lens.Lens' StartImportResponse (Prelude.Maybe MergeStrategy) startImportResponse_mergeStrategy = Lens.lens (\StartImportResponse' {mergeStrategy} -> mergeStrategy) (\s@StartImportResponse' {} a -> s {mergeStrategy = a} :: StartImportResponse) -- | The parameters used when importing the resource. startImportResponse_resourceSpecification :: Lens.Lens' StartImportResponse (Prelude.Maybe ImportResourceSpecification) startImportResponse_resourceSpecification = Lens.lens (\StartImportResponse' {resourceSpecification} -> resourceSpecification) (\s@StartImportResponse' {} a -> s {resourceSpecification = a} :: StartImportResponse) -- | The response's http status code. startImportResponse_httpStatus :: Lens.Lens' StartImportResponse Prelude.Int startImportResponse_httpStatus = Lens.lens (\StartImportResponse' {httpStatus} -> httpStatus) (\s@StartImportResponse' {} a -> s {httpStatus = a} :: StartImportResponse) instance Prelude.NFData StartImportResponse where rnf StartImportResponse' {..} = Prelude.rnf creationDateTime `Prelude.seq` Prelude.rnf importId `Prelude.seq` Prelude.rnf importStatus `Prelude.seq` Prelude.rnf mergeStrategy `Prelude.seq` Prelude.rnf resourceSpecification `Prelude.seq` Prelude.rnf httpStatus